Note: This is a fork of ISPageScrollView. This fork uses UIViewControllers instead of UIViews.
ISPageScrollView is a UIScrollView subclass optimised for huge number of pages display. It uses lazy-loading mechanism to maintain only the previous few pages and the next few pages in order to minimize the memory usage.
id<ISPageScrollViewDataSource> dataSource: Like UITableViewDataSource, it asks its dataSource object for views displayed in each page.
id<ISPageScrollViewDelegate> pageDelegate: Tells receiver when a page will be removed from cache, has been removed from cache or when the displayed page changed.
NSInteger numberOfReusablePages: number of pages maintanined in memory. This number should be an odd number (e.g: 5 = current displayed page + 2 pages in front + 2 pages after)
NSMutableDictionary readonly scrollViewAvailablePages: this is the dictionary that stores the views of the pages in memory. The keys for the dictionary are NSNumbers for page index. The values for each key is an UIView object.
*-controllerForScrollView:(ISPageScrollView )scrollView page:(NSInteger)pageIndex: Needs to return the view controller to use on specified page.
*-numberOfPagesForPageScrollView:(ISPageScrollView )scrollView: Needs to return the number of pages in the scroll view.
It can be created in xcode like UIScollView or can be created programatically.
ISPageScrollView *pageScrollView = [[ISPageScrollView alloc] initWithFrame:CGRectMake(0, 0, 200, 100)];
pageScrollView.dataSource = self;
pageScrollView.numberOfReusableControllers = 5;
[pageScrollView displayPage:0];
Also implement both methods of the datasource.
UIKitHelper is available under the MIT license. See the LICENSE file for more info.