I ever recorded how to use the built-in ListView
component in [Flutter] Use "ListView" to create a list component, and its display result is as follows:
data:image/s3,"s3://crabby-images/cbe46/cbe46e38a0423a7a5e8f04d8e67169531a4b3a1b" alt=""
But in order to show more pretty widget, I searched for various components, and finally found a pleasing module: flutter_staggered_grid_view.
Please forgive me for directly quoting their pictures on pub.dev:
data:image/s3,"s3://crabby-images/72648/7264874d1f7d901cf7a281116c4b18b91f65db1f" alt=""
how is it? Isn't it beautiful? Different grids are combined into a Widget, and you can also slide down. In view of this, I started the study of this module and recorded it here.
For more detailed content, please refer to the developer's pub.dev https://pub.dev/packages/flutter_staggered_grid_view
Preparation
Since this is an external module, not Flutter's own, we have to go to pubspec.yaml to set this module first.
data:image/s3,"s3://crabby-images/f2465/f24654ededdc1189c4f52490f8096a195967464d" alt=""
When I was studying, the version of this module reached 0.3.0, but I will definitely continue to update it in the future. It is best to check the current latest version on the developer's pub.dev at any time.
data:image/s3,"s3://crabby-images/32c7c/32c7c118c567cbd5827137be6e6e496eb0c47e8f" alt=""
After writing the version number to be quoted, click on the Packages get above, it should be completed within a few seconds.
How to use flutter_staggered_grid_view
import 'package:flutter/material.dart'; import 'package:flutter_staggered_grid_view/flutter_staggered_grid_view.dart'; void main() => runApp(new MyApp()); class MyApp extends StatelessWidget{ @override Widget build(BuildContext context) { return MaterialApp( home: new Scaffold( appBar: new AppBar( title: new Text('staggered_grid_view TEST'), ), body: StaggeredGridView.countBuilder( crossAxisCount: 4, itemCount: 20, itemBuilder: (BuildContext context, int index) => new Container( color: Colors.deepOrange, child: new Center( child: new CircleAvatar( backgroundColor: Colors.white, child: new Text('$index'), ), ), ), staggeredTileBuilder: (int index) => new StaggeredTile.count(2, 2), mainAxisSpacing: 4.0, crossAxisSpacing: 4.0, ), ), ); } }
Output:
data:image/s3,"s3://crabby-images/39be3/39be3d063956aa17f64150be95166ef1517491a3" alt=""
In order to show, I did not carefully design the beautiful interface adjusted by the developer above, but simply set it to be left-right symmetrical and contain round-framed numbers on a white background.
The following explains the various settings in the code:
- StaggeredGridView.countBuilder: module widget builder
- crossAxisCount: The number of widths
- itemCount: Number of components
- StaggeredTile.count: Length and width settings
- mainAxisSpacing: Interval between upper and lower components
- crossAxisSpacing: Left and right component spacing
Of course, we can adjust the above settings. For example:
itemBuilder: (BuildContext context, int index) => new Container( color: Colors.deepOrange,
We change the component to blue color:
itemBuilder: (BuildContext context, int index) => new Container( color: index%3==0?Colors.deepOrange:Colors.blueAccent,
In this way, only the components whose component number is divisible by 3 will display dark orange, and all other components will be blue.
For example, we set all length and width equal to 2:
staggeredTileBuilder: (int index) => new StaggeredTile.count(2, 2),
Change to:
staggeredTileBuilder: (int index) => new StaggeredTile.count(2, index.isOdd?1:2),
The length is 2 only when the component number is an even number, and the length is only 1 if it is an odd number.
Output:
data:image/s3,"s3://crabby-images/e8b30/e8b30a43ec40fafb0047edd0609c444486400a19" alt=""
We will get such an arrangement pattern of components with different colors, length and width.
Of course, due to my poor art and time factors, I did not use this module very well.
But if you see the sample picture set by the developer, you can definitely feel the power of this module.
data:image/s3,"s3://crabby-images/d5c78/d5c780ad0be4ade3a21ec30459165be272727de6" alt="這張圖片的 alt 屬性值為空,它的檔案名稱為 example_01.png"
I hope everyone can make beautiful apps.