Dragging and Tapping to Select in GridView Items

You are currently viewing Dragging and Tapping to Select in GridView Items
Drag Select GridView

Dragging and Tapping to Select in GridView Items

A grid that supports both dragging and tapping to select its items.

Drag Select
Drag Select

Basic usage

DragSelectGridView constructor is very similar to GridView.builder, so you should take your time to understand the latter before diving into this library.

Once you are familiar with GridView.builder, probably the only additional piece of information you’ll need is DragSelectGridViewController. With it, you’re able to know which indexes are selected.

Check this example:

class MyApp extends StatefulWidget {
  @override
  _MyAppState createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {
  final controller = DragSelectGridViewController();

  @override
  void initState() {
    super.initState();
    controller.addListener(scheduleRebuild);
  }

  @override
  void dispose() {
    controller.removeListener(scheduleRebuild);
    super.dispose();
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: SelectionAppBar(
        selection: controller.value,
      ),
      body: DragSelectGridView(
        gridController: controller,
        itemCount: 20,
        itemBuilder: (context, index, selected) {
          return SelectableItem(
            index: index,
            selected: selected,
          );
        },
        gridDelegate: SliverGridDelegateWithMaxCrossAxisExtent(
          maxCrossAxisExtent: 80,
        ),
      ),
    );
  }

  void scheduleRebuild() => setState(() {});
}

As you may have noticed in the code above, DragSelectGridView must be used along two other widgets in order to provide a proper user experience. In the example, they are:

  • SelectableItem: A selectable widget, which is going to visually indicate whether the item is selected or not.
  • SelectionAppBar: A custom AppBar, which shows the amount of selected items and an option to unselect them.
See also  Flutter Card Swipe View like Tinder

The example project provides some samples of those widgets. I won’t add them to the library, since they are unrelated to the grid itself, but feel free to copy them into your project, as long as you respect the license terms.

Advanced usage

You can use the setter DragSelectGridViewController.value to directly change the selection (I’m not quite sure why you’d need this, but I don’t ask questions).

See also  Flutter Simple AutoComplete TextFormField

It allows this sort of interaction:

Advance Uses
Advanced Uses

You can check the code here.

There are some other minor settings you can do to make DragSelectGridView fit your needs, like DragSelectGridView.autoScrollHotspotHeight and DragSelectGridView.unselectOnWillPop. Those features are well documented, so I’ll let you take your discovery time.

Hopefully, this is everything you need to know to use this library.

See also  Custom Date Range Picker in Flutter

Credit

This is developed by hcbpassos
Download this project from the below link.
https://github.com/hcbpassos/drag_select_grid_view/archive/refs/heads/master.zip
You can visit original source page from the below link:
https://github.com/hcbpassos/drag_select_grid_view

Spread the love

Leave a Reply