轻按单元格时如何执行到新ViewController的过渡动画

时间:2019-05-03 08:13:22

标签: ios swift uitableview uiviewcontroller

我尝试在点击UIViewController时创建一个tableView cell过渡。我正在使用模态搜索转到另一个Viewcontroller,我将使用ViewController的transitioningDelegate,但它仍然无法执行动画。我不确定是否应该在prepareForSeguedidSelectRow中这样做。我是ViewController过渡的新手。我该如何纠正。

Pop Animator类

class PopAnimator: NSObject, UIViewControllerAnimatedTransitioning {

    func transitionDuration(using pTransitionContext: UIViewControllerContextTransitioning?) -> TimeInterval {
        return 1.0
    }

    func animateTransition(using pTransitionContext: UIViewControllerContextTransitioning) {
        let containerView = pTransitionContext.containerView
        guard let toView = pTransitionContext.view(forKey: .to) else { return }
        containerView.addSubview(toView)
        toView.alpha = 1.0
        UIView.animate(withDuration: 1.0, animations: {
            toView.alpha = 1.0
        }) { _ in
            pTransitionContext.completeTransition(true)
        }
    }
}

目标ViewController

class ThingsTransitionVC: UIViewController {

    @IBOutlet weak var nameLabel: UILabel!
    @IBOutlet weak var detailsLabel: UILabel!
    @IBOutlet weak var titleLabel: UILabel!

    var transitionThing: Thing?

    override func viewDidLoad() {
        super.viewDidLoad()
        if let thing = self.transitionThing {
            self.nameLabel.text = thing.name
            self.detailsLabel.text = thing.details
            self.titleLabel.text = thing.title
        }
    }

    @IBAction func cancelButton(_ sender: UIBarButtonItem) {
        self.presentingViewController?.dismiss(animated: true)
    }
}

列出包含表视图的ViewController

class ThingsListVC: UIViewController {
       override func prepare(for segue: UIStoryboardSegue, sender: Any?) {

        if segue.identifier == "ThingSegue" {
            let navVC = segue.destination as! UINavigationController
            let thingTransitionVC = navVC.topViewController as! ThingsTransitionVC
            let theThing = sender as? Thing
            thingTransitionVC.transitionThing = theThing
            thingTransitionVC.transitioningDelegate = self
        }
    }

     func tableView(_ pTableView: UITableView, didSelectRowAt pIndexPath: IndexPath) {
    let thingSelected = self.objectForIndexPath(pIndexPath)
    self.performSegue(withIdentifier: "ThingSegue", sender: thingSelected)
    pTableView.deselectRow(at: pIndexPath , animated: true)
}

}

extension ThingsListVC: UIViewControllerTransitioningDelegate {
    func animationController(forPresented presented: UIViewController, presenting: UIViewController, source: UIViewController) -> UIViewControllerAnimatedTransitioning? {
        let popAnimator = PopAnimator()
        return popAnimator
    }

    func animationController(forDismissed dismissed: UIViewController) -> UIViewControllerAnimatedTransitioning? {
        return nil
    }
}

1 个答案:

答案 0 :(得分:0)

在源ViewController中使用UIViewControllerTransitioningDelegate

  public override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
        if segue.identifier == "segueIdentifier1st"
        {

            let controller = segue.destination as! firstVC
            controller.transitioningDelegate = self
            controller.modalPresentationStyle = .custom

        }
        else if segue.identifier == "segueIdentifier2nd"
        {
            let controller = segue.destination as! secondVC

            controller.transitioningDelegate = self

            controller.modalPresentationStyle = .custom
        }
        //interactiveTransition.attach(to: controller)
    }
    override func shouldPerformSegue(withIdentifier identifier: String, sender: Any?) -> Bool {

        return true
    }
    // MARK: UIViewControllerTransitioningDelegate

    public func animationController(forPresented presented: UIViewController, presenting: UIViewController, source: UIViewController) -> UIViewControllerAnimatedTransitioning?
    {
        transition.transitionMode = .present
        if presented.restorationIdentifier!  == "segueIdentifier1st"
        {
            transition.startingPoint = CGPoint(x: btnAddWidget.center.x , y: btnAddWidget.frame.origin.y+50)
        }
        else if presented.restorationIdentifier! == "segueIdentifier2nd"
        {
            //transition.startingPoint = CGPoint(x: self.view.frame.size.width-45, y:45)
            transition.startingPoint = getTransitionOrigin()
        }
        transition.bubbleColor = backgroundThemeColor
        return transition
    }
    public func animationController(forDismissed dismissed: UIViewController) -> UIViewControllerAnimatedTransitioning? {
        transition.transitionMode = .dismiss
        if dismissed.restorationIdentifier!  == "segueIdentifier1st"
        {
            transition.startingPoint = CGPoint(x: btnAddWidget.center.x , y: btnAddWidget.frame.origin.y+50)
        }
        else if dismissed.restorationIdentifier! == "segueIdentifier2nd"
        {
            //transition.startingPoint = CGPoint(x: self.view.frame.size.width-45, y:45)
            transition.startingPoint = getTransitionOrigin()
        }
        transition.bubbleColor = backgroundThemeColor

        return transition
    }