Commit 400d6df7 authored by Adam Barth's avatar Adam Barth

Actually perform a block layout

This CL teaches simple_render_tree how to do a block layout using layout2.dart.

R=eseidel@chromium.org, ianh@google.com

Review URL: https://codereview.chromium.org/1144423002
parent 3a6cab2c
...@@ -6,16 +6,29 @@ import 'dart:math'; ...@@ -6,16 +6,29 @@ import 'dart:math';
import 'dart:sky'; import 'dart:sky';
import 'package:sky/framework/layout2.dart'; import 'package:sky/framework/layout2.dart';
class RenderBlueCircle extends RenderBox { class RenderSolidColor extends RenderDecoratedBox {
void paint(RenderNodeDisplayList canvas) { RenderSolidColor(int backgroundColor)
double radius = min(width, height) * 0.45; : super(new BoxDecoration(backgroundColor: backgroundColor));
Paint paint = new Paint()..setARGB(255, 0, 255, 255);
canvas.drawCircle(width / 2, height / 2, radius, paint); BoxDimensions getIntrinsicDimensions(BoxConstraints constraints) {
return new BoxDimensions.withConstraints(constraints, height: 200.0);
}
void layout(BoxConstraints constraints, { RenderNode relayoutSubtreeRoot }) {
setWidth(constraints, constraints.maxWidth);
setHeight(constraints, 200.0);
layoutDone();
} }
} }
void main() { void main() {
RenderView renderView = new RenderView(root: new RenderBlueCircle()); var root = new RenderBlock(
decoration: new BoxDecoration(backgroundColor: 0xFF00FFFF));
root.add(new RenderSolidColor(0xFF00FF00));
root.add(new RenderSolidColor(0xFF0000FF));
RenderView renderView = new RenderView(root: root);
renderView.layout(newWidth: view.width, newHeight: view.height); renderView.layout(newWidth: view.width, newHeight: view.height);
renderView.paintFrame(); renderView.paintFrame();
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment