Step-by-Step Guide to Implementing GridViews in Flutter
Understanding GridView in Flutter
A GridView in Flutter acts like a table or grid, allowing us to neatly present items in rows and columns. It's a handy way to display various elements within a tabular layout, making it easy for users to interact with and select items.
What Exactly is a GridView?
Layout Organizer: Picture a grid paper divided into rows and columns. Each square of this grid can hold different things—text, pictures, icons, or anything you want to display.
Two-Dimensional Display: The GridView displays items in a two-dimensional array, meaning it arranges elements both horizontally and vertically.
User Interaction: Users can tap or select items within this grid layout, enabling them to interact with your app by choosing specific items of interest.
Why Choose a GridView?
Organized Presentation: It's perfect for organizing and showcasing numerous items in an orderly manner, like a photo gallery, product catalog, or a list of options.
User-Friendly: Helps users browse through multiple items without overwhelming the screen, providing a structured and manageable view.
GridView Types in Flutter
GridView.count()
GridView.builder()
GridView.custom()
GridView.extent()
1. GridView.count:
Description: This type of GridView allows you to create a scrollable grid layout with a fixed number of items in each row or column.
Features:
You can define the number of items in the cross-axis (either rows or columns).
Customize the aspect ratio of the items to suit your layout needs.
Use Case: Ideal for displaying a grid where you want a fixed number of items per row or column, maintaining a consistent layout pattern.
2. GridView.builder:
Description: This GridView variant efficiently handles large collections of data by generating grid items dynamically as the user scrolls.
Features:
Uses a builder function to create and populate grid items on-demand, optimizing performance by rendering items only when needed.
Suitable for handling large datasets without compromising app performance.
Use Case: Perfect for displaying grids with a massive number of items where creating all items at once might be resource-intensive.
3. The GridView.custom() constructor in Flutter allows developers to create a highly customizable grid layout by providing custom delegate implementations for building and controlling the layout of grid items. This variant of the GridView offers extensive flexibility and control over the grid's behavior and appearance.
4. GridView.extent:
Description: This type of GridView creates a scrollable grid where items have a fixed extent in the main axis (either width or height).
Features:
Allows you to specify the extent (size) of items in the main axis, maintaining a consistent size across the grid items.
Customize the aspect ratio of the items.
Use Case: Useful when you want items in the grid to have a fixed size in one direction (either width or height), providing a uniform appearance.
Ex
import 'package:flutter/material.dart';
void main() {
runApp(const MyApp());
}
class MyApp extends StatelessWidget {
const MyApp({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
appBar: AppBar(title: const Text('GridView Example')),
// body: GridView.count(
// crossAxisCount: 2,
// crossAxisSpacing: 5,
// mainAxisSpacing: 5,
// children: List.generate(12, (index) {
// return Text(index.toString());
// },),
// ),
// body: GridView.extent(
// maxCrossAxisExtent: 200, // Maximum width of an item
// crossAxisSpacing: 10,
// mainAxisSpacing: 10,
// children: List.generate(100, (index) {
// return Container(
// color: Colors.green,
// child: Center(
// child: Text(index.toString()),
// ),
// );
// }),
// ),
// body: GridView.builder(
// // gridDelegate: SliverGridDelegateWithFixedCrossAxisCount(
// // crossAxisCount: 3, // 2 columns
// // crossAxisSpacing: 10,
// // mainAxisSpacing: 10,
// // ),
//
// gridDelegate: const SliverGridDelegateWithFixedCrossAxisCount(
// crossAxisCount: 2,
// crossAxisSpacing: 10,
// mainAxisSpacing: 10,
// childAspectRatio: 2 / 3, // Width aur height ka ratio
// ),
// itemCount: 100, // Total items
// itemBuilder: (context, index) {
// return Container(
// color: Colors.orange,
// child: Center(
// child: Text('Item $index'),
// ),
// );
// },
// ),
// body: GridView.custom(
// gridDelegate: const SliverGridDelegateWithFixedCrossAxisCount(
// crossAxisCount: 2,
// crossAxisSpacing: 2,
// mainAxisSpacing: 3,
// childAspectRatio:3,
//
// ),
// childrenDelegate: SliverChildBuilderDelegate(
// (context, index) {
// return Container(
// color: Colors.blue,
// child: Center(child: Text('Item $index')),
// );
// },
// childCount: 20,
// ),
// ),
// body: GridView.custom(
// gridDelegate: const SliverGridDelegateWithFixedCrossAxisCount(
// crossAxisCount: 3,
// crossAxisSpacing: 8,
// mainAxisSpacing: 8,
// ),
// childrenDelegate: SliverChildBuilderDelegate(
// (context, index) {
// return Container(
// decoration: BoxDecoration(
// color: index % 2 == 0 ? Colors.blue : Colors.orange,
// borderRadius: BorderRadius.circular(8),
// ),
// child: Center(
// child: Text(
// 'Item $index',
// style: const TextStyle(color: Colors.white),
// ),
// ),
// );
// },
// childCount: 30,
// ),
// ),
// body: GridView.custom(
// gridDelegate: const SliverGridDelegateWithFixedCrossAxisCount(
// crossAxisCount: 4,
// mainAxisSpacing: 10,
// crossAxisSpacing: 10,
// ),
// childrenDelegate: SliverChildListDelegate(
// [
// Container(color: Colors.red, child: const Center(child: Text('Item 1'))),
// Container(color: Colors.blue, child: const Center(child: Text('Item 2'))),
// Container(color: Colors.green, child: const Center(child: Text('Item 3'))),
// Container(color: Colors.orange, child: const Center(child: Text('Item 4'))),
// ],
// ),
// ),
body: GridView.custom(
gridDelegate: const SliverGridDelegateWithFixedCrossAxisCount(
crossAxisCount: 3,
mainAxisSpacing: 10,
crossAxisSpacing: 10,
),
childrenDelegate: SliverChildBuilderDelegate(
(context, index) {
if (index % 2 == 0) {
return Container(
color: Colors.purple,
child: Center(child: Text('Even Item ${index}')),
);
} else {
return Container(
color: Colors.teal,
child: Center(child: Text('Odd Item $index')),
);
}
},
childCount: 9090,
),
)
,
),
);
}
}
Conclusion:
In a Flutter application, a GridView serves as an excellent tool to present various items in a visually organized grid layout. Its versatility and user-friendly design make it a valuable choice for displaying diverse content in a structured manner.
Comments
Post a Comment