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

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

Issue 1149063007: Expose the RenderView root through the AppView, so that you can change it. (Closed) Base URL: https://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.attach();
15 _renderView.layout(newWidth: sky.view.width, newHeight: sky.view.height); 16 _renderView.layout(newWidth: sky.view.width, newHeight: sky.view.height);
16 17
17 sky.view.scheduleFrame(); 18 sky.view.scheduleFrame();
18 } 19 }
19 20
20 RenderView _renderView; 21 RenderView _renderView;
21 22
23 RenderBox get root => _renderView.root;
24 void set root(RenderBox value) {
25 _renderView.root = value;
abarth-chromium 2015/05/27 16:52:48 Do we need to schedule a frame here?
Hixie 2015/05/27 17:41:47 The "root" setter on RenderView takes care of that
26 }
27
22 void _beginFrame(double timeStamp) { 28 void _beginFrame(double timeStamp) {
23 RenderNode.flushLayout(); 29 RenderNode.flushLayout();
24 _renderView.paintFrame(); 30 _renderView.paintFrame();
25 } 31 }
26 32
27 void _handleEvent(sky.Event event) { 33 void _handleEvent(sky.Event event) {
28 if (event is! sky.PointerEvent) 34 if (event is! sky.PointerEvent)
29 return; 35 return;
30 HitTestResult result = new HitTestResult(); 36 HitTestResult result = new HitTestResult();
31 _renderView.hitTest(result, x: event.x, y: event.y); 37 _renderView.hitTest(result, x: event.x, y: event.y);
32 result.path.reversed.forEach((RenderNode node) { 38 result.path.reversed.forEach((RenderNode node) {
33 node.handlePointer(event); 39 node.handlePointer(event);
34 }); 40 });
35 } 41 }
36 42
37 } 43 }
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