A lightweight framework for displaying coachmarks in iOS apps. Built in pure Swift 👨💻
A compact coachmark which is generally used in list views. Here's a demo of what this looks like,
A coachmark similar to the one used on the appstore product page.
For CocoaPods, add this to your podfile
pod 'OSCoachmarkView', '~> 0.1'
For Carthage, add the following to your Cartfile
github "AamirAnwar/OSListCoachmark" ~> 0.1
You can use any of the preset coachmarks using OSListCoachmarkGenerator or create any custom view in the same fashion. Here is how you would embed your custom view inside the coachmark.
let view = CustomCoachmarkView()
let coachmarkView = OSCoachmarkView()
coachmarkView.attachedView = view
Sizing of the above custom coachmark will be based on autolayout subject to min/max constraints. To position the coachmark relative to the view, you can write your own logic to show/hide the coachmark or you can use OSCoachmarkPresenter to do this. Here's an example of what this might look like -
let coachmarkPresenter = OSCoachmarkPresenter()
coachmarkPresenter.view = coachmarkView
coachmarkPresenter.attachToView(self.view, anchor: .bottom)
OSCoachmarkPresenter objects can attach a coachmark to a given view with two modes - top and bottom. All animation and presentation logic is taken care of with you only having to call show() and hide() based on any logic you choose.
// Show
self.coachmarkPresenter.show()
//Hide
self.coachmarkPresenter.hide()
Checkout the example Xcode Project in the Example folder which has a demo with all three classes in action 🚀
- Added Blur support in OSListCoachmarkView
- Optional loader in OSListCoachmarkView
You can find the reference docs under OSCoachmarkView/docs/index.html
- iOS 11.0+
- Xcode 9
- Swift 4
All help is welcome. Open an issue or even better submit a pull request 😀
Aamir Anwar @aamiranwarr Feel free to reach out to me on twitter!
OSListCoachmark is released under the MIT license. See LICENSE for more details.
- Abstract out presenter logic
- Add animation options to both top and bottom modes
- Add blur support
- Create example coachmarks using the Factory Pattern
- Add Cocoapod/Carthage support
- Polish README
- Add Travis Support
- Generate documentation