“This is the 20th day of my participation in the August Gwen Challenge. For details, see: August Gwen Challenge” juejin.cn/post/698796…
Small dish to restrain Box to explore the road is still continuing, small dish today mainly learn Overflow related Box;
OverflowBox
Source code analysis
class OverflowBox extends SingleChildRenderObjectWidget { const OverflowBox({ Key key, This. minWidth, // Allow the minimum width this.maxWidth, // Allow the maximum width this.minHeight, This.maxheight, // Widget child,})}Copy the code
According to the source code analysis, OverflowBox restricts the child Widget by setting the maximum and minimum width and height, and is related to the parent Widget. The child Widget may overflow the parent Widget.
Case try
The tip explores the relationship between OverflowBox and parent widgets and child widgets in the following scenarios. Alignment is a common alignment and will not be explained separately here. Because OverflowBox allows child widgets to overflow parent widgets, many friends use it to implement custom dialogs;
- There is no constraint on the parent Widget, only set minWidth/minHeight, and the width of the child Widget is less than or equal to the OverflowBox minimum width and height. Child. width <= minWidth && child.height <= minHeight.
Return the Container (color: Colors. BlueAccent. WithOpacity (0.4), the child: OverflowBox (alignment: alignment. Center, minHeight: Child: 100, the Container (color: Colors. The purple. WithOpacity (0.4), width: 50, height: 50)));Copy the code
- The parent Widget is unconstrained and only minWidth/minHeight is set. The child Widget is larger than the OverflowBox minimum width and height. MinWidth < child.width < maxWidth, which is displayed as the width and height of the child Widget.
Return Container(color: color.green. WithOpacity (0.4), child: OverflowBox(alignment: align.center, minHeight: Child: 100, minWidth: 100, the Container (color: Colors. The purple. WithOpacity (0.4), width: 150, height: 150)));Copy the code
- The parent Widget is unconstrained, set maxWidth/maxHeight, Child. If child. Width > maxWidth | | height > maxHeight with high OverflowBox setting the maximum width constraint child widgets; If child.width < maxWidth && child.height < maxHeight, the above two constraints are applied;
Return the Container (color: Colors. Orange. WithOpacity (0.4), the child: OverflowBox (alignment: alignment. Center, minHeight: 100, maxWidth: 150, maxHeight: 150, child: Container (color: Colors. The purple. WithOpacity (0.4), width: 50, height: 50))); Function Function Function Function Function Function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function 100, minWidth: 100, maxWidth: 150, maxHeight: 150, child: Container (color: Colors. The purple. WithOpacity (0.4), width: 200, height: 200)));Copy the code
- Parent Widget has constraints, set maxWidth > parent. The width | | maxHeight > parent. The height, this time to allow child widgets tall wide in parent Widget width is high, the constraint way same as the above situation;
Return Container(width: 200, height: 200, color: color.brown. WithOpacity (0.4), child: OverflowBox(alignment: Alignment.center, minHeight: 100, minWidth: 50, maxHeight: 250, maxWidth: 250, child: Container(color: Colors. The purple. WithOpacity (0.4))));Copy the code
- Note That the minimum width and height cannot be greater than the maximum width and height of most widgets.
Return Container(width: 200, height: 200, color: color.brown. WithOpacity (0.4), child: OverflowBox(alignment: Alignment. Center, minHeight: 250, minWidth: 50, child: Container (color: Colors. The purple. WithOpacity (0.4))));Copy the code
SizedOverflowBox
Source code analysis
class SizedOverflowBox extends SingleChildRenderObjectWidget { const SizedOverflowBox({ Key key, @required this.size, Alignment = alignment. Center, // Alignment Widget child,})}Copy the code
SizedBox is a combination of SizedBox and OverflowBox. OverflowBox is a combination of SizedBox and OverflowBox. OverflowBox is a combination of SizedBox and OverflowBox.
Case try
Size is the basic size constraint for the child widgets, and alignment is a common alignment. The following scenario is used to try the small dishes.
- Width <= Size. X && child.height <= Size. Y is displayed as the width and height constraint of the child Widget.
Return Container(color: color.green. WithOpacity (0.4), child: Center(child: SizedOverflowBox(size: Size(100, 100), alignment: Alignment.center, child: Container(width: 50, height: 50, color: Colors. BlueAccent. WithOpacity (0.6)))));Copy the code
- Parent Widget unconstrained, if child. Width > Size. X | | child. Height > Size. H, with child widgets show wide high overflow;
Return the Container (color: Colors. Orange. WithOpacity (0.4), the child: Center (child: SizedOverflowBox (size: Size(100, 100), alignment: Alignment.center, child: Container(width: 150, height: 150, color: Colors. The purple. WithOpacity (0.4)))));Copy the code
- If child.width <= size. x && child.height <= size. y, condition 1 is the same as condition 1. If child. Width > parent. Width > = Size. X | | child. Height > parent. The height > = Size. The y, The child Widget overflows SizedOverflowBox into the parent Widget constraint width display;
Return the Container (width: 150, height: 150, color: Colors. RedAccent. WithOpacity (0.4), the child: Center (child: SizedOverflowBox( size: Size(100, 100), alignment: Alignment.center, child: Container(width: 250, height: 50, color: Colors. Grey. WithOpacity (0.8)))));Copy the code
- . When the parent Widget has constraint, if the Size x > parent. The width | | Size. The y > parent. The height, finally display the biggest wide high is the width of the parent Widget constraint high (child widgets overflow or not overflow);
Return the Container (width: 150, height: 150, color: Colors. RedAccent. WithOpacity (0.4), the child: Center (child: SizedOverflowBox( size: Size(400, 400), alignment: Alignment.topLeft, child: Container(width: 150, height: 50, color: Colors. Grey. WithOpacity (0.8)))));Copy the code
Little understanding
Xiaosai has tried many constraints on boxes, and even some boxes are similar in usage and functionality. The same functionality can be implemented with other widgets. But why so many constraints on boxes?
Xiao CAI’s understanding of this is not deep enough, only a simple exchange of personal understanding, if there is a mistake, please guide! A common SizedBox can be used as either a constraint box or a space placeholder. Container can do this and achieve many complex effects. The reasons for the existence of the SizedBox are as follows: First, the Function of the SizedBox is simple and the performance of the Flutter is better than that of Container (Flutter rendering performance is very high and can be ignored). Second, the function of SizedBox is more clear; Proper use of widgets makes coding clearer and more efficient;
Xiaokai’s exploration of Box constraint is over for now, I hope you can try more of all kinds of Box!
Source: Little Monk A Ce