Infinite Carousel helps you to create interactive carousel experience within your Flutter applications.
Infinite Carousel does not use PageView underneath, therefore it has some unique features not present in PageView based Carousels like:
It allows you to control placement (or anchor) of selected item on viewport (unlike PageView which always has its selected page in the center of viewport).
It gives control over of scrolling speed, therefore allowing user to increase / slow the carousel movements when scrolled free hand.
It simulates a realistic slowing down effect after scrolling, adding a touch of natural behavior and refinement.
Default behaviour is InfiniteScrollPhysics
, which makes sure we always land on an item after free hand scrolling, with added friction effect. But you can also set it to PageViewTypeScrollPhysics
to get the PageView like scroll effect.
It supports infinite looping on items, and exposes both actual indices and relative indices of items.
It supports both horizontal and vertical axis directions with respect to LTR and RTL text directions.
Add the package to pubspec.yaml
$ flutter pub add infinite_carousel
or
dependencies:
infinite_carousel: ^1.1.1
After that import the package.
import 'package:infinite_carousel/infinite_carousel.dart';
InfiniteCarousel.builder(
itemCount: 10,
itemExtent: 120,
center: true,
anchor: 0.0,
velocityFactor: 0.2,
onIndexChanged: (index) {},
controller: controller,
axisDirection: Axis.horizontal,
loop: true,
itemBuilder: (context, itemIndex, realIndex) {
},
)
You can programatically control the Carousel movement by providing InfiniteScrollController
, which provides number of useful methods.
- pass
initialItem
in the constructor. - animateToItem(index)
- jumpToItem(index)
- nextItem()
- previousItem()
Attribute | Data Type | Description | Default Value |
---|---|---|---|
itemCount | int | Total number of items. | Required |
itemExtent | double | Size of single item in viewport. If axis is horizontal, then this corresponds to width of item, else height of the item. | Required |
itemBuilder | Widget Function(BuildContext, int itemIndex, int realIndex) | To lazily build items on the viewport. When Loop is false, ItemIndex is equal to RealIndex (i.e, index of element). When loop is true, two indexes are exposed by item builder. One is itemIndex, that is the modded item index i.e., for list of 10, position(11) = 1, and position(-1) = 9. Other is realIndex, that is the actual index, i.e. (..., -2, -1, 0, 1, 2, ...) in loop. Real Index is needed if you want to support JumpToItem by tapping on it. | Required |
physics | ScrollPhysics | Defaults to InfiniteScrollPhysics , which makes sure we always land on a particular item after free-hand scrolling. You can also provide PageViewTypeScrollPhysics to get PageView scroll effect. |
InfiniteScrollPhysics |
controller | ScrollController | Scroll Controller for the carousel. | InfiniteScrollController |
onIndexChanged | void Function(int) | Callback that includes new selected index. | |
anchor | double | Where to place selected item on the viewport. Ranges from 0 to 1. 0.0 means selected item is aligned to start of the viewport, and 1.0 meaning selected item is aligned to end of the viewport. This property is ignored when center is set to true. | 0.0 |
loop | bool | Whether to create a infinite looping list | true |
velocityFactor | double | Increase/Decrease velocity of carousel scrolling to this factor. | 0.2 |
axisDirection | Axis | Axis direction of carousel. | Axis.horizontal |
center | bool | Align selected item to center of the viewport. When this is true, anchor property is ignored. | true |
Earlier, flutter allowed scrolling the widgets by dragging using the mouse. Now, by default, it allows scrolling widgets to be dragged by all PointerDeviceKinds except for PointerDeviceKind.mouse.
If you want to support scrolling by drag, please pass the explicit ScrollBehavior
to InfiniteCarousel.
scrollBehavior: ScrollConfiguration.of(context).copyWith(
dragDevices: {
// Allows to swipe in web browsers
PointerDeviceKind.touch,
PointerDeviceKind.mouse
},
),
Reference: https://docs.flutter.dev/release/breaking-changes/default-scroll-behavior-drag
Contributions of all kinds are welcome. Please read CONTRIBUTING.md and CODE_OF_CONDUCT.md before raising issues and creating new pull requests.
Images used in the gifs belong to their original authors and the links can be found in example project.
Manuinder Sekhon @ GeekyAnts (Github)