A UIPresentationController
and attendant clases for iOS to present a view
controller pinned to an edge of the screen like an action sheet.
To use SheetPresentation with the
Swift Package Manager, add it as a
dependency to your project from within Xcode or as a dependency in your
Package.swift
file.
To use SheetPresentation with CocoaPods, add a
dependency to your Podfile
:
target 'MyAwesomeApp' do
pod 'SheetPresentation'
end
Then run pod install
and use the generated .xcworkspace
to open your
project.
To use SheetPresentation with
Carthage, add a dependency to your
Cartfile
:
github "Detroit-Labs/SheetPresentation"
Run carthage update
to build the framework. Then follow the rest of the steps
in Carthage’s README to
add the framework to your project, configure a Run Script build phase, etc.
To use SheetPresentation, create a SheetPresentationManager
and
set it as the transitioningDelegate
of the view controller you want to
present, then set the modalPresentationStyle
of the view controller to
.custom
.
let manager = SheetPresentationManager() // Save this reference somewhere
let viewControllerToPresent = …
viewControllerToPresent.transitioningDelegate = manager
viewControllerToPresent.modalPresentationStyle = .custom
present(viewControllerToPresent, animated: true, completion: nil)
SheetPresentation also works with Objective-C:
SheetPresentationManager *manager = [[SheetPresentationManager alloc] init];
UIViewController *viewControllerToPresent = …;
viewControllerToPresent.transitioningDelegate = manager;
viewControllerToPresent.modalPresentationStyle = UIModalPresentationCustom;
[self presentViewController:viewControllerToPresent
animated:YES
completion:NULL];
To correctly compute the height of the presented view controller, it must either
satisfy Auto Layout constraints for a height using
systemLayoutSizeFitting(UIView.layoutFittingCompressedSize)
or have a non-zero
preferredContentSize
.