Chromium Code Reviews| Index: sky/examples/raw/simple_render_tree.dart |
| diff --git a/sky/examples/raw/simple_render_tree.dart b/sky/examples/raw/simple_render_tree.dart |
| index a9e559b0ac463e4a76993062457d67cc548bd9ee..8617d4172acb13a1915a46e3ef8cd383b52ee5d0 100644 |
| --- a/sky/examples/raw/simple_render_tree.dart |
| +++ b/sky/examples/raw/simple_render_tree.dart |
| @@ -7,19 +7,26 @@ import 'dart:sky'; |
| import 'package:sky/framework/layout2.dart'; |
| class RenderSolidColor extends RenderDecoratedBox { |
| + final double desiredHeight; |
| + final double desiredWidth; |
| final int backgroundColor; |
| - RenderSolidColor(int backgroundColor) |
| - : super(new BoxDecoration(backgroundColor: backgroundColor)), |
| - backgroundColor = backgroundColor; |
| + RenderSolidColor(int backgroundColor, { double desiredHeight: double.INFINITY, |
| + double desiredWidth: double.INFINITY }) |
| + : desiredHeight = desiredHeight, |
| + desiredWidth = desiredWidth, |
| + backgroundColor = backgroundColor, |
| + super(new BoxDecoration(backgroundColor: backgroundColor)); |
| BoxDimensions getIntrinsicDimensions(BoxConstraints constraints) { |
| - return new BoxDimensions.withConstraints(constraints, height: 200.0); |
| + return new BoxDimensions.withConstraints(constraints, |
| + height: desiredHeight, |
| + width: desiredWidth); |
| } |
| void layout(BoxConstraints constraints, { RenderNode relayoutSubtreeRoot }) { |
| - width = constraints.constrainWidth(constraints.maxWidth); |
| - height = constraints.constrainHeight(200.0); |
| + width = constraints.constrainWidth(desiredWidth); |
| + height = constraints.constrainHeight(desiredHeight); |
| layoutDone(); |
| } |
| @@ -56,12 +63,44 @@ void main() { |
| view.setEventCallback(handleEvent); |
| view.setBeginFrameCallback(beginFrame); |
| - var root = new RenderBlock( |
| - decoration: new BoxDecoration(backgroundColor: 0xFF00FFFF), |
| + var root = new RenderFlex( |
| + direction: FlexDirection.Vertical, |
| + decoration: new BoxDecoration(backgroundColor: 0xFF000000)); |
| + |
| + void addFlexChild(RenderFlex renderFlex, int backgroundColor, { int flex: 0 }) { |
|
Hixie
2015/05/23 00:34:20
renderFlex => parent
|
| + RenderNode child = new RenderSolidColor(backgroundColor); |
| + renderFlex.add(child); |
| + renderFlex.setParentData(child); |
|
Hixie
2015/05/23 00:34:20
add() implies setParentData()
|
| + child.parentData.flex = flex; |
| + } |
| + |
| + // Yellow bar at top |
| + addFlexChild(root, 0xFFFFFF00, flex: 1); |
| + |
| + // Turquoise box |
| + root.add(new RenderSolidColor(0x7700FFFF, desiredHeight: 100.0, desiredWidth: 100.0)); |
| + |
| + // Green and cyan render block with padding |
| + var renderBlock = new RenderBlock( |
| + decoration: new BoxDecoration(backgroundColor: 0xFFFFFFFF), |
| padding: const EdgeDims(10.0, 10.0, 10.0, 10.0)); |
| - root.add(new RenderSolidColor(0xFF00FF00)); |
| - root.add(new RenderSolidColor(0xFF0000FF)); |
| + renderBlock.add(new RenderSolidColor(0xFF00FF00, desiredHeight: 50.0, desiredWidth: 100.0)); |
| + renderBlock.add(new RenderSolidColor(0x7700FFFF, desiredHeight: 100.0, desiredWidth: 50.0)); |
| + |
| + root.add(renderBlock); |
| + |
| + var row = new RenderFlex( |
| + direction: FlexDirection.Horizontal, |
| + decoration: new BoxDecoration(backgroundColor: 0xFF333333)); |
| + |
| + // Purple and blue cells |
| + addFlexChild(row, 0x77FF00FF, flex: 1); |
| + addFlexChild(row, 0xFF0000FF, flex: 2); |
| + |
| + root.add(row); |
| + root.setParentData(row); |
| + row.parentData.flex = 3; |
| renderView = new RenderView(root: root); |
| renderView.layout(newWidth: view.width, newHeight: view.height); |