项目作者: kukushi

项目描述 :
An interactive iOS side menu with rich features.
高级语言: Swift
项目地址: git://github.com/kukushi/SideMenu.git
创建时间: 2018-03-09T14:05:05Z
项目社区:https://github.com/kukushi/SideMenu

开源协议:MIT License

下载


" class="reference-link">

Version
Swift5
Carthage compatible
License
Platform

Overview

SideMenu is an easy-to-use side menu container controller written in Swift 5.

Besides all the features a Side Menu should have, it supports:

  • Four kinds of status bar behaviors (iOS 12 only)
  • Three different menu position
  • Both storyboard and programmatically
  • Caching the content view controller and lazy initialization
  • Rubber band effect while panning
  • Custom transition animation
  • RTL supports
  • API References
  • CHANGELOG

Preview

Menu Position / Status Menu 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

For Swift 5.0 and later, please use 2.0.0 or later version.

CocoaPods

To install SideMenu with CocoaPods, add the below line in your Podfile:

  1. pod 'SideMenuSwift'
  2. # Note it's NOT 'SideMenu'

Carthage

To install SideMenu with Carthage, add the below line in your Cartfile:

  1. github "kukushi/SideMenu" "master"

Swift Package Manager

  1. In your project’s Package Description, click the + to add a new package.
  2. Paste https://github.com/kukushi/SideMenu.git into the search field.
  3. Choose the project to integrate in the Add to Project selection box.
  4. Click Add Package.
  5. Note that you should use import SideMenu to import SideMenu.

Usages

Storyboard



To set up SideMenu in storyboard:



1. Open the view controller’s Identity inspector. Change its Class to SideMenuController and Module to SideMenuSwift.
2. 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 to SideMenuSegue and Module to SideMenuSwift.
- Change the content segue’s identifier to SideMenu.Content, Class to SideMenuSegue and Module to SideMenuSwift.
4. (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.
5. It’s done. Check this screenshot a for clear view.

Programmatically



To start the app with SideMenu programmatically:


swift import UIKit import SideMenuSwift // If you are using Carthage, uses `import SideMenu` @UIApplicationMain class AppDelegate: UIResponder, UIApplicationDelegate { var window: UIWindow? @objc func applicationDidFinishLaunching(_ application: UIApplication) { let contentViewController = ... let menuViewController = ... window = UIWindow(frame: UIScreen.main.bounds) window?.rootViewController = SideMenuController(contentViewController: contentViewController, menuViewController: menuViewController) window?.makeKeyAndVisible() return true } }

Use the sideMenuController method which provided in UIViewController‘s extension to get the parent SideMenuController:

  1. viewController.sideMenuController?.revealMenu()

Preferences

All the preferences of SideMenu can be found in SideMenuController.preferences. It’s recommend to check out the Example to see how those options will take effect.

  1. SideMenuController.preferences.basic.menuWidth = 240
  2. SideMenuController.preferences.basic.statusBarBehavior = .hideOnMenu
  3. SideMenuController.preferences.basic.position = .below
  4. SideMenuController.preferences.basic.direction = .left
  5. SideMenuController.preferences.basic.enablePanGesture = true
  6. SideMenuController.preferences.basic.supportedOrientations = .portrait
  7. SideMenuController.preferences.basic.shouldRespectLanguageDirection = true
  8. // See a lot more options on `Preferences.swift`.

Caching the Content

One of the coolest features of SideMenu is caching.

  1. // Cache the view controllers somewhere in your code
  2. sideMenuController?.cache(viewController: secondViewController, with: "second")
  3. sideMenuController?.cache(viewController: thirdViewController, with: "third")
  4. // Switch to it when needed
  5. sideMenuController?.setContentViewController(with: "second")

What about the content view controller initialized from the Storyboard? We can use the preferences to apply a default key for it!

  1. SideMenuController.preferences.basic.defaultCacheKey = "default"

What if we can’t want to load all the content view controllers so early? We can use lazy caching:

  1. sideMenuController?.cache(viewControllerGenerator: { self.storyboard?.instantiateViewController(withIdentifier: "SecondViewController") }, with: "second")
  2. sideMenuController?.cache(viewControllerGenerator: { self.storyboard?.instantiateViewController(withIdentifier: "ThirdViewController") }, with: "third")

Requirements

  • Xcode 15 or later
  • iOS 12.0 or later

License

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