Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Sign in
Toggle navigation
F
Front-End
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
abdullh.alsoleman
Front-End
Commits
1770004e
Commit
1770004e
authored
Jan 18, 2016
by
Ian Hickson
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #1291 from Hixie/block-intrinsics
Fix some intrinsic constraints contract violations.
parents
aa701d44
60d9ab7e
Changes
9
Show whitespace changes
Inline
Side-by-side
Showing
9 changed files
with
151 additions
and
36 deletions
+151
-36
block.dart
packages/flutter/lib/src/rendering/block.dart
+17
-13
box.dart
packages/flutter/lib/src/rendering/box.dart
+15
-0
object.dart
packages/flutter/lib/src/rendering/object.dart
+52
-12
shifted_box.dart
packages/flutter/lib/src/rendering/shifted_box.dart
+4
-4
viewport.dart
packages/flutter/lib/src/rendering/viewport.dart
+4
-4
mixed_viewport.dart
packages/flutter/lib/src/widgets/mixed_viewport.dart
+1
-1
block_test.dart
packages/flutter/test/rendering/block_test.dart
+48
-0
custom_multi_child_layout_test.dart
...s/flutter/test/widget/custom_multi_child_layout_test.dart
+4
-1
custom_one_child_layout_test.dart
...ges/flutter/test/widget/custom_one_child_layout_test.dart
+6
-1
No files found.
packages/flutter/lib/src/rendering/block.dart
View file @
1770004e
...
@@ -131,7 +131,7 @@ class RenderBlock extends RenderBlockBase {
...
@@ -131,7 +131,7 @@ class RenderBlock extends RenderBlockBase {
double
minExtent:
0.0
double
minExtent:
0.0
})
:
super
(
children:
children
,
direction:
direction
,
itemExtent:
itemExtent
,
minExtent:
minExtent
);
})
:
super
(
children:
children
,
direction:
direction
,
itemExtent:
itemExtent
,
minExtent:
minExtent
);
double
_getIntrinsicCrossAxis
(
BoxConstraints
constraints
,
_ChildSizingFunction
childSize
)
{
double
_getIntrinsicCrossAxis
(
BoxConstraints
constraints
,
_ChildSizingFunction
childSize
,
_Constrainer
constrainer
)
{
double
extent
=
0.0
;
double
extent
=
0.0
;
BoxConstraints
innerConstraints
=
isVertical
?
constraints
.
widthConstraints
()
:
constraints
.
heightConstraints
();
BoxConstraints
innerConstraints
=
isVertical
?
constraints
.
widthConstraints
()
:
constraints
.
heightConstraints
();
RenderBox
child
=
firstChild
;
RenderBox
child
=
firstChild
;
...
@@ -140,10 +140,10 @@ class RenderBlock extends RenderBlockBase {
...
@@ -140,10 +140,10 @@ class RenderBlock extends RenderBlockBase {
final
BlockParentData
childParentData
=
child
.
parentData
;
final
BlockParentData
childParentData
=
child
.
parentData
;
child
=
childParentData
.
nextSibling
;
child
=
childParentData
.
nextSibling
;
}
}
return
extent
;
return
constrainer
(
extent
)
;
}
}
double
_getIntrinsicMainAxis
(
BoxConstraints
constraints
)
{
double
_getIntrinsicMainAxis
(
BoxConstraints
constraints
,
_Constrainer
constrainer
)
{
double
extent
=
0.0
;
double
extent
=
0.0
;
BoxConstraints
innerConstraints
=
_getInnerConstraints
(
constraints
);
BoxConstraints
innerConstraints
=
_getInnerConstraints
(
constraints
);
RenderBox
child
=
firstChild
;
RenderBox
child
=
firstChild
;
...
@@ -160,7 +160,7 @@ class RenderBlock extends RenderBlockBase {
...
@@ -160,7 +160,7 @@ class RenderBlock extends RenderBlockBase {
final
BlockParentData
childParentData
=
child
.
parentData
;
final
BlockParentData
childParentData
=
child
.
parentData
;
child
=
childParentData
.
nextSibling
;
child
=
childParentData
.
nextSibling
;
}
}
return
math
.
max
(
extent
,
minExtent
);
return
constrainer
(
math
.
max
(
extent
,
minExtent
)
);
}
}
double
getMinIntrinsicWidth
(
BoxConstraints
constraints
)
{
double
getMinIntrinsicWidth
(
BoxConstraints
constraints
)
{
...
@@ -168,10 +168,11 @@ class RenderBlock extends RenderBlockBase {
...
@@ -168,10 +168,11 @@ class RenderBlock extends RenderBlockBase {
if
(
isVertical
)
{
if
(
isVertical
)
{
return
_getIntrinsicCrossAxis
(
return
_getIntrinsicCrossAxis
(
constraints
,
constraints
,
(
RenderBox
child
,
BoxConstraints
innerConstraints
)
=>
child
.
getMinIntrinsicWidth
(
innerConstraints
)
(
RenderBox
child
,
BoxConstraints
innerConstraints
)
=>
child
.
getMinIntrinsicWidth
(
innerConstraints
),
constraints
.
constrainWidth
);
);
}
}
return
_getIntrinsicMainAxis
(
constraints
);
return
_getIntrinsicMainAxis
(
constraints
,
constraints
.
constrainWidth
);
}
}
double
getMaxIntrinsicWidth
(
BoxConstraints
constraints
)
{
double
getMaxIntrinsicWidth
(
BoxConstraints
constraints
)
{
...
@@ -179,29 +180,32 @@ class RenderBlock extends RenderBlockBase {
...
@@ -179,29 +180,32 @@ class RenderBlock extends RenderBlockBase {
if
(
isVertical
)
{
if
(
isVertical
)
{
return
_getIntrinsicCrossAxis
(
return
_getIntrinsicCrossAxis
(
constraints
,
constraints
,
(
RenderBox
child
,
BoxConstraints
innerConstraints
)
=>
child
.
getMaxIntrinsicWidth
(
innerConstraints
)
(
RenderBox
child
,
BoxConstraints
innerConstraints
)
=>
child
.
getMaxIntrinsicWidth
(
innerConstraints
),
constraints
.
constrainWidth
);
);
}
}
return
_getIntrinsicMainAxis
(
constraints
);
return
_getIntrinsicMainAxis
(
constraints
,
constraints
.
constrainWidth
);
}
}
double
getMinIntrinsicHeight
(
BoxConstraints
constraints
)
{
double
getMinIntrinsicHeight
(
BoxConstraints
constraints
)
{
assert
(
constraints
.
isNormalized
);
assert
(
constraints
.
isNormalized
);
if
(
isVertical
)
if
(
isVertical
)
return
_getIntrinsicMainAxis
(
constraints
);
return
_getIntrinsicMainAxis
(
constraints
,
constraints
.
constrainHeight
);
return
_getIntrinsicCrossAxis
(
return
_getIntrinsicCrossAxis
(
constraints
,
constraints
,
(
RenderBox
child
,
BoxConstraints
innerConstraints
)
=>
child
.
getMinIntrinsicWidth
(
innerConstraints
)
(
RenderBox
child
,
BoxConstraints
innerConstraints
)
=>
child
.
getMinIntrinsicWidth
(
innerConstraints
),
constraints
.
constrainHeight
);
);
}
}
double
getMaxIntrinsicHeight
(
BoxConstraints
constraints
)
{
double
getMaxIntrinsicHeight
(
BoxConstraints
constraints
)
{
assert
(
constraints
.
isNormalized
);
assert
(
constraints
.
isNormalized
);
if
(
isVertical
)
if
(
isVertical
)
return
_getIntrinsicMainAxis
(
constraints
);
return
_getIntrinsicMainAxis
(
constraints
,
constraints
.
constrainHeight
);
return
_getIntrinsicCrossAxis
(
return
_getIntrinsicCrossAxis
(
constraints
,
constraints
,
(
RenderBox
child
,
BoxConstraints
innerConstraints
)
=>
child
.
getMaxIntrinsicWidth
(
innerConstraints
)
(
RenderBox
child
,
BoxConstraints
innerConstraints
)
=>
child
.
getMaxIntrinsicWidth
(
innerConstraints
),
constraints
.
constrainHeight
);
);
}
}
...
@@ -346,7 +350,7 @@ class RenderBlockViewport extends RenderBlockBase {
...
@@ -346,7 +350,7 @@ class RenderBlockViewport extends RenderBlockBase {
if
(
intrinsicCallback
==
null
)
{
if
(
intrinsicCallback
==
null
)
{
assert
(()
{
assert
(()
{
'RenderBlockViewport does not support returning intrinsic dimensions if the relevant callbacks have not been specified.'
;
'RenderBlockViewport does not support returning intrinsic dimensions if the relevant callbacks have not been specified.'
;
return
false
;
return
RenderObject
.
debugInDebugDoesMeetConstraints
;
});
});
return
constrainer
(
0.0
);
return
constrainer
(
0.0
);
}
}
...
...
packages/flutter/lib/src/rendering/box.dart
View file @
1770004e
...
@@ -531,15 +531,30 @@ abstract class RenderBox extends RenderObject {
...
@@ -531,15 +531,30 @@ abstract class RenderBox extends RenderObject {
/// The box constraints most recently received from the parent.
/// The box constraints most recently received from the parent.
BoxConstraints
get
constraints
=>
super
.
constraints
;
BoxConstraints
get
constraints
=>
super
.
constraints
;
bool
debugDoesMeetConstraints
()
{
bool
debugDoesMeetConstraints
()
{
assert
(!
RenderObject
.
debugInDebugDoesMeetConstraints
);
RenderObject
.
debugInDebugDoesMeetConstraints
=
true
;
assert
(
constraints
!=
null
);
assert
(
constraints
!=
null
);
// verify that the size is not infinite
assert
(
_size
!=
null
);
assert
(
_size
!=
null
);
assert
(()
{
assert
(()
{
'See https://flutter.io/layout/#unbounded-constraints'
;
'See https://flutter.io/layout/#unbounded-constraints'
;
return
!
_size
.
isInfinite
;
return
!
_size
.
isInfinite
;
});
});
// verify that the size is within the constraints
bool
result
=
constraints
.
isSatisfiedBy
(
_size
);
bool
result
=
constraints
.
isSatisfiedBy
(
_size
);
if
(!
result
)
if
(!
result
)
debugPrint
(
"
${this.runtimeType}
does not meet its constraints. Constraints:
$constraints
, size:
$_size
"
);
debugPrint
(
"
${this.runtimeType}
does not meet its constraints. Constraints:
$constraints
, size:
$_size
"
);
// verify that the intrinsics are also within the constraints
double
intrinsic
;
intrinsic
=
getMinIntrinsicWidth
(
constraints
);
assert
(
intrinsic
==
constraints
.
constrainWidth
(
intrinsic
));
intrinsic
=
getMaxIntrinsicWidth
(
constraints
);
assert
(
intrinsic
==
constraints
.
constrainWidth
(
intrinsic
));
intrinsic
=
getMinIntrinsicHeight
(
constraints
);
assert
(
intrinsic
==
constraints
.
constrainHeight
(
intrinsic
));
intrinsic
=
getMaxIntrinsicHeight
(
constraints
);
assert
(
intrinsic
==
constraints
.
constrainHeight
(
intrinsic
));
RenderObject
.
debugInDebugDoesMeetConstraints
=
false
;
return
result
;
return
result
;
}
}
...
...
packages/flutter/lib/src/rendering/object.dart
View file @
1770004e
...
@@ -436,6 +436,7 @@ abstract class RenderObject extends AbstractNode implements HitTestTarget {
...
@@ -436,6 +436,7 @@ abstract class RenderObject extends AbstractNode implements HitTestTarget {
dynamic
debugOwner
;
dynamic
debugOwner
;
void
_debugReportException
(
String
method
,
dynamic
exception
,
StackTrace
stack
)
{
void
_debugReportException
(
String
method
,
dynamic
exception
,
StackTrace
stack
)
{
try
{
if
(
debugRenderingExceptionHandler
!=
null
)
{
if
(
debugRenderingExceptionHandler
!=
null
)
{
debugRenderingExceptionHandler
(
this
,
method
,
exception
,
stack
);
debugRenderingExceptionHandler
(
this
,
method
,
exception
,
stack
);
}
else
{
}
else
{
...
@@ -444,11 +445,43 @@ abstract class RenderObject extends AbstractNode implements HitTestTarget {
...
@@ -444,11 +445,43 @@ abstract class RenderObject extends AbstractNode implements HitTestTarget {
debugPrint
(
'
$exception
'
);
debugPrint
(
'
$exception
'
);
debugPrint
(
'The following RenderObject was being processed when the exception was fired:
\n
${this}
'
);
debugPrint
(
'The following RenderObject was being processed when the exception was fired:
\n
${this}
'
);
if
(
debugOwner
!=
null
)
if
(
debugOwner
!=
null
)
debugPrint
(
'That RenderObject had the following owner:
\n
$debugOwner
'
);
debugPrint
(
'This RenderObject had the following owner:
\n
$debugOwner
'
);
int
depth
=
0
;
List
<
String
>
descendants
=
<
String
>[];
void
visitor
(
RenderObject
child
)
{
descendants
.
add
(
'
${" " * depth}$child
'
);
depth
+=
1
;
if
(
depth
<
5
)
child
.
visitChildren
(
visitor
);
depth
-=
1
;
}
visitChildren
(
visitor
);
if
(
descendants
.
length
>
1
)
{
debugPrint
(
'This RenderObject had the following descendants:'
);
}
else
if
(
descendants
.
length
==
1
)
{
debugPrint
(
'This RenderObject had the following child:'
);
}
else
{
debugPrint
(
'This RenderObject has no descendants.'
);
}
descendants
.
forEach
(
debugPrint
);
assert
(()
{
if
(
debugInDebugDoesMeetConstraints
)
{
debugPrint
(
'This exception was thrown while debugDoesMeetConstraints() was running.'
);
debugPrint
(
'debugDoesMeetConstraints() verifies that some invariants are not being'
);
debugPrint
(
'violated. For example, it verifies that RenderBox objects are sized in'
);
debugPrint
(
'a manner consistent with the constraints provided, and, in addition, that'
);
debugPrint
(
'the getMinIntrinsicWidth(), getMaxIntrinsicWidth(), etc, functions all'
);
debugPrint
(
'return consistent values within the same constraints.'
);
}
return
true
;
});
debugPrint
(
'Stack trace:'
);
debugPrint
(
'Stack trace:'
);
debugPrint
(
'
$stack
'
);
debugPrint
(
'
$stack
'
);
debugPrint
(
'------------------------------------------------------------------------'
);
debugPrint
(
'------------------------------------------------------------------------'
);
}
}
}
catch
(
exception
)
{
debugPrint
(
'(exception during exception handler:
$exception
)'
);
}
}
}
static
bool
_debugDoingLayout
=
false
;
static
bool
_debugDoingLayout
=
false
;
...
@@ -486,6 +519,13 @@ abstract class RenderObject extends AbstractNode implements HitTestTarget {
...
@@ -486,6 +519,13 @@ abstract class RenderObject extends AbstractNode implements HitTestTarget {
Constraints
get
constraints
=>
_constraints
;
Constraints
get
constraints
=>
_constraints
;
/// Override this function in a subclass to verify that your state matches the constraints object.
/// Override this function in a subclass to verify that your state matches the constraints object.
bool
debugDoesMeetConstraints
();
bool
debugDoesMeetConstraints
();
/// When true, debugDoesMeetConstraints() is currently executing.
///
/// This should be set by implementations of debugDoesMeetConstraints() so that
/// tests can selectively ignore custom layout callbacks. It should not be set
/// outside of debugDoesMeetConstraints() implementations and should not be used
/// for purposes other than tests.
static
bool
debugInDebugDoesMeetConstraints
=
false
;
bool
debugAncestorsAlreadyMarkedNeedsLayout
()
{
bool
debugAncestorsAlreadyMarkedNeedsLayout
()
{
if
(
_relayoutSubtreeRoot
==
null
)
if
(
_relayoutSubtreeRoot
==
null
)
return
true
;
// we haven't yet done layout even once, so there's nothing for us to do
return
true
;
// we haven't yet done layout even once, so there's nothing for us to do
...
...
packages/flutter/lib/src/rendering/shifted_box.dart
View file @
1770004e
...
@@ -110,7 +110,7 @@ class RenderPadding extends RenderShiftedBox {
...
@@ -110,7 +110,7 @@ class RenderPadding extends RenderShiftedBox {
assert
(
constraints
.
isNormalized
);
assert
(
constraints
.
isNormalized
);
double
totalPadding
=
padding
.
left
+
padding
.
right
;
double
totalPadding
=
padding
.
left
+
padding
.
right
;
if
(
child
!=
null
)
if
(
child
!=
null
)
return
c
hild
.
getMinIntrinsicWidth
(
constraints
.
deflate
(
padding
))
+
totalPadding
;
return
c
onstraints
.
constrainWidth
(
child
.
getMinIntrinsicWidth
(
constraints
.
deflate
(
padding
))
+
totalPadding
)
;
return
constraints
.
constrainWidth
(
totalPadding
);
return
constraints
.
constrainWidth
(
totalPadding
);
}
}
...
@@ -118,7 +118,7 @@ class RenderPadding extends RenderShiftedBox {
...
@@ -118,7 +118,7 @@ class RenderPadding extends RenderShiftedBox {
assert
(
constraints
.
isNormalized
);
assert
(
constraints
.
isNormalized
);
double
totalPadding
=
padding
.
left
+
padding
.
right
;
double
totalPadding
=
padding
.
left
+
padding
.
right
;
if
(
child
!=
null
)
if
(
child
!=
null
)
return
c
hild
.
getMaxIntrinsicWidth
(
constraints
.
deflate
(
padding
))
+
totalPadding
;
return
c
onstraints
.
constrainWidth
(
child
.
getMaxIntrinsicWidth
(
constraints
.
deflate
(
padding
))
+
totalPadding
)
;
return
constraints
.
constrainWidth
(
totalPadding
);
return
constraints
.
constrainWidth
(
totalPadding
);
}
}
...
@@ -126,7 +126,7 @@ class RenderPadding extends RenderShiftedBox {
...
@@ -126,7 +126,7 @@ class RenderPadding extends RenderShiftedBox {
assert
(
constraints
.
isNormalized
);
assert
(
constraints
.
isNormalized
);
double
totalPadding
=
padding
.
top
+
padding
.
bottom
;
double
totalPadding
=
padding
.
top
+
padding
.
bottom
;
if
(
child
!=
null
)
if
(
child
!=
null
)
return
c
hild
.
getMinIntrinsicHeight
(
constraints
.
deflate
(
padding
))
+
totalPadding
;
return
c
onstraints
.
constrainHeight
(
child
.
getMinIntrinsicHeight
(
constraints
.
deflate
(
padding
))
+
totalPadding
)
;
return
constraints
.
constrainHeight
(
totalPadding
);
return
constraints
.
constrainHeight
(
totalPadding
);
}
}
...
@@ -134,7 +134,7 @@ class RenderPadding extends RenderShiftedBox {
...
@@ -134,7 +134,7 @@ class RenderPadding extends RenderShiftedBox {
assert
(
constraints
.
isNormalized
);
assert
(
constraints
.
isNormalized
);
double
totalPadding
=
padding
.
top
+
padding
.
bottom
;
double
totalPadding
=
padding
.
top
+
padding
.
bottom
;
if
(
child
!=
null
)
if
(
child
!=
null
)
return
c
hild
.
getMaxIntrinsicHeight
(
constraints
.
deflate
(
padding
))
+
totalPadding
;
return
c
onstraints
.
constrainHeight
(
child
.
getMaxIntrinsicHeight
(
constraints
.
deflate
(
padding
))
+
totalPadding
)
;
return
constraints
.
constrainHeight
(
totalPadding
);
return
constraints
.
constrainHeight
(
totalPadding
);
}
}
...
...
packages/flutter/lib/src/rendering/viewport.dart
View file @
1770004e
...
@@ -88,28 +88,28 @@ class RenderViewport extends RenderBox with RenderObjectWithChildMixin<RenderBox
...
@@ -88,28 +88,28 @@ class RenderViewport extends RenderBox with RenderObjectWithChildMixin<RenderBox
double
getMinIntrinsicWidth
(
BoxConstraints
constraints
)
{
double
getMinIntrinsicWidth
(
BoxConstraints
constraints
)
{
assert
(
constraints
.
isNormalized
);
assert
(
constraints
.
isNormalized
);
if
(
child
!=
null
)
if
(
child
!=
null
)
return
c
hild
.
getMinIntrinsicWidth
(
_getInnerConstraints
(
constraints
));
return
c
onstraints
.
constrainWidth
(
child
.
getMinIntrinsicWidth
(
_getInnerConstraints
(
constraints
)
));
return
super
.
getMinIntrinsicWidth
(
constraints
);
return
super
.
getMinIntrinsicWidth
(
constraints
);
}
}
double
getMaxIntrinsicWidth
(
BoxConstraints
constraints
)
{
double
getMaxIntrinsicWidth
(
BoxConstraints
constraints
)
{
assert
(
constraints
.
isNormalized
);
assert
(
constraints
.
isNormalized
);
if
(
child
!=
null
)
if
(
child
!=
null
)
return
c
hild
.
getMaxIntrinsicWidth
(
_getInnerConstraints
(
constraints
));
return
c
onstraints
.
constrainWidth
(
child
.
getMaxIntrinsicWidth
(
_getInnerConstraints
(
constraints
)
));
return
super
.
getMaxIntrinsicWidth
(
constraints
);
return
super
.
getMaxIntrinsicWidth
(
constraints
);
}
}
double
getMinIntrinsicHeight
(
BoxConstraints
constraints
)
{
double
getMinIntrinsicHeight
(
BoxConstraints
constraints
)
{
assert
(
constraints
.
isNormalized
);
assert
(
constraints
.
isNormalized
);
if
(
child
!=
null
)
if
(
child
!=
null
)
return
c
hild
.
getMinIntrinsicHeight
(
_getInnerConstraints
(
constraints
));
return
c
onstraints
.
constrainHeight
(
child
.
getMinIntrinsicHeight
(
_getInnerConstraints
(
constraints
)
));
return
super
.
getMinIntrinsicHeight
(
constraints
);
return
super
.
getMinIntrinsicHeight
(
constraints
);
}
}
double
getMaxIntrinsicHeight
(
BoxConstraints
constraints
)
{
double
getMaxIntrinsicHeight
(
BoxConstraints
constraints
)
{
assert
(
constraints
.
isNormalized
);
assert
(
constraints
.
isNormalized
);
if
(
child
!=
null
)
if
(
child
!=
null
)
return
c
hild
.
getMaxIntrinsicHeight
(
_getInnerConstraints
(
constraints
));
return
c
onstraints
.
constrainHeight
(
child
.
getMaxIntrinsicHeight
(
_getInnerConstraints
(
constraints
)
));
return
super
.
getMaxIntrinsicHeight
(
constraints
);
return
super
.
getMaxIntrinsicHeight
(
constraints
);
}
}
...
...
packages/flutter/lib/src/widgets/mixed_viewport.dart
View file @
1770004e
...
@@ -156,7 +156,7 @@ class _MixedViewportElement extends RenderObjectElement<MixedViewport> {
...
@@ -156,7 +156,7 @@ class _MixedViewportElement extends RenderObjectElement<MixedViewport> {
'MixedViewport does not support returning intrinsic dimensions. '
+
'MixedViewport does not support returning intrinsic dimensions. '
+
'Calculating the intrinsic dimensions would require walking the entire child list, '
+
'Calculating the intrinsic dimensions would require walking the entire child list, '
+
'which defeats the entire point of having a lazily-built list of children.'
;
'which defeats the entire point of having a lazily-built list of children.'
;
return
false
;
return
RenderObject
.
debugInDebugDoesMeetConstraints
;
});
});
return
null
;
return
null
;
}
}
...
...
packages/flutter/test/rendering/block_test.dart
View file @
1770004e
...
@@ -13,6 +13,54 @@ class TestBlockPainter extends Painter {
...
@@ -13,6 +13,54 @@ class TestBlockPainter extends Painter {
}
}
void
main
(
)
{
void
main
(
)
{
test
(
'block intrinsics'
,
()
{
RenderParagraph
paragraph
=
new
RenderParagraph
(
new
StyledTextSpan
(
new
TextStyle
(
height:
1.0
),
<
TextSpan
>[
new
PlainTextSpan
(
'Hello World'
)]
)
);
const
BoxConstraints
unconstrained
=
const
BoxConstraints
();
double
textWidth
=
paragraph
.
getMaxIntrinsicWidth
(
unconstrained
);
double
oneLineTextHeight
=
paragraph
.
getMinIntrinsicHeight
(
unconstrained
);
final
BoxConstraints
constrained
=
new
BoxConstraints
(
maxWidth:
textWidth
*
0.9
);
double
wrappedTextWidth
=
paragraph
.
getMinIntrinsicWidth
(
unconstrained
);
double
twoLinesTextHeight
=
paragraph
.
getMinIntrinsicHeight
(
constrained
);
// controls
expect
(
wrappedTextWidth
,
lessThan
(
textWidth
));
expect
(
paragraph
.
getMinIntrinsicWidth
(
unconstrained
),
equals
(
wrappedTextWidth
));
expect
(
paragraph
.
getMaxIntrinsicWidth
(
constrained
),
equals
(
constrained
.
maxWidth
));
expect
(
oneLineTextHeight
,
lessThan
(
twoLinesTextHeight
));
expect
(
twoLinesTextHeight
,
lessThan
(
oneLineTextHeight
*
3.0
));
expect
(
paragraph
.
getMaxIntrinsicHeight
(
unconstrained
),
equals
(
oneLineTextHeight
));
expect
(
paragraph
.
getMaxIntrinsicHeight
(
constrained
),
equals
(
twoLinesTextHeight
));
RenderBox
testBlock
=
new
RenderBlock
(
children:
<
RenderBox
>[
paragraph
,
]
);
expect
(
testBlock
.
getMinIntrinsicWidth
(
unconstrained
),
equals
(
wrappedTextWidth
));
expect
(
testBlock
.
getMinIntrinsicWidth
(
constrained
),
equals
(
wrappedTextWidth
));
expect
(
testBlock
.
getMaxIntrinsicWidth
(
unconstrained
),
equals
(
textWidth
));
expect
(
testBlock
.
getMaxIntrinsicWidth
(
constrained
),
equals
(
constrained
.
maxWidth
));
expect
(
testBlock
.
getMinIntrinsicHeight
(
unconstrained
),
equals
(
oneLineTextHeight
));
expect
(
testBlock
.
getMinIntrinsicHeight
(
constrained
),
equals
(
twoLinesTextHeight
));
expect
(
testBlock
.
getMaxIntrinsicHeight
(
unconstrained
),
equals
(
oneLineTextHeight
));
expect
(
testBlock
.
getMaxIntrinsicHeight
(
constrained
),
equals
(
twoLinesTextHeight
));
final
BoxConstraints
empty
=
new
BoxConstraints
.
tight
(
Size
.
zero
);
expect
(
testBlock
.
getMinIntrinsicWidth
(
empty
),
equals
(
0.0
));
expect
(
testBlock
.
getMaxIntrinsicWidth
(
empty
),
equals
(
0.0
));
expect
(
testBlock
.
getMinIntrinsicHeight
(
empty
),
equals
(
0.0
));
expect
(
testBlock
.
getMaxIntrinsicHeight
(
empty
),
equals
(
0.0
));
});
test
(
'overlay painters can attach and detach'
,
()
{
test
(
'overlay painters can attach and detach'
,
()
{
TestBlockPainter
first
=
new
TestBlockPainter
();
TestBlockPainter
first
=
new
TestBlockPainter
();
TestBlockPainter
second
=
new
TestBlockPainter
();
TestBlockPainter
second
=
new
TestBlockPainter
();
...
...
packages/flutter/test/widget/custom_multi_child_layout_test.dart
View file @
1770004e
...
@@ -11,6 +11,7 @@ class TestMultiChildLayoutDelegate extends MultiChildLayoutDelegate {
...
@@ -11,6 +11,7 @@ class TestMultiChildLayoutDelegate extends MultiChildLayoutDelegate {
BoxConstraints
getSizeConstraints
;
BoxConstraints
getSizeConstraints
;
Size
getSize
(
BoxConstraints
constraints
)
{
Size
getSize
(
BoxConstraints
constraints
)
{
if
(!
RenderObject
.
debugInDebugDoesMeetConstraints
)
getSizeConstraints
=
constraints
;
getSizeConstraints
=
constraints
;
return
new
Size
(
200.0
,
300.0
);
return
new
Size
(
200.0
,
300.0
);
}
}
...
@@ -22,6 +23,7 @@ class TestMultiChildLayoutDelegate extends MultiChildLayoutDelegate {
...
@@ -22,6 +23,7 @@ class TestMultiChildLayoutDelegate extends MultiChildLayoutDelegate {
bool
performLayoutIsChild
;
bool
performLayoutIsChild
;
void
performLayout
(
Size
size
,
BoxConstraints
constraints
)
{
void
performLayout
(
Size
size
,
BoxConstraints
constraints
)
{
assert
(!
RenderObject
.
debugInDebugDoesMeetConstraints
);
expect
(()
{
expect
(()
{
performLayoutSize
=
size
;
performLayoutSize
=
size
;
performLayoutConstraints
=
constraints
;
performLayoutConstraints
=
constraints
;
...
@@ -34,6 +36,7 @@ class TestMultiChildLayoutDelegate extends MultiChildLayoutDelegate {
...
@@ -34,6 +36,7 @@ class TestMultiChildLayoutDelegate extends MultiChildLayoutDelegate {
bool
shouldRelayoutCalled
=
false
;
bool
shouldRelayoutCalled
=
false
;
bool
shouldRelayoutValue
=
false
;
bool
shouldRelayoutValue
=
false
;
bool
shouldRelayout
(
_
)
{
bool
shouldRelayout
(
_
)
{
assert
(!
RenderObject
.
debugInDebugDoesMeetConstraints
);
shouldRelayoutCalled
=
true
;
shouldRelayoutCalled
=
true
;
return
shouldRelayoutValue
;
return
shouldRelayoutValue
;
}
}
...
...
packages/flutter/test/widget/custom_one_child_layout_test.dart
View file @
1770004e
...
@@ -3,6 +3,7 @@
...
@@ -3,6 +3,7 @@
// found in the LICENSE file.
// found in the LICENSE file.
import
'package:flutter_test/flutter_test.dart'
;
import
'package:flutter_test/flutter_test.dart'
;
import
'package:flutter/rendering.dart'
;
import
'package:flutter/widgets.dart'
;
import
'package:flutter/widgets.dart'
;
import
'package:test/test.dart'
;
import
'package:test/test.dart'
;
...
@@ -13,11 +14,13 @@ class TestOneChildLayoutDelegate extends OneChildLayoutDelegate {
...
@@ -13,11 +14,13 @@ class TestOneChildLayoutDelegate extends OneChildLayoutDelegate {
Size
childSizeFromGetPositionForChild
;
Size
childSizeFromGetPositionForChild
;
Size
getSize
(
BoxConstraints
constraints
)
{
Size
getSize
(
BoxConstraints
constraints
)
{
if
(!
RenderObject
.
debugInDebugDoesMeetConstraints
)
constraintsFromGetSize
=
constraints
;
constraintsFromGetSize
=
constraints
;
return
new
Size
(
200.0
,
300.0
);
return
new
Size
(
200.0
,
300.0
);
}
}
BoxConstraints
getConstraintsForChild
(
BoxConstraints
constraints
)
{
BoxConstraints
getConstraintsForChild
(
BoxConstraints
constraints
)
{
assert
(!
RenderObject
.
debugInDebugDoesMeetConstraints
);
constraintsFromGetConstraintsForChild
=
constraints
;
constraintsFromGetConstraintsForChild
=
constraints
;
return
new
BoxConstraints
(
return
new
BoxConstraints
(
minWidth:
100.0
,
minWidth:
100.0
,
...
@@ -28,6 +31,7 @@ class TestOneChildLayoutDelegate extends OneChildLayoutDelegate {
...
@@ -28,6 +31,7 @@ class TestOneChildLayoutDelegate extends OneChildLayoutDelegate {
}
}
Offset
getPositionForChild
(
Size
size
,
Size
childSize
)
{
Offset
getPositionForChild
(
Size
size
,
Size
childSize
)
{
assert
(!
RenderObject
.
debugInDebugDoesMeetConstraints
);
sizeFromGetPositionForChild
=
size
;
sizeFromGetPositionForChild
=
size
;
childSizeFromGetPositionForChild
=
childSize
;
childSizeFromGetPositionForChild
=
childSize
;
return
Offset
.
zero
;
return
Offset
.
zero
;
...
@@ -36,6 +40,7 @@ class TestOneChildLayoutDelegate extends OneChildLayoutDelegate {
...
@@ -36,6 +40,7 @@ class TestOneChildLayoutDelegate extends OneChildLayoutDelegate {
bool
shouldRelayoutCalled
=
false
;
bool
shouldRelayoutCalled
=
false
;
bool
shouldRelayoutValue
=
false
;
bool
shouldRelayoutValue
=
false
;
bool
shouldRelayout
(
_
)
{
bool
shouldRelayout
(
_
)
{
assert
(!
RenderObject
.
debugInDebugDoesMeetConstraints
);
shouldRelayoutCalled
=
true
;
shouldRelayoutCalled
=
true
;
return
shouldRelayoutValue
;
return
shouldRelayoutValue
;
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment