SwipeTransition 0.5.0

SwipeTransition 0.5.0

Tatsuya Tanaka 维护。



logotype-a

Build Status Carthage compatible pods Platform Swift Version Objective-C compatible

SwipeTransition 允许使用滑动手势实现时尚的过渡效果,如“滑动返回”。

Demo

在网页上尝试演示(appetize.io): https://appetize.io/app/pebm8kveqhfj3wn204adn0xu8r

特性

  • 在任意位置实现滑动返回。
  • 在任意位置滑动以取消。
  • 自动应用于所有视图控制器!
  • UIScrollViewUITableViewUICollectionView 等上无手势冲突。

要求

  • 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)

Linked Frameworks and Libraries

注意:这些框架使用方法交换。

如果您想不使用方法交换手动设置,请只使用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()

其他使用

请参阅这个维基页面

参与贡献

  1. Fork它!
  2. 创建您的功能分支: git checkout -b my-new-feature
  3. 提交您的更改: git commit -am 'Add some feature'
  4. 推送到分支:git push origin my-new-feature
  5. 提交.tabs.request-url

支持此项目

捐助以帮助我继续这项工作。

Donate

待办事项

  • 所有 .modalPresentationStyle 支持
  • 动画支持(淡入/自定义)
  • 一些过渡样式支持(例如:从右向左滑动过渡)

许可证

SwipeTransition是在MIT许可证下发布的。有关详细信息,请参阅LICENSE。