2016-07-28 38 views
1

如何設置畫布中移動對象的點擊事件?另外如何在canvas中將對象從下到上移動到頂部。我是javascript中的新成員,我打算在頁面打開時開發樣本,像方形和圓形這樣的對象隨機從頁面底部自動移至頂部。如何設置在canvas中移動對象的onclick事件?

+1

從本質上講,你必須做繁重的自己。您需要檢查點擊位置是否與畫布上的對象相交。 http://stackoverflow.com/questions/9880279/how-do-i-add-a-simple-onclick-event-handler-to-a-canvas-element – Zach

回答

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>

相關問題