質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

Q&A

0回答

314閲覧

アニメーションが再利用できない

midomurasaki

総合スコア46

iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

0グッド

0クリップ

投稿2017/11/26 11:22

編集2022/01/12 10:55

Swift4, iOSアプリの実装で質問です。

UIViewPropertyAnimatorを使用してアニメーションを表示させようと思い、以下のコードを作成しました。
Storyboardにはボタンとスイッチが一つずつあるシンプルな構成で、アニメーション対象となるUIViewはコード内で作成しています。

swift

1import UIKit 2 3class ViewController: UIViewController { 4 5 @IBOutlet weak var reverseSwitch: UISwitch! 6 var animator: UIViewPropertyAnimator? 7 8 @IBAction func switchReverse(_ sender: UISwitch) { 9 animator?.isReversed = sender.isOn 10 } 11 12 @IBAction func pushAnimationButton(_ sender: Any) { 13 animator?.startAnimation() 14 } 15 16 override func viewDidLoad() { 17 super.viewDidLoad() 18 19 let rect: CGRect = CGRect(x: 0, y: 0, width: 20, height: 20) 20 let view: UIView = UIView(frame: rect) 21 view.backgroundColor = UIColor.blue 22 self.view.addSubview(view) 23 24 animator = UIViewPropertyAnimator(duration: 3, curve: .easeOut) { 25 view.center = self.view.center 26 } 27 guard let isReversed: Bool = animator?.isReversed else { return } 28 reverseSwitch.isOn = isReversed 29 } 30 31 override func didReceiveMemoryWarning() { 32 super.didReceiveMemoryWarning() 33 } 34 35} 36

ここで、以下2点の問題が解決できず困っています。

  • アニメーションを終えた後、animator?.startAnimation()を呼び出しても再度アニメーションさせることができない
  • curveを.easeOut等に設定し、animator?.isReversedで逆再生すると座標が飛んでしまう

animatorのstateの状態がいくつかあり、その状態によってはstartAnimation()ができないのかと思い、stopAnimation(_ withoutFinishing: Bool)finishAnimation(at: UIViewAnimatingPosition)を試した上で呼び出しても再度アニメーションさせることが出来ませんでした。

実行結果

イメージ説明

上記問題の解決方法について、ご回答よろしくお願いいたします。

参考URL
https://dev.classmethod.jp/smartphone/ios10-uiviewpropertyanimator/
https://qiita.com/KEN-chan/items/f80c17c583ac44d67a58

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問