我想在tabswitch [1]创建一个类似iOS app facebook的动画.我已经尝试开发某种动画,出现的问题是旧的视图控制器直接在交换机上变得不可见,而不是在新控制器快速滑动时缓慢淡出.
我发现这个问题How to animate Tab bar tab switch with a CrossDissolve slide transition?,但正确的标记解决方案对我来说并不适用(它不是幻灯片,它是一个淡入淡出过渡).我还想得到的是向左或向右滑动以切换标签的功能.就像在旧版本的facebook上一样.
到目前为止我得到的是:
extension TabBarController: UITabBarControllerDelegate { func tabBarController(_ tabBarController: UITabBarController,shouldSelect viewController: UIViewController) -> Bool { guard let fromView = selectedViewController?.view,let toView = viewController.view else { return false } if fromView != toView { toView.transform = CGAffineTransform(translationX: -90,y: 0) UIView.animate(withDuration: 0.25,delay: 0.0,options: .curveEaseInOut,animations: { toView.transform = CGAffineTransform(translationX: 0,y: 0) }) }; return true } }
class TabBarController: UITabBarController { override func viewDidLoad() { super.viewDidLoad() delegate = self } }
如何解决这个问题?
[1]
我非常想从Facebook应用程序中添加一个gif.问题是我不想审查视频,只是透露了太多的数据. (即使fb已经拥有它们).另外在youtube上我找不到合适的录音.请在iOS的fb应用程序中自行尝试.
您可以使用以下想法:
https://samwize.com/2016/04/27/making-tab-bar-slide-when-selected/
此外,这里是更新到Swift 4.1的代码,我也删除了强制解包:
import UIKit class MyTabBarController: UITabBarController { override func viewDidLoad() { super.viewDidLoad() delegate = self } } extension MyTabBarController: UITabBarControllerDelegate { func tabBarController(_ tabBarController: UITabBarController,shouldSelect viewController: UIViewController) -> Bool { guard let tabViewControllers = tabBarController.viewControllers,let toIndex = tabViewControllers.index(of: viewController) else { return false } animatetoTab(toIndex: toIndex) return true } func animatetoTab(toIndex: Int) { guard let tabViewControllers = viewControllers,let selectedVC = selectedViewController else { return } guard let fromView = selectedVC.view,let toView = tabViewControllers[toIndex].view,let fromIndex = tabViewControllers.index(of: selectedVC),fromIndex != toIndex else { return } // Add the toView to the tab bar view fromView.superview?.addSubview(toView) // Position toView off screen (to the left/right of fromView) let screenWidth = UIScreen.main.bounds.size.width let scrollRight = toIndex > fromIndex let offset = (scrollRight ? screenWidth : -screenWidth) toView.center = CGPoint(x: fromView.center.x + offset,y: toView.center.y) // disable interaction during animation view.isUserInteractionEnabled = false UIView.animate(withDuration: 0.3,usingSpringWithdamping: 1,initialSpringVeLocity: 0,options: .curveEaSEOut,animations: { // Slide the views by -offset fromView.center = CGPoint(x: fromView.center.x - offset,y: fromView.center.y) toView.center = CGPoint(x: toView.center.x - offset,y: toView.center.y) },completion: { finished in // Remove the old view from the tabbar view. fromView.removeFromSuperview() self.selectedindex = toIndex self.view.isUserInteractionEnabled = true }) } }
因此,您需要继承UITabBarController并且还必须编写动画部分,您可以调整动画选项(延迟,持续时间等).
我希望它有所帮助,欢呼!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。