ホームページ ウェブフロントエンド H5 チュートリアル HTML5 Canvas を使用してキーボードとマウスのアニメーションを作成する例を共有する_html5 チュートリアル スキル

HTML5 Canvas を使用してキーボードとマウスのアニメーションを作成する例を共有する_html5 チュートリアル スキル

May 16, 2016 pm 03:45 PM
canvas html5 アニメーション

キーボードでボールの動きを制御します

ご存知のとおり、私たちが見ているアニメーションは、実際には静止画像の素早い切り替えの連続であり、視覚的な残像により肉眼では「動画」のような視覚効果を与えます。これを理解すると、キャンバス上にアニメーション効果を描画することが比較的簡単になります。最初に特定の静的グラフィックをクリアし、それを別の場所に再描画することを繰り返して、静的グラフィックを特定の軌道に従って移動させ、アニメーション効果を生成するだけです。

次に、キャンバス上に固体のボールを描画し、キーボードの矢印キーを使用してボールの動きを制御し、ダイナミックな効果を生み出します。サンプルコードは次のとおりです:

JavaScript コードコンテンツをクリップボードにコピーします
  1. "UTF-8">
  2. html5キャンバス描画可動ボール入力例
  3. "moveBall(event)">
  4. <キャンバス ID="myCanvas" width="400px" height="300px" style="border: 1px 単色赤;">
  5. お使いのブラウザは Canvas タグをサポートしていません。
  6. <スクリプトタイプ="text/javascript">
  7. //Canvas オブジェクト (canvas) を取得します
  8. var Canvas = document.getElementById("myCanvas");
  9. //球のクラスを表します
  10. 関数 Ball(x, y ,radius,speed){
  11. this.x = x || 10; //球の x 座標、デフォルトは 10
  12. this.y = y || 10; //球の y 座標、デフォルトは 10
  13. this.radius = radius || //球の半径、デフォルトは 10
  14. this.speed = 速度 || // ボールの移動速度、デフォルトは 5
  15. //上に移動
  16. this.moveUp = 関数(){
  17. this.y -= this.speed
  18. if(this.y < .radius){ //上限を超えないようにします
  19. RM
  20. };
  21. //右に移動
  22. this
  23. .moveRight =
  24. function
  25. (){
  26. this
  27. .x =
  28. this.speed var
  29. maxX = Canvas.width -
  30. this.radius; if(
  31. this
  32. .x > maxX){ //正しい境界を超えないようにします
  33. この.x = maxX; }
  34. };
  35. //左に移動
  36. this.moveLeft = function(){
  37. this.x -= this.speed
  38. if(this.x < .radius){
  39. //左境界を超えないようにします
  40. this
  41. .x = this.radius;
  42. };
  43. //下に移動
  44. this
  45. .moveDown =
  46. function(){ this
  47. .y =
  48. this.speed var
  49. maxY = Canvas.height -
  50. this.radius; if(
  51. this
  52. .y > maxY){ //下限を超えないようにします
  53. これ.y = maxY;
  54. }; }
  55. //ボールを描く
  56. 関数
  57. drawBall(ball){
  58. if
  59. (typeof ctx !=
  60. "未定義"
  61. ){ ctx.beginPath(); ctx.arc(ball.x, ball.y, ball.radius, 0, Math.PI * 2, false); >
  62. ctx.fill();
  63. }
  64. }
  65. //キャンバスをクリア
  66. 関数 clearCanvas(){
  67. if(typeof ctx != "未定義"){
  68. ctx.clearRect(0, 0, 400, 300);
  69. }
  70. }
  71. var ball = new Ball();
  72. //HTML5 をサポートしていない一部のブラウザで構文エラーが表示されるのを避けるために、現在のブラウザが Canvas オブジェクトをサポートしているかどうかを単純に検出します
  73. if(canvas.getContext){
  74. //対応する CanvasRenderingContext2D オブジェクト (ブラシ) を取得します
  75. var ctx = Canvas.getContext("2d"); ドローボール (ボール)
  76. }
  77. //onkeydown イベントのコールバック ハンドラー関数
  78. //ユーザーのキーに従ってボールの動きを制御します
  79. 関数 moveBall(event){
  80. スイッチ(event.keyCode){
  81. case 37: //左矢印キー
  82. ball.moveLeft();
  83. ブレイク;
  84. case 38: //上方向キー
  85. ball.moveUp();
  86. ブレイク;
  87. case
  88. 39: //右矢印キー ball.moveRight();
  89. ブレイク
  90. ; case
  91. 40:
  92. //下矢印キー ball.moveDown();
  93. ブレイク
  94. ;
  95. default:
  96. //その他のキー操作は反応しません
  97. 戻る;
  98. }
  99. clearCanvas();
  100. //まずキャンバスをクリアします
  101. drawBall(ball);
  102. //最新のボールを描画します
  103. }
  104. HTML5 をサポートするブラウザを使用して次の Web ページを開いて実際の効果を確認してください (矢印キーを使用して移動します):
  105. キャンバスを使用して可動ボールを描画します
ピエロのスマイリーフェイス
いくつかの API を理解するだけで、必要なアニメーション パラメーターを使用して、動きに反応するこの興味深い Web アニメーションを作成できます。

最初のステップは顔の特徴を描くことです
このピエロには耳と眉がないので、器官は 3 つだけ残っていますが、2 つの目は別々に描く必要があるので、合計 4 つのパーツがあります。まずはコードを見てみましょう。

左目を描画するコード



JavaScript コード

コンテンツをクリップボードにコピーします

  1. var leftEye = new Kinetic.Line({
  2. x: 150、
  3. ポイント: [0, 200, 50, 190, 100, 200, 50, 210]、
  4. テンション: 0.5、
  5. クローズ済み: true
  6. ストローク: '白'
  7. ストローク幅: 10
  8. });

右目を描画するコード

JavaScript コードコンテンツをクリップボードにコピーします
  1. var rightEye = new Kinetic.Line({
  2. x: sw - 250、
  3. ポイント: [0, 200, 50, 190, 100, 200, 50, 210]、
  4. テンション: 0.5、
  5. クローズ済み: true
  6. ストローク: '白'
  7. ストローク幅: 10
  8. });

鼻を描くためのコード

JavaScript コードコンテンツをクリップボードにコピーします
  1. var names = new Kinetic.Line({
  2. ポイント: [240, 280, sw/2, 300, sw-240,280]、
  3. テンション: 0.5、
  4. クローズ済み: true
  5. ストローク: '白'
  6. ストローク幅: 10
  7. });

口を描くためのコード

JavaScript コードコンテンツをクリップボードにコピーします
  1. varmouth = new Kinetic.Line({
  2. ポイント: [150, 340, sw/2, 380, sw - 150, 340, sw/2, sh]、
  3. テンション: 0.5、
  4. クローズ済み: true
  5. ストローク: 「赤」
  6. ストローク幅: 10
  7. });

それがほんの数行のコードであることがわかったら、がっかりするでしょうか?はい、とても簡単です。あなたは Web ゲーム アニメーション プログラマーになれるという自信を持ち始めていると思います。

上記のコードを簡単に説明します。 Kinetic は私たちが使用する JS ツールキットです。ページの先頭で、次のように参照する必要があります:

JavaScript コードコンテンツをクリップボードにコピーします
  1. varmouth = new Kinetic.Line({
  2. ポイント: [150, 340, sw/2, 380, sw - 150, 340, sw/2, sh]、
  3. テンション: 0.5、
  4. クローズ済み: true
  5. ストローク: 「赤」
  6. ストローク幅: 10
  7. });

その他は、線の弾力性、色、幅など、いくつかの重要なポイントです。これらは理解しやすいです。

2 番目のステップは、画像を動かすことです

このアニメーションが魅力的な理由は、マウスの動きに反応し、ユーザーと対話できることです。これは、アニメーションを成功させるために最も重要な側面です。よく観察すると、ピエロの顔の変化は目が大きくなり、口が大きくなり、鼻が大きくなるだけです。しかし、特別なのは、この変化が瞬間的な変化ではないということです。そこにはいくつかのアルゴリズムが含まれています。これが最も懸念される部分です。幸いなことに、これらのアルゴリズム テクノロジは非常に成熟しており、アニメーション エンジン ライブラリはこれらのテクノロジを非常にシンプルで便利なインターフェイスにカプセル化しています。物事を動かす方法を見てみましょう。

左目のアニメーション

JavaScript コードコンテンツをクリップボードにコピーします
  1. var leftEyeTween = new Kinetic.Tween({
  2. ノード: leftEye、
  3. 期間: 1、
  4. イージング: Kinetic.Easings.ElasticEaseOut、
  5. y: -100、
  6. ポイント: [0, 200, 50, 150, 100, 200, 50, 200]
  7. });

右目のアニメーション

JavaScript コードコンテンツをクリップボードにコピーします
  1. var rightEyeTween = new Kinetic.Tween({
  2. ノード: rightEye、
  3. 期間: 1、
  4. イージング: Kinetic.Easings.ElasticEaseOut、
  5. y: -100、
  6. ポイント: [0, 200, 50, 150, 100, 200, 50, 200]
  7. });

鼻のアニメーション

JavaScript コードコンテンツをクリップボードにコピーします
  1. var namesTween = new Kinetic.Tween({
  2. ノード: 鼻、
  3. 期間: 1、
  4. イージング: Kinetic.Easings.ElasticEaseOut、
  5. y: -100、
  6. ポイント: [220, 280, sw/2, 200, sw-220,280]
  7. });

口のアニメーション

JavaScript コードコンテンツをクリップボードにコピーします
  1. varmouthTween = new Kinetic.Tween({
  2. ノード: 口、
  3. 期間: 1、
  4. イージング: Kinetic.Easings.ElasticEaseOut、
  5. ポイント: [100, 250, sw/2, 250, sw - 100, 250, sw/2, sh-20]
  6. });

コードは非常に単純で、変数名は一目瞭然です。経験の少ないプログラマにとって、これらのコードを理解するのは難しくありません。基本的に、コードのすべての部分で、アニメーション アクションの減衰モードと期間を指定するためのいくつかのポイントを指定できます。

完全なアニメーション コード

JavaScript コードコンテンツをクリップボードにコピーします
  1.   
  2.   
  3.      
  4.        
  5.      
  6.      
  7.     
    "container">
      
  8.   
  9.   
  10.   
  11.   

デモを見る

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

HTMLの表の境界線 HTMLの表の境界線 Sep 04, 2024 pm 04:49 PM

HTML の表の境界線に関するガイド。ここでは、HTML でのテーブルの境界線の例を示しながら、テーブル境界線を定義する複数の方法について説明します。

HTML のネストされたテーブル HTML のネストされたテーブル Sep 04, 2024 pm 04:49 PM

これは、HTML でのネストされたテーブルのガイドです。ここでは、テーブル内にテーブルを作成する方法をそれぞれの例とともに説明します。

HTML 左マージン HTML 左マージン Sep 04, 2024 pm 04:48 PM

HTML マージン左のガイド。ここでは、HTML margin-left の概要とその例、およびそのコード実装について説明します。

HTML テーブルのレイアウト HTML テーブルのレイアウト Sep 04, 2024 pm 04:54 PM

HTML テーブル レイアウトのガイド。ここでは、HTML テーブル レイアウトの値と例および出力について詳しく説明します。

HTML入力プレースホルダー HTML入力プレースホルダー Sep 04, 2024 pm 04:54 PM

HTML 入力プレースホルダーのガイド。ここでは、コードと出力とともに HTML 入力プレースホルダーの例について説明します。

HTML 内のテキストの移動 HTML 内のテキストの移動 Sep 04, 2024 pm 04:45 PM

HTML でのテキストの移動に関するガイド。ここでは、概要、マーキー タグが構文でどのように機能するか、および実装例について説明します。

HTML 順序付きリスト HTML 順序付きリスト Sep 04, 2024 pm 04:43 PM

HTML 順序付きリストのガイド。ここでは、HTML 順序付きリストと型の導入とその例についても説明します。

HTML の onclick ボタン HTML の onclick ボタン Sep 04, 2024 pm 04:49 PM

HTML オンクリック ボタンのガイド。ここでは、それらの紹介、動作、例、およびさまざまなイベントでの onclick イベントについてそれぞれ説明します。

See all articles