Swift2を使用したiOS開発-アニメーション

アニメーションは、ユーザーの注意をアプリケーションに引き付けるため、アプリケーションの重要な部分です。アニメーションは、高速で繰り返される画像のコレクションにすぎません。また、アプリケーションを他のアプリケーションとは異なるものにします。

アニメーションプロジェクトの作成-キティアニメーション

これは単純なプロジェクトで、ボタンがクリックされたときにアニメーションを実行します。複数の画像を使用してGIFを作成するため、任意のGIFをダウンロードして画像に変換すると、そのGIFの複数のフレームが作成されます。

このセクションでは、次の画像を使用します。

これらの画像を一緒に再生すると、アニメーションが作成されます。したがって、シングルビューアプリケーションを作成します。次に、画像表示オプション、ラベル、およびボタンをメインビューコントローラー内にドラッグします。これが完了したら、画像ビューとボタンをSwiftファイルに接続します。

(これらの画像を使用したくない場合は、gifを検索し、gifから画像へのコンバーターを使用してオンラインで画像に変換します。)

ボタンアクションの中に、ボタンが押されたときに画像を表示する次のコマンドを挿入します。

imageView.image = UIImage(named: "frame_0_delay-0.1s.gif") 
// frame_0_delay-0.1s.gif, is the name of image

これは、プログラムで画像を画像ビューに割り当てる方法です。ビューは次のようになります-

アプリケーションを実行すると、最初のビューが表示されます。アニメーションボタンをクリックすると、画像が表示されます。

これはアニメーションではなく、単なる画像です。今すぐアニメーションを作成します-

画像アウトレットの下に変数を追加します。 var counter = 1

画像に共通の名前があり、1つの文字だけが異なることを確認してください。以下に示すように、アニメーションボタンのコードを変更します-

@IBAction func animatePressed(_ sender: Any) { 
   imageView.image = UIImage(named: "frame_\(counter)_delay-0.1s.gif") 
   counter += 1 
   if counter == 9 { 
      counter = 0 
   } 
}

今、あなたが押すと animateボタンを押すと、画像が毎回変わります。次のステップは、以下を作成することです-

  • 変数を作成する- isAnimating そしてそれにFalseを割り当てます。

  • タイマー変数を作成し、 Timer() それに機能します。

上記の2つの手順が完了したら、関数animateを作成し、次のコードを貼り付けます。

func animate() { 
   imageView.image = UIImage(named: "frame_\(counter)_delay-s.gif") 
   counter += 1 
   if counter == 9 { 
      counter = 0 
   } 
}

ここで、counterは、前のファイルで作成したカウンター変数です。ここで、アニメーションボタン関数内に次のコードを追加します-

if isAnimating { 
   timer.invalidate() 
   isAnimating = false 
} else { 
   timer = Timer.scheduledTimer(timeInterval: 0.1, target: self, selector: 
   #selector(ViewController.animate), userInfo: nil, repeats: true) 
   isAnimating = true 
}

アプリケーションを実行してみると、デバイスでアニメーションが実行されていることがわかります。

Challenge −アニメーションを停止する停止ボタンを追加します。