0

キャンバス上の画像を歪ませてアニメーション化したい。キャンバスに画像を描画できますが、描画後にスキューしてアニメーション化するにはどうすればよいですか?キャンバスに描かれた画像の参照を取得するにはどうすればよいですか?

このように帆布に絵を描くことができます

var ctx = document.getElementById('canvas').getContext('2d');
ctx.drawImage(image, sx, sy, sWidth, sHeight, dx, dy, dWidth, dHeight);
4

1 に答える 1

1

以下は、始めるための非常に大まかなスケッチです。

$(function () {
  var
    loaded = false,
    ctx = $('canvas')[0].getContext('2d'),
    img;

  img = $('<img>', {
    src: 'http://www.gravatar.com/avatar/e25f40f6711403073e7da6c33be21eb8?s=128&d=identicon&r=PG'
  }).on('load', function () {
    loaded = true;
  }).get(0);


  setInterval(function () {
    var f = 0;

    return function () {
      if (loaded) {
        ctx.clearRect(0, 0, 500, 500);

        ctx.save();
        ctx.setTransform (1, f, 0, 1, 0, 0);
        ctx.drawImage(img, 50, 50);
        ctx.restore();

        f += 0.01;

        if (f > 1) {
          f = 0;
        }
      }
    };
  }(), 16);
});

デモ: http://jsfiddle.net/UHSKL/

于 2012-05-02T08:30:36.990 に答える