Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(103)

Side by Side Diff: sky/sdk/lib/framework/app.dart

Issue 1158933004: In Sky framework AppView, cache the hit test result for pointer events and continue using that resu… (Closed) Base URL: git@github.com:domokit/mojo.git@master
Patch Set: Created 5 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 import 'layout2.dart'; 5 import 'layout2.dart';
6 import 'dart:sky' as sky; 6 import 'dart:sky' as sky;
7 7
8 class AppView { 8 class AppView {
9 9
10 AppView(RenderBox root) { 10 AppView(RenderBox root) {
11 sky.view.setEventCallback(_handleEvent); 11 sky.view.setEventCallback(_handleEvent);
12 sky.view.setBeginFrameCallback(_beginFrame); 12 sky.view.setBeginFrameCallback(_beginFrame);
13 13
14 _renderView = new RenderView(root: root); 14 _renderView = new RenderView(root: root);
15 _renderView.layout(newWidth: sky.view.width, newHeight: sky.view.height); 15 _renderView.layout(newWidth: sky.view.width, newHeight: sky.view.height);
16 16
17 _hitTestResultForPointer = new Map<int, HitTestResult>();
abarth-chromium 2015/05/27 18:13:19 You can actually do this work on line 24 directly.
18
17 sky.view.scheduleFrame(); 19 sky.view.scheduleFrame();
18 } 20 }
19 21
20 RenderView _renderView; 22 RenderView _renderView;
21 23
24 Map<int, HitTestResult> _hitTestResultForPointer;
abarth-chromium 2015/05/27 18:13:19 final Map<int, HitTestResult> _hitTestResultForPoi
25
22 void _beginFrame(double timeStamp) { 26 void _beginFrame(double timeStamp) {
23 RenderNode.flushLayout(); 27 RenderNode.flushLayout();
24 _renderView.paintFrame(); 28 _renderView.paintFrame();
25 } 29 }
26 30
27 void _handleEvent(sky.Event event) { 31 void _handleEvent(sky.Event event) {
28 if (event is! sky.PointerEvent) 32 if (event is sky.PointerEvent)
29 return; 33 _handlePointerEvent(event);
30 HitTestResult result = new HitTestResult(); 34 }
31 _renderView.hitTest(result, x: event.x, y: event.y); 35
36 void _handlePointerEvent(sky.PointerEvent event) {
37 HitTestResult result;
38 switch(event.type) {
39 case 'pointerdown':
40 result = new HitTestResult();
41 _renderView.hitTest(result, x: event.x, y: event.y);
42 _hitTestResultForPointer[event.pointer] = result;
43 break;
44 case 'pointerup':
45 case 'pointercancel':
46 result = _hitTestResultForPointer[event.pointer];
47 _hitTestResultForPointer.remove(event.pointer);
48 break;
49 case 'pointermove':
50 result = _hitTestResultForPointer[event.pointer];
51 break;
52 }
32 result.path.reversed.forEach((RenderNode node) { 53 result.path.reversed.forEach((RenderNode node) {
abarth-chromium 2015/05/27 18:13:19 I'd add an assert(result != null)
33 node.handlePointer(event); 54 node.handlePointer(event);
34 }); 55 });
35 } 56 }
36 57
37 } 58 }
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698