国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

canvas 繪制貪吃蛇游戲

AlphaWallet / 1235人閱讀

摘要:蛇類當中的保存當前蛇類的所有的方塊。移動,根據(jù)保存的私有變量方向用來對數(shù)組中保存的方塊對象進行更改還有一個蘋果類。用于進行隨機生成吃蘋果,在移動方法中,如果蛇的頭方塊和蘋果方塊重合那么吃到蘋果,重新調(diào)用生成蘋果方法。

效果如下

代碼



    
    貪吃蛇
    





let canvas = document.getElementById("canvas");
let context = canvas.getContext("2d");
// 分數(shù)記錄
let fraction = 0;
// 定義貪吃蛇的組成,方塊對象
class Block{
    // 按照size的大小劃分行列
    // 列
    col;
    // 行
    row;
    // 大小
    size;
    constructor(col, row, size){
        this.col = col;
        this.row = row;
        this.size = size;
    }
    // 畫方法
    draw(){
        context.fillRect(this.col * this.size, this.row * this.size, this.size, this.size);
    }
}
// 蛇類
class Snake{
    body = [new Block(20, 20, 10), new Block(20, 21, 10)];
    direction = "right";
    apple;
    constructor(apple) {
        this.apple = apple;
    }
    draw(){
        for(let i = 0; i < this.body.length; i++){
            this.body[i].draw();
        }
    };
    move(){
        let head = this.body[0];
        // 用于生成新蛇的方塊
        let newhead;
        if(this.direction == "right"){
            newhead = new Block(head.col + 1, head.row, head.size);
        }
        if(this.direction == "left"){
            newhead = new Block(head.col - 1, head.row, head.size);
        }
        if(this.direction == "up"){
            newhead = new Block(head.col, head.row - 1, head.size);
        }
        if(this.direction == "down"){
            newhead = new Block(head.col, head.row + 1, head.size);
        }
        // 增加頭部
        this.body.unshift(newhead);
        // 進行判斷蛇頭是否碰到了蘋果,若碰到了則不刪除最后一個方塊,反之刪除最后一個方塊
        if(newhead.col == this.apple.col
            && newhead.row == this.apple.row){
            // 進行檢測,如果生成在蛇身上,繼續(xù)生成,反之結(jié)束循環(huán)
            while(true){
                this.apple.initialization();
                for(let i = 0; i < this.body.length; i++){
                    if(this.apple.row == this.body[i].row
                        && this.apple.col == this.body[i].col){
                        this.apple.initialization();
                    }
                }
                break;
            }
            // 分數(shù)加入
            fraction++;
        }else{
            // 彈出
            this.body.pop();
        }
    };
    // 碰撞檢測
    impactChecking(){
        // 獲取頭節(jié)點
        let newBody = this.body[0];
        console.log(newBody.col);
        // 查看行,列是否超過邊界
        if(newBody.col > 40
            || newBody.row > 40
            || newBody.row < 0
            || newBody.col < 0){
            alert("游戲結(jié)束");
            fraction = 0;
            this.body = [new Block(20, 20, 10), new Block(20, 21, 10)];
        }
        // 查看是否碰到自己身體
        for(let i = 1; i < this.body.length; i++){
            if(newBody.col == this.body[i].col
                && newBody.row == this.body[i].row){
                alert("游戲結(jié)束");
                fraction = 0;
                this.body = [new Block(20, 20, 10), new Block(20, 21, 10)];
            }
        }
    }
}
// 實物,蘋果類
class Apple{
    // 列
    col;
    // 行
    row;
    sizeR;
    constructor(){
        this.initialization();
    };
    // 初始化蘋果
    initialization(){
        // 生成列坐標
        this.col = Math.floor(Math.random() * (40 - 1) + 1);
        // 生成行坐標
        this.row = Math.floor(Math.random() * (40 - 1) + 1);
        // 設(shè)置蘋果半徑
        this.sizeR = 5;
    }
    // 畫蘋果的方法
    draw(){
        // 顏色
        context.fillStyle = "Red";
        // 畫蘋果
        context.beginPath();
        // 圓心坐標
        context.arc(this.col * this.sizeR * 2 + this.sizeR, this.row * this.sizeR * 2 + this.sizeR, this.sizeR, 0, Math.PI * 2, false);
        // 填充
        context.fill();
        // 恢復原來顏色
        context.fillStyle = "Black";
    }
}
// 生成一個蘋果
let apple = new Apple();
// 生成一個蛇
let snake = new Snake(apple);
setInterval(() => {
    context.clearRect(0, 0, 400, 400);
    // 繪制分數(shù)
    context.fillText("分數(shù)為 " + fraction, 10, 10);
    // 繪制蛇
    snake.draw();
    // 對蛇進行移動
    snake.move();
    // 繪制蘋果
    apple.draw();
    // 進行檢測
    snake.impactChecking();
    context.strokeRect(0, 0, 400, 400);
}, 200);
// 對貪吃蛇控制
// 上下左右運動
$("body").keydown((event) => {
    // 左
    if(event.keyCode == 37 && snake.direction != "right"){
        snake.direction = "left";
    }
    // 上
    if(event.keyCode == 38 && snake.direction != "down"){
        snake.direction = "up";
    }
    // 右
    if(event.keyCode == 39 && snake.direction != "left"){
        snake.direction = "right";
    }
    // 下
    if(event.keyCode == 40 && snake.direction != "up"){
        snake.direction = "down";
    }
});
思路

思路,蛇由兩個類組成,方塊類和蛇類,蛇類的存在依賴于方塊類。蛇類當中的body保存當前蛇類的所有的方塊。繪圖,直接遍歷body內(nèi)部的所有繪圖方法。移動,根據(jù)保存的私有變量方向用來對數(shù)組中保存的方塊對象進行更改
還有一個蘋果類。用于進行隨機生成
吃蘋果,在移動方法中,如果蛇的頭方塊和蘋果方塊重合那么吃到蘋果,重新調(diào)用生成蘋果方法。
碰撞檢測,如果行和列超過范圍,即碰撞發(fā)生
最重要的,坐標行和列化,使用的時候乘以一個數(shù)就行

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/101666.html

相關(guān)文章

  • 使用TypeScript和Canvas編寫移動端貪吃大作戰(zhàn)游戲

    摘要:基本介紹一款移動端貪吃蛇大作戰(zhàn)游戲。主要的游戲邏輯有貪吃蛇移動碰撞檢測貪吃蛇碰撞碰撞墻壁和吃食物。貪吃蛇的身體如何跟隨頭部移動需要分為兩種情況,在單位時間內(nèi)貪吃蛇移動一單位長度和貪吃蛇移動多單位長度。 基本介紹 一款移動端貪吃蛇大作戰(zhàn)游戲。(只支持移動端) 這是一個臨近 deadline 的課設(shè)項目,為了方便地使用TS,我直接使用angular-cli生成了TypeScript的項...

    AlphaWallet 評論0 收藏0
  • 裝逼的最高境界---一行js代碼完成一個簡易版的貪吃游戲

    摘要:有些奇淫技巧玩好的話,就能提升自己的逼格,這不,一行代碼實現(xiàn)一個貪吃蛇小游戲就成了裝逼到了最高境界嘛代碼如下當前瀏覽器不支持標簽游戲結(jié)束我不是來裝逼的。 有些奇淫技巧玩好的話,就能提升自己的逼格,這不,一行js代碼實現(xiàn)一個貪吃蛇小游戲就成了裝逼到了最高境界嘛!代碼如下: (function(){var s = [41,40],d = 1,f = 43,x,c = document.cr...

    hidogs 評論0 收藏0
  • 裝逼的最高境界---一行js代碼完成一個簡易版的貪吃游戲

    摘要:有些奇淫技巧玩好的話,就能提升自己的逼格,這不,一行代碼實現(xiàn)一個貪吃蛇小游戲就成了裝逼到了最高境界嘛代碼如下當前瀏覽器不支持標簽游戲結(jié)束我不是來裝逼的。 有些奇淫技巧玩好的話,就能提升自己的逼格,這不,一行js代碼實現(xiàn)一個貪吃蛇小游戲就成了裝逼到了最高境界嘛!代碼如下: (function(){var s = [41,40],d = 1,f = 43,x,c = document.cr...

    vincent_xyb 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<