SwipeTransitionAutoSwipeToDismiss 0.5.0

SwipeTransitionAutoSwipeToDismiss 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》。

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》。

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. 分叉本项目!
  2. 创建您的功能分支: git checkout -b my-new-feature
  3. 提交您的更改: git commit -am '添加某个功能'
  4. 将分支推送到远程: git push origin my-new-feature
  5. 提交拉取请求 :D

支持此项目

捐赠以帮助我继续为此项目工作。

Donate

待办事项

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

许可证

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