UIViewPropertyAnimator

UIViewPropertyAnimator

如果我想通过UIViewPropertyAnimator利用与用户互动的动画,如何将对象顺时针旋转360º?

// Does not animate
let animator = UIViewPropertyAnimator(duration: 2, curve: .linear) {
    let radians = Angle(360).radians // 6.28318530717959
    view.transform = view.transform.rotated(by: CGFloat(radians))
}
// (Using RxSwift to handle the user interaction via UISlider,
// but that can be ignored as an implementation detail for this question.)
let scrubs = slider.rx.value.asDriver()
scrubs.drive(onNext: { (value:Float) -> Void in
    animator.fractionComplete = CGFloat(value)
})

最佳答案

幸运的是,UIViewPropertyAnimator使这个过程非常简单(如果不是有点hackish?)。只需制作两个动画,每个动画为180º:

let animator = UIViewPropertyAnimator(duration: 2, curve: .linear) {
    let radians = Angle(180).radians // 3.14159265358979
    view.transform = view.transform.rotated(by: CGFloat(radians))
}
animator.addAnimations {
    let radians = Angle(180).radians
    view.transform = view.transform.rotated(by: radians)
}

这就像一个动画,可以通过fractionComplete开始,停止,暂停,完成或“清理”。

ios - 如何使用UIViewPropertyAnimator旋转360º-LMLPHP

关于ios - 如何使用UIViewPropertyAnimator旋转360º,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/41182567/

10-12 13:07