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
7bf3cb41
Commit
7bf3cb41
authored
Jan 02, 2016
by
Adam Barth
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #1061 from abarth/generalize_grid_layout
Generalize grid layout
parents
a5925149
46a178dc
Changes
7
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
478 additions
and
91 deletions
+478
-91
render_grid.dart
examples/rendering/render_grid.dart
+4
-1
media_query.dart
examples/widgets/media_query.dart
+3
-3
edge_dims.dart
packages/flutter/lib/src/painting/edge_dims.dart
+11
-2
box.dart
packages/flutter/lib/src/rendering/box.dart
+1
-1
grid.dart
packages/flutter/lib/src/rendering/grid.dart
+342
-75
basic.dart
packages/flutter/lib/src/widgets/basic.dart
+112
-7
grid_test.dart
packages/flutter/test/rendering/grid_test.dart
+5
-2
No files found.
examples/rendering/render_grid.dart
View file @
7bf3cb41
...
@@ -20,7 +20,10 @@ Color randomColor() {
...
@@ -20,7 +20,10 @@ Color randomColor() {
RenderBox
buildGridExample
(
)
{
RenderBox
buildGridExample
(
)
{
List
<
RenderBox
>
children
=
new
List
<
RenderBox
>.
generate
(
30
,
(
_
)
=>
new
RenderSolidColorBox
(
randomColor
()));
List
<
RenderBox
>
children
=
new
List
<
RenderBox
>.
generate
(
30
,
(
_
)
=>
new
RenderSolidColorBox
(
randomColor
()));
return
new
RenderGrid
(
children:
children
,
maxChildExtent:
100.0
);
return
new
RenderGrid
(
children:
children
,
delegate:
new
MaxTileWidthGridDelegate
(
maxTileWidth:
100.0
)
);
}
}
main
()
=>
new
RenderingFlutterBinding
(
root:
buildGridExample
());
main
()
=>
new
RenderingFlutterBinding
(
root:
buildGridExample
());
examples/widgets/media_query.dart
View file @
7bf3cb41
...
@@ -62,7 +62,7 @@ class AdaptiveItem {
...
@@ -62,7 +62,7 @@ class AdaptiveItem {
}
}
class
MediaQueryExample
extends
StatelessComponent
{
class
MediaQueryExample
extends
StatelessComponent
{
static
const
double
_max
ChildExtent
=
150.0
;
static
const
double
_max
TileWidth
=
150.0
;
static
const
double
_gridViewBreakpoint
=
450.0
;
static
const
double
_gridViewBreakpoint
=
450.0
;
Widget
_buildBody
(
BuildContext
context
)
{
Widget
_buildBody
(
BuildContext
context
)
{
...
@@ -78,9 +78,9 @@ class MediaQueryExample extends StatelessComponent {
...
@@ -78,9 +78,9 @@ class MediaQueryExample extends StatelessComponent {
}
else
{
}
else
{
return
new
Block
(
return
new
Block
(
<
Widget
>[
<
Widget
>[
new
Grid
(
new
MaxTileWidth
Grid
(
items
.
map
((
AdaptiveItem
item
)
=>
item
.
toCard
()).
toList
(),
items
.
map
((
AdaptiveItem
item
)
=>
item
.
toCard
()).
toList
(),
max
ChildExtent:
_maxChildExtent
max
TileWidth:
_maxTileWidth
)
)
]
]
);
);
...
...
packages/flutter/lib/src/painting/edge_dims.dart
View file @
7bf3cb41
...
@@ -43,8 +43,17 @@ class EdgeDims {
...
@@ -43,8 +43,17 @@ class EdgeDims {
/// Whether every dimension is non-negative.
/// Whether every dimension is non-negative.
bool
get
isNonNegative
=>
top
>=
0.0
&&
right
>=
0.0
&&
bottom
>=
0.0
&&
left
>=
0.0
;
bool
get
isNonNegative
=>
top
>=
0.0
&&
right
>=
0.0
&&
bottom
>=
0.0
&&
left
>=
0.0
;
/// The size that this edge dims would occupy with an empty interior.
/// The total offset in the vertical direction.
ui
.
Size
get
collapsedSize
=>
new
ui
.
Size
(
left
+
right
,
top
+
bottom
);
double
get
horizontal
=>
left
+
right
;
/// The total offset in the horizontal direction.
double
get
vertical
=>
top
+
bottom
;
/// The size that this EdgeDims would occupy with an empty interior.
ui
.
Size
get
collapsedSize
=>
new
ui
.
Size
(
horizontal
,
vertical
);
/// An EdgeDims with top and bottom as well as left and right flipped.
EdgeDims
get
flipped
=>
new
EdgeDims
.
TRBL
(
bottom
,
left
,
top
,
right
);
ui
.
Rect
inflateRect
(
ui
.
Rect
rect
)
{
ui
.
Rect
inflateRect
(
ui
.
Rect
rect
)
{
return
new
ui
.
Rect
.
fromLTRB
(
rect
.
left
-
left
,
rect
.
top
-
top
,
rect
.
right
+
right
,
rect
.
bottom
+
bottom
);
return
new
ui
.
Rect
.
fromLTRB
(
rect
.
left
-
left
,
rect
.
top
-
top
,
rect
.
right
+
right
,
rect
.
bottom
+
bottom
);
...
...
packages/flutter/lib/src/rendering/box.dart
View file @
7bf3cb41
...
@@ -374,7 +374,7 @@ abstract class RenderBox extends RenderObject {
...
@@ -374,7 +374,7 @@ abstract class RenderBox extends RenderObject {
return
constraints
.
constrainWidth
(
0.0
);
return
constraints
.
constrainWidth
(
0.0
);
}
}
/// Return the minimum height that this box could be without failing to
render
/// Return the minimum height that this box could be without failing to
paint
/// its contents within itself.
/// its contents within itself.
///
///
/// Override in subclasses that implement [performLayout].
/// Override in subclasses that implement [performLayout].
...
...
packages/flutter/lib/src/rendering/grid.dart
View file @
7bf3cb41
This diff is collapsed.
Click to expand it.
packages/flutter/lib/src/widgets/basic.dart
View file @
7bf3cb41
...
@@ -33,6 +33,7 @@ export 'package:flutter/rendering.dart' show
...
@@ -33,6 +33,7 @@ export 'package:flutter/rendering.dart' show
FontWeight
,
FontWeight
,
FractionalOffset
,
FractionalOffset
,
Gradient
,
Gradient
,
GridDelegate
,
HitTestBehavior
,
HitTestBehavior
,
ImageFit
,
ImageFit
,
ImageRepeat
,
ImageRepeat
,
...
@@ -1125,21 +1126,125 @@ class Positioned extends ParentDataWidget<StackRenderObjectWidgetBase> {
...
@@ -1125,21 +1126,125 @@ class Positioned extends ParentDataWidget<StackRenderObjectWidgetBase> {
}
}
}
}
abstract
class
GridRenderObjectWidgetBase
extends
MultiChildRenderObjectWidget
{
GridRenderObjectWidgetBase
({
List
<
Widget
>
children
,
Key
key
})
:
super
(
key:
key
,
children:
children
)
{
_delegate
=
createDelegate
();
}
GridDelegate
_delegate
;
/// The delegate that controls the layout of the children.
GridDelegate
createDelegate
();
RenderGrid
createRenderObject
()
=>
new
RenderGrid
(
delegate:
_delegate
);
void
updateRenderObject
(
RenderGrid
renderObject
,
GridRenderObjectWidgetBase
oldWidget
)
{
renderObject
.
delegate
=
_delegate
;
}
}
/// Uses the grid layout algorithm for its children.
/// Uses the grid layout algorithm for its children.
///
///
/// For details about the grid layout algorithm, see [RenderGrid].
/// For details about the grid layout algorithm, see [RenderGrid].
class
Grid
extends
MultiChildRenderObjectWidget
{
class
CustomGrid
extends
GridRenderObjectWidgetBase
{
Grid
(
List
<
Widget
>
children
,
{
Key
key
,
this
.
maxChildExtent
})
CustomGrid
(
List
<
Widget
>
children
,
{
Key
key
,
this
.
delegate
})
:
super
(
key:
key
,
children:
children
)
{
:
super
(
key:
key
,
children:
children
)
{
assert
(
maxChildExtent
!=
null
);
assert
(
delegate
!=
null
);
}
}
final
double
maxChildExtent
;
/// The delegate that controls the layout of the children.
final
GridDelegate
delegate
;
RenderGrid
createRenderObject
()
=>
new
RenderGrid
(
maxChildExtent:
maxChildExtent
);
GridDelegate
createDelegate
()
=>
delegate
;
}
/// Uses a grid layout with a fixed column count.
///
/// For details about the grid layout algorithm, see [MaxTileWidthGridDelegate].
class
FixedColumnCountGrid
extends
GridRenderObjectWidgetBase
{
FixedColumnCountGrid
(
List
<
Widget
>
children
,
{
Key
key
,
this
.
columnCount
,
this
.
tileAspectRatio
:
1.0
,
this
.
padding
:
EdgeDims
.
zero
})
:
super
(
key:
key
,
children:
children
)
{
assert
(
columnCount
!=
null
);
}
/// The number of columns in the grid.
final
int
columnCount
;
void
updateRenderObject
(
RenderGrid
renderObject
,
Grid
oldWidget
)
{
/// The ratio of the width to the height of each tile in the grid.
renderObject
.
maxChildExtent
=
maxChildExtent
;
final
double
tileAspectRatio
;
/// The amount of padding to apply to each child.
final
EdgeDims
padding
;
FixedColumnCountGridDelegate
createDelegate
()
{
return
new
FixedColumnCountGridDelegate
(
columnCount:
columnCount
,
tileAspectRatio:
tileAspectRatio
,
padding:
padding
);
}
}
/// Uses a grid layout with a max tile width.
///
/// For details about the grid layout algorithm, see [MaxTileWidthGridDelegate].
class
MaxTileWidthGrid
extends
GridRenderObjectWidgetBase
{
MaxTileWidthGrid
(
List
<
Widget
>
children
,
{
Key
key
,
this
.
maxTileWidth
,
this
.
tileAspectRatio
:
1.0
,
this
.
padding
:
EdgeDims
.
zero
})
:
super
(
key:
key
,
children:
children
)
{
assert
(
maxTileWidth
!=
null
);
}
/// The maximum width of a tile in the grid.
final
double
maxTileWidth
;
/// The ratio of the width to the height of each tile in the grid.
final
double
tileAspectRatio
;
/// The amount of padding to apply to each child.
final
EdgeDims
padding
;
MaxTileWidthGridDelegate
createDelegate
()
{
return
new
MaxTileWidthGridDelegate
(
maxTileWidth:
maxTileWidth
,
tileAspectRatio:
tileAspectRatio
,
padding:
padding
);
}
}
/// Supplies per-child data to the grid's [GridDelegate].
class
GridPlacementData
<
DataType
,
WidgetType
extends
RenderObjectWidget
>
extends
ParentDataWidget
<
WidgetType
>
{
GridPlacementData
({
Key
key
,
this
.
placementData
,
Widget
child
})
:
super
(
key:
key
,
child:
child
);
/// Opaque data passed to the getChildPlacement method of the grid's [GridDelegate].
final
DataType
placementData
;
void
applyParentData
(
RenderObject
renderObject
)
{
assert
(
renderObject
.
parentData
is
GridParentData
);
final
GridParentData
parentData
=
renderObject
.
parentData
;
if
(
parentData
.
placementData
!=
placementData
)
{
parentData
.
placementData
=
placementData
;
AbstractNode
targetParent
=
renderObject
.
parent
;
if
(
targetParent
is
RenderObject
)
targetParent
.
markNeedsLayout
();
}
}
void
debugFillDescription
(
List
<
String
>
description
)
{
super
.
debugFillDescription
(
description
);
description
.
add
(
'placementData:
$placementData
'
);
}
}
}
}
...
...
packages/flutter/test/rendering/grid_test.dart
View file @
7bf3cb41
...
@@ -16,7 +16,10 @@ void main() {
...
@@ -16,7 +16,10 @@ void main() {
new
RenderDecoratedBox
(
decoration:
new
BoxDecoration
())
new
RenderDecoratedBox
(
decoration:
new
BoxDecoration
())
];
];
RenderGrid
grid
=
new
RenderGrid
(
children:
children
,
maxChildExtent:
100.0
);
RenderGrid
grid
=
new
RenderGrid
(
children:
children
,
delegate:
new
MaxTileWidthGridDelegate
(
maxTileWidth:
100.0
)
);
layout
(
grid
,
constraints:
const
BoxConstraints
(
maxWidth:
200.0
));
layout
(
grid
,
constraints:
const
BoxConstraints
(
maxWidth:
200.0
));
children
.
forEach
((
RenderBox
child
)
{
children
.
forEach
((
RenderBox
child
)
{
...
@@ -28,7 +31,7 @@ void main() {
...
@@ -28,7 +31,7 @@ void main() {
expect
(
grid
.
size
.
height
,
equals
(
200.0
),
reason:
"grid height"
);
expect
(
grid
.
size
.
height
,
equals
(
200.0
),
reason:
"grid height"
);
expect
(
grid
.
needsLayout
,
equals
(
false
));
expect
(
grid
.
needsLayout
,
equals
(
false
));
grid
.
maxChildExtent
=
60.0
;
grid
.
delegate
=
new
MaxTileWidthGridDelegate
(
maxTileWidth:
60.0
)
;
expect
(
grid
.
needsLayout
,
equals
(
true
));
expect
(
grid
.
needsLayout
,
equals
(
true
));
pumpFrame
();
pumpFrame
();
...
...
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