mirror of
https://github.com/flutter/flutter.git
synced 2026-02-20 02:29:02 +08:00
98 lines
3.1 KiB
Dart
98 lines
3.1 KiB
Dart
// Copyright 2015 The Chromium Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
import '../resources/third_party/unittest/unittest.dart';
|
|
import '../resources/unit.dart';
|
|
import '../resources/display_list.dart';
|
|
import 'dart:sky' as sky;
|
|
import 'package:sky/framework/app.dart';
|
|
import 'package:sky/framework/rendering/block.dart';
|
|
import 'package:sky/framework/rendering/box.dart';
|
|
import 'package:sky/framework/rendering/flex.dart';
|
|
|
|
class RenderSolidColor extends RenderDecoratedBox {
|
|
final sky.Size desiredSize;
|
|
final int backgroundColor;
|
|
|
|
RenderSolidColor(int backgroundColor, { this.desiredSize: const sky.Size.infinite() })
|
|
: backgroundColor = backgroundColor,
|
|
super(decoration: new BoxDecoration(backgroundColor: backgroundColor)) {
|
|
}
|
|
|
|
sky.Size getIntrinsicDimensions(BoxConstraints constraints) {
|
|
return constraints.constrain(desiredSize);
|
|
}
|
|
|
|
void performLayout() {
|
|
size = constraints.constrain(desiredSize);
|
|
}
|
|
|
|
void handlePointer(sky.PointerEvent event) {
|
|
if (event.type == 'pointerdown')
|
|
decoration = new BoxDecoration(backgroundColor: 0xFFFF0000);
|
|
else if (event.type == 'pointerup')
|
|
decoration = new BoxDecoration(backgroundColor: backgroundColor);
|
|
}
|
|
}
|
|
|
|
TestApp app;
|
|
|
|
void main() {
|
|
initUnit();
|
|
|
|
test("should flex", () {
|
|
RenderFlex flexRoot = new RenderFlex(direction: FlexDirection.Vertical);
|
|
|
|
RenderDecoratedBox root = new RenderDecoratedBox(
|
|
decoration: new BoxDecoration(backgroundColor: 0xFF000000),
|
|
child: flexRoot
|
|
);
|
|
|
|
void addFlexChildSolidColor(RenderFlex parent, int backgroundColor, { int flex: 0 }) {
|
|
RenderSolidColor child = new RenderSolidColor(backgroundColor);
|
|
parent.add(child);
|
|
child.parentData.flex = flex;
|
|
}
|
|
|
|
// Yellow bar at top
|
|
addFlexChildSolidColor(flexRoot, 0xFFFFFF00, flex: 1);
|
|
|
|
// Turquoise box
|
|
flexRoot.add(new RenderSolidColor(0x7700FFFF, desiredSize: new sky.Size(100.0, 100.0)));
|
|
|
|
// Green and cyan render block with padding
|
|
var renderBlock = new RenderBlock();
|
|
|
|
renderBlock.add(new RenderSolidColor(0xFF00FF00, desiredSize: new sky.Size(100.0, 50.0)));
|
|
renderBlock.add(new RenderSolidColor(0x7700FFFF, desiredSize: new sky.Size(50.0, 100.0)));
|
|
|
|
var renderDecoratedBlock = new RenderDecoratedBox(
|
|
decoration: new BoxDecoration(backgroundColor: 0xFFFFFFFF),
|
|
child: renderBlock
|
|
);
|
|
|
|
flexRoot.add(new RenderPadding(const EdgeDims(10.0, 10.0, 10.0, 10.0), renderDecoratedBlock));
|
|
|
|
var row = new RenderFlex(direction: FlexDirection.Horizontal);
|
|
|
|
// Purple and blue cells
|
|
addFlexChildSolidColor(row, 0x77FF00FF, flex: 1);
|
|
addFlexChildSolidColor(row, 0xFF0000FF, flex: 2);
|
|
|
|
var decoratedRow = new RenderDecoratedBox(
|
|
decoration: new BoxDecoration(backgroundColor: 0xFF333333),
|
|
child: row
|
|
);
|
|
|
|
flexRoot.add(decoratedRow);
|
|
decoratedRow.parentData.flex = 3;
|
|
app = new TestApp(root);
|
|
|
|
expect(root.size.width, equals(sky.view.width));
|
|
expect(root.size.height, equals(sky.view.height));
|
|
expect(renderBlock.size.width, equals(sky.view.width - 20.0));
|
|
|
|
});
|
|
}
|