Skip to content

A horizontal scroller with optional pageControl and/or next and previous buttons

License

Notifications You must be signed in to change notification settings

abdelouali/PagedHorizontalView

 
 

Repository files navigation

PagedHorizontalView

Version License Platform

Supports Swift 3

A horizontal scoller view that makes its collection view cells full screen and can optionally wire UIPageControl and a previous and next UIbuttons.

It doesn't affect the appearance of the controls and doesn't implement the collection view data source to keep full flexibility while doing the repeated work for a horizontal scroller.

Requirements

  • iOS 7.0+ / Mac OS X 10.9+
  • Xcode 8.0
  • Swift 3.0

Usage

Interface builder:
  1. Drag and drop a UIView.
  2. Change the class name to PagedHorizontalView from identity inspector. Step 2
  3. Drag and drop a UICollectionView, use the defaults.
  4. Optionally drag and drop a UIPageControl
  5. Optionally drag and drop 2 UIButtons for next and previous
  6. Wire the UICollectionView to the PagedHorizontalView Step 4
  7. Wire the UIPageControl to the PagedHorizontalView either the reference outlet pageControl or the pageChanged: action. But not both.
  8. Wire the 2 UIButtons either the reference outlet nextButton and previousButton or touch up inside action with goToNextPage and goToPreviousPage. But not both, wiring the action and the reference outlet will give unexpected behavior.
Programmatically:

Alternatively, you can create it from code just as you create a normal UIView and set the properties instead of wiring them as described above for collectionView, pageControl, etc.

You need to set a layout object of kind UICollectionViewFlowLayout for the UICollectionView.

IMPORTANT

In both cases programmatically or using interface builder, you should set the dataSource for the UICollectionView yourself. This way, you have full flexibility to specify the layout of the scrolling content.

Demo

Step 4

Installation

For iOS 8 or later:

PagedHorizontalView is available through CocoaPods. To install it, simply add the following line to your Podfile:

pod "PagedHorizontalView"

For iOS 7.x:

Embedded frameworks require a minimum deployment target of iOS 8.

To use PagedHorizontalView with a project targeting iOS 7, you must include PagedHorizontalView.swift directly into your project.

Author

Mohamed Afifi, [email protected]

License

PagedHorizontalView is available under the MIT license. See the LICENSE file for more info.

About

A horizontal scroller with optional pageControl and/or next and previous buttons

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Swift 82.4%
  • Ruby 12.7%
  • Objective-C 4.9%