SideMenu
SideMenu is an easy-to-use container view controller written in Swift.
Besides all the features a Side Menu should have, it supports:
- Four types of status bar behaviors which adopts by most Apps
- Three different menu position
- Both storyboard and programmatically
- Caching the content view controller and lazy initialization
- Rubber band effect while panning
Preview
Menu Position / Status Bar Behavior
Above + None | Below + Slide |
---|---|
![]() |
![]() |
SideBySide + Fade | SideBySide + HideOnMenu |
---|---|
![]() |
![]() |
We call the left/right view controller as the menu view controller, the central view controller as content view controller.
Installation
CocoaPods
To install SideMenu
with CocoaPods, add the below line in your Podfile
:
Carthage
To install SideMenu
with Carthage, add the below line in your Cartfile
:
github "kukushi/SideMenu" "master"
Usages
Storyboard
To set up SideMenu
in storyboard:
- Open the view controller's Identity inspector. Change the Class to
SideMenuController
and Module toSideMenuSwift
. - Set up the menu view controller and the initial content view controller in your Storyboard. Add a Custom segue from the
SideMenuController
to each of them.- Change the menu segue's identifier to
SideMenu.Menu
, Class toSideMenuSegue
and Module toSideMenuSwift
. - Change the content segue's identifier to
SideMenu.Content
, Class toSideMenuSegue
and Module toSideMenuSwift
.
- Change the menu segue's identifier to
- (Optional) If you want to use custom segue identifier:
- Open the
SideMenuController
's Attribute inspector. - In the Side Menu Controller section, modify the Content SegueID/Menu SegueID to the desired value and change the corresponding segue's identifier.
- Open the
- It's done. Check this screenshot a for clear view.
Programmatically
To start the app with SideMenu
:
Use the sm_sideMenuController
method provided in UIViewController
's extension to get the parent SideMenuController
:
Preferences
All the preferences of SideMenu can be found in SideMenuController.preferences
. Its recommend to check out the Example
to see how those options will take effect.
Caching The Content
One of the biggest features of SideMenu is caching.
What about the content view controller initialized from the Storyboard? We can use the preferences to apply a default key for it!
What if we can't want to load all the content view controllers so early? We can use lazy caching:
Requirements
- Xcode 9
- iOS 9.0 or later