• 締切済み

javascriptで滑らかに画像を動かす方法

androidアプリでjavascriptでトランプゲームを作ろうとしています。 実際にディーラーから、トランプが配られたみたいに滑らかにトランプを動かしたいのですが、何を使えばできるのでしょうか?

みんなの回答

  • b0a0a
  • ベストアンサー率49% (156/313)
回答No.3

requestAnimationFrameを使う

回答No.2

かんたんなことを、こむずかしく。 ぜんかくくうはくは、はんかくに。 いめーじてきに、くばられるかーどは、どんなうごきをするの? <!DOCTYPE html> <title>ぎゃらが?</title> <meta charset="UTF-8"> <style> #inv {  position: absolute; } </style> <body> <h1>アニメーション</h1> <p>  <img id ="inv" alt="インベーダ" width="36" height="24"   src=""> <script> (function () {  var win = this;    if ('undefined' === typeof this.requestAnimationFrame) {   this.requestAnimationFrame =    this.requestAnimationFrame ||    this.webkitRequestAnimationFrame||    this.mozRequestAnimationFrame  ||    this.oRequestAnimationFrame   ||    this.msRequestAnimationFrame  ||    function (callback, that) {     var tmpFunc = function () {      var timestamp = +(new Date); //(new Date).getTime ();      callback (timestamp); //callback.call (that, timestamp);     };     win.setTimeout (tmpFunc, Math.floor (1000/60));    };  }    //_____________      var ToAnimate = new Function;    ToAnimate.create =   (function (callBackFunction, operatingTime) {    if (1 > arguments.length)     throw new Error ('Invalid argument.');    if ('function' !== typeof callBackFunction)     throw new Error ('Not function.');    if ('undefined' === typeof operatingTime)     operatingTime = -1; //無限に        return {     state : null,          start :      (function (opTime_) {       if (this.state)        return;              this.state = true;              if (! isNaN (opTime_))        operatingTime = opTime_;              var now = (new Date).getTime ();       var AnimationEndTime = operatingTime + now;              (function cb (timeStamp) {        var opTime = AnimationEndTime - timeStamp;        var rate = opTime / operatingTime;        if (1 < rate) {         rate = 1;         callBackFunction (rate);        }        else if (rate < 0) {         rate = 0;         callBackFunction (rate);        } else {         callBackFunction (rate);         requestAnimationFrame (cb);        }       }) (now);      }),          stop :      (function () {       this.state = false;      })    };   });    //_____________    this.ToAnimate = ToAnimate;   }).call (window); var s = document.getElementById ('inv').style; function inv (rate) {//range 0-1  var x = 320 + Math.cos (rate*10) * 300;  var y = 600 - rate * 600;  s.top = y + 'px';  s.left = x + 'px'; } var anime = ToAnimate.create (inv, 3000);//callback, time(ms) anime.start (); </script>

回答No.1

jQueryを導入するのが一番楽なんじゃないでしょうか。

faneda
質問者

補足

ご回答ありがとうございます。 jQueryのどの機能を使用すれば実現できますか?

関連するQ&A

専門家に質問してみよう