SwipeTransition 允许使用滑动手势实现时尚的过渡效果,如“滑动返回”。
在网页上尝试演示(appetize.io): https://appetize.io/app/pebm8kveqhfj3wn204adn0xu8r
特性
- 在任意位置实现滑动返回。
- 在任意位置滑动以取消。
- 自动应用于所有视图控制器!
- 在
UIScrollView
、UITableView
、UICollectionView
等上无手势冲突。
要求
- Xcode 10.2 (10.0+)
- Swift 5 (4.2+)
- iOS 8.0+
安装
Carthage
github "tattn/SwipeTransition"
CocoaPods
pod "SwipeTransition"
pod "SwipeTransitionAutoSwipeBack" # if needed
pod "SwipeTransitionAutoSwipeToDismiss" # if needed
使用
使用方法
只需将这些框架设置到链接的框架和库
中,即可正常工作。(如果使用Carthage)
注意:这些框架使用方法交换。
如果您想不使用方法交换手动设置,请只使用SwipeTransition.framework
。
手动设置
注意:如果您使用`AutoSwipeBack.framework`,这些步骤是不必要的。
只需使用SwipeBackNavigationController
替换UINavigationController
。当然,您也可以使用Interface Builder进行设置。
let viewController = UIViewController()
let navigationController = SwipeBackNavigationController(rootViewControlelr: viewController)
另一种方法是将swipeBack
设置为true。
class CustomNavigationController: UINavigationController {
override func viewDidLoad() {
super.viewDidLoad()
swipeBack = SwipeBackController(navigationController: self)
}
}
注意:如果您使用`AutoSwipeToDismiss.framework`,这些步骤是不必要的。
只需使用SwipeToDismissNavigationController
替换UINavigationController
。当然,您也可以使用Interface Builder进行设置。
let viewController = UIViewController()
let navigationController = SwipeToDismissNavigationController(rootViewControlelr: viewController)
另一种方法是将swipeToDismiss
设置为true。
class CustomNavigationController: UINavigationController {
override func viewDidLoad() {
super.viewDidLoad()
modalPresentationStyle = .fullScreen
swipeToDismiss = SwipeToDismissController(viewController: self)
}
}
启用/禁用手势
使用isEnabled
属性。
self.navigationController?.swipeBack?.isEnabled = false
self.swipeToDismiss?.isEnabled = false
配置
您还可以改变动画之类的行为。
SwipeBackConfiguration.shared.parallaxFactor = 0.6
SwipeToDismissConfiguration.shared.dismissHeightRatio = 0.5
通过继承配置类,您可以用计算属性进行设置。
class CustomSwipeBackConfiguration: SwipeBackConfiguration {
override var transitionDuration: TimeInterval {
get { return 1.5 }
set { super.transitionDuration = newValue }
}
}
SwipeBackConfiguration.shared = CustomSwipeBackConfiguration()
其他使用
请参阅这个维基页面
参与贡献
- Fork它!
- 创建您的功能分支:
git checkout -b my-new-feature
- 提交您的更改:
git commit -am 'Add some feature'
- 推送到分支:
git push origin my-new-feature
- 提交.tabs.request-url
支持此项目
捐助以帮助我继续这项工作。
待办事项
- 所有
.modalPresentationStyle
支持 - 动画支持(淡入/自定义)
- 一些过渡样式支持(例如:从右向左滑动过渡)
许可证
SwipeTransition是在MIT许可证下发布的。有关详细信息,请参阅LICENSE。