Sometimes, your app’s UX designer wants infinite scroll for one of your collection views when the data displayed is limited. When a user scrolls to the very end of the data set, the first piece of data reappears on screen; if the use scrolls the other way, the last piece of data reappears.Traditionally, the solution for an infinite UICollectionView is to have a large duplicated data set (for example, 1000 * original data set) to trick the user into believing the collection view is infinite.
But, a large duplicated data will inevitably introduce extra overhead by having a large amount of UICollectionViewLayoutAttributes. Besides, what if the user is bored to death and just sits there for a day to scroll your collection view? The chance for this to happen might be small, but, after all, having a large duplicated data set is not a very elegant solution.
JWInfiniteCollectionView pads only a few extra duplicated items both at the start and end of your data set. In this way, it avoids most of the overhead introduced by having a large duplicated data set, if not all.
The infinite scrolling is made possible by padding extra items at both the left and right side (brown rectangles) of the original data set (black rectangles) to achieve larger scrollable area; This is similar to having a large duplicated data set, but difference is the amount.
- At start, the collection view’s contentOffset is calculated to show only the original data set (drawn in black rectangles);
- When the user scrolls right and contentOffset hits the trigger value, we reset contentOffset to show same visual results; but actually padded data set;
- When the user scrolls left, the same logic is used.
For more details, you can read this blog post.
To run the example project, clone the repo, and run pod install
from the Example directory first.
- iOS 8.0+
- ARC
- horizontal infinite scrolling
- simple custom flow layout
- add a infinite switch flag so that switch between normal collection view and infinitely-scrolling collection view is possible
- custom flow layout subclass to customize collection view cell layout attributes
- add more possible tests
CocoaPods is a dependency manager for developing iOS or OSX apps, which automates and simplifies the process of using 3rd-party libraries in your projects. See the "Getting Started" guide for more information. You can install it with the following command:
$ gem install cocoapods
To integrate JWWaveView into your Xcode project using CocoaPods, simply add the following line to your Podfile:
pod 'JWInfiniteCollectionView'
Then, run the following command:
$ pod install
Alex1989Wang, [email protected]
JWInfiniteCollectionView is available under the MIT license. See the LICENSE file for more info.