Commit 71976b30 authored by Hixie's avatar Hixie

Fix RenderFractionallySizedBox's constraints logic

Fixes https://github.com/flutter/flutter/issues/2735
parent b00cf22e
...@@ -247,15 +247,15 @@ class RenderConstrainedBox extends RenderProxyBox { ...@@ -247,15 +247,15 @@ class RenderConstrainedBox extends RenderProxyBox {
} }
} }
/// Sizes itself to a fraction of the total available space. /// Sizes its child to a fraction of the total available space.
/// ///
/// For both its width and width height, this render object imposes a tight /// For both its width and height, this render object imposes a tight
/// constraint on its child that is a multiple (typically less than 1.0) of the /// constraint on its child that is a multiple (typically less than 1.0) of the
/// maximum constraint it received from its parent on that axis. If the factor /// maximum constraint it received from its parent on that axis. If the factor
/// for a given axis is null, then the constraints from the parent are just /// for a given axis is null, then the constraints from the parent are just
/// passed through instead. /// passed through instead.
/// ///
/// It then tries to size itself t the size of its child. /// It then tries to size itself to the size of its child.
class RenderFractionallySizedBox extends RenderProxyBox { class RenderFractionallySizedBox extends RenderProxyBox {
RenderFractionallySizedBox({ RenderFractionallySizedBox({
RenderBox child, RenderBox child,
...@@ -323,41 +323,41 @@ class RenderFractionallySizedBox extends RenderProxyBox { ...@@ -323,41 +323,41 @@ class RenderFractionallySizedBox extends RenderProxyBox {
double getMinIntrinsicWidth(BoxConstraints constraints) { double getMinIntrinsicWidth(BoxConstraints constraints) {
assert(constraints.debugAssertIsNormalized); assert(constraints.debugAssertIsNormalized);
if (child != null) if (child != null)
return child.getMinIntrinsicWidth(_getInnerConstraints(constraints)); return constraints.constrainWidth(child.getMinIntrinsicWidth(_getInnerConstraints(constraints)));
return _getInnerConstraints(constraints).constrainWidth(0.0); return constraints.constrainWidth(_getInnerConstraints(constraints).constrainWidth(0.0));
} }
@override @override
double getMaxIntrinsicWidth(BoxConstraints constraints) { double getMaxIntrinsicWidth(BoxConstraints constraints) {
assert(constraints.debugAssertIsNormalized); assert(constraints.debugAssertIsNormalized);
if (child != null) if (child != null)
return child.getMaxIntrinsicWidth(_getInnerConstraints(constraints)); return constraints.constrainWidth(child.getMaxIntrinsicWidth(_getInnerConstraints(constraints)));
return _getInnerConstraints(constraints).constrainWidth(0.0); return constraints.constrainWidth(_getInnerConstraints(constraints).constrainWidth(0.0));
} }
@override @override
double getMinIntrinsicHeight(BoxConstraints constraints) { double getMinIntrinsicHeight(BoxConstraints constraints) {
assert(constraints.debugAssertIsNormalized); assert(constraints.debugAssertIsNormalized);
if (child != null) if (child != null)
return child.getMinIntrinsicHeight(_getInnerConstraints(constraints)); return constraints.constrainHeight(child.getMinIntrinsicHeight(_getInnerConstraints(constraints)));
return _getInnerConstraints(constraints).constrainHeight(0.0); return constraints.constrainHeight(_getInnerConstraints(constraints).constrainHeight(0.0));
} }
@override @override
double getMaxIntrinsicHeight(BoxConstraints constraints) { double getMaxIntrinsicHeight(BoxConstraints constraints) {
assert(constraints.debugAssertIsNormalized); assert(constraints.debugAssertIsNormalized);
if (child != null) if (child != null)
return child.getMaxIntrinsicHeight(_getInnerConstraints(constraints)); return constraints.constrainHeight(child.getMaxIntrinsicHeight(_getInnerConstraints(constraints)));
return _getInnerConstraints(constraints).constrainHeight(0.0); return constraints.constrainHeight(_getInnerConstraints(constraints).constrainHeight(0.0));
} }
@override @override
void performLayout() { void performLayout() {
if (child != null) { if (child != null) {
child.layout(_getInnerConstraints(constraints), parentUsesSize: true); child.layout(_getInnerConstraints(constraints), parentUsesSize: true);
size = child.size; size = constraints.constrain(child.size);
} else { } else {
size = _getInnerConstraints(constraints).constrain(Size.zero); size = constraints.constrain(_getInnerConstraints(constraints).constrain(Size.zero));
} }
} }
......
// 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 'package:flutter/rendering.dart';
import 'package:test/test.dart';
import 'rendering_tester.dart';
void main() {
test("RenderFractionallySizedBox constraints", () {
RenderBox root, leaf, test;
root = new RenderPositionedBox(
child: new RenderConstrainedBox(
additionalConstraints: new BoxConstraints.tight(const Size(200.0, 200.0)),
child: test = new RenderFractionallySizedBox(
widthFactor: 2.0,
heightFactor: 0.5,
child: leaf = new RenderConstrainedBox(
additionalConstraints: const BoxConstraints.expand()
)
)
)
);
layout(root);
expect(root.size.width, equals(800.0));
expect(root.size.height, equals(600.0));
expect(test.size.width, equals(200.0));
expect(test.size.height, equals(200.0));
expect(leaf.size.width, equals(400.0));
expect(leaf.size.height, equals(100.0));
});
}
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