如何在画布中移动对象中设置onclick事件?

时间:2016-07-28 12:16:39

标签: javascript css canvas html5-canvas html2canvas

如何在画布中移动对象中设置click事件?另外如何在canvas中将对象从底部移动到顶部。我最近在javascript中我将开发样本,就像页面打开时一样,方形和圆形等对象随机来自页面底部并自动移动到顶部。

1 个答案:

答案 0 :(得分:2)

您需要建立一个包含移动对象的数组。触发onclick处理程序时,检查单击的坐标是否在数组中的任何对象内。

在每个动画帧上,通过从每个对象中减去一些y坐标来向上移动对象。

//width and height of canvas...
var rW = 400;
var rH = 500;

var coinImage = getCoinImage();
var coinsOnScreen = [];
var risingSpeed = 100; //pixels per second...
var coinSize = 75;

var lastAnimationTime = 0;
var howLongUntilNextCoin = 1000;
var nextCoinOnScreen = 0;

function doDraw() {
  var can = document.getElementById("myCanvas");
  can.width = rW;
  can.height = rH;
  var context = can.getContext("2d");

  //Erase the canvas
  context.fillStyle = "#FFFFFF";
  context.fillRect(0, 0, rW, rH);

  if (new Date().getTime() - nextCoinOnScreen > 0) {

    var newX = Math.floor(Math.random() * rW) + 1;
    var newY = rH + 50;

    var newCoin = {
      x: newX,
      y: newY
    };
    coinsOnScreen.push(newCoin);
    nextCoinOnScreen = new Date().getTime() + howLongUntilNextCoin;
  }

  //Now draw the coins
  if (lastAnimationTime != 0) {

    var deltaTime = new Date().getTime() - lastAnimationTime;
    var coinRisePixels = Math.floor((deltaTime * risingSpeed) / 1000);

    var survivingCoins = [];
    for (var i = 0; i < coinsOnScreen.length; i++) {
      var coin = coinsOnScreen[i];
      coin.y = coin.y - coinRisePixels;
      //the stl variable controlls the alpha of the image            
      if (coin.y + 50 > 0) {
        context.drawImage(coinImage, coin.x, coin.y);
        //this coin is still on the screen, so promote it to the new array...
        survivingCoins.push(coin);
      }
    }
    coinsOnScreen = survivingCoins;
  }
  lastAnimationTime = new Date().getTime();
  //Wait, and then call this function again to animate:
  setTimeout(function() {
    doDraw();
  }, 30);
}

function setupClickHandler() {
  var can = document.getElementById("myCanvas");
  //Here is the onclick handler
  can.onclick = function(e) {
    var x = e.clientX;
    var y = e.clientY;
    var survivingCoins = [];
    for (var i = 0; i < coinsOnScreen.length; i++) {
      var coin = coinsOnScreen[i];
      //check to see if this coin has been clicked...
      if (x > coin.x && x < coin.x + coinSize && y > coin.y && y < coin.y + coinSize) {
        //ths coin will disappear because it is not inserted into the new array...
        console.log("Coin was clicked!! " + x + " " + y);
      } else {
        survivingCoins.push(coin);
      }

    }
    coinsOnScreen = survivingCoins;
  };

}


doDraw();
setupClickHandler();

function getCoinImage() {
  var image = new Image(50, 50);
  image.src = "";
  return image;
}
<canvas id="myCanvas"></canvas>