国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > HTML > 正文

教你如何一步一步用Canvas寫一個貪吃蛇

2024-08-26 00:21:07
字體:
來源:轉載
供稿:網友

之前在慕課網看了幾集Canvas的視頻,一直想著寫點東西練練手。感覺貪吃蛇算是比較簡單的了,當年大學的時候還寫過C語言字符版的,沒想到還是遇到了很多問題。

最終效果如下(圖太大的話 時間太長 錄制gif的軟件有時限…)

Canvas,貪吃蛇

首先定義游戲區域。貪吃蛇的屏幕上只有蛇身和蘋果兩種元素,而這兩個都可以用正方形格子構成。正方形之間添加縫隙。為什么要添加縫隙?你可以想象當你成功填滿所有格子的時候,如果沒有縫隙,就是一個實心的大正方形……你根本不知道蛇身什么樣。

畫了一個圖。

Canvas,貪吃蛇

格子是左上角的坐標是(0, 0),向右是橫坐標增加,向下是縱坐標增加。這個方向和Canvas相同。

每次畫一個格子的時候,要從左上角開始,我們直知道Canvas的左上角坐標是(0, 0),假設格子的邊長是 GRID_WIDTH 縫隙的寬度是  GAP_WIDTH ,可以得到第(i, j)個格子的左上角坐標  (i*(GRID_WIDTH+GAP_WIDTH)+GAP_WIDTH, j*(GRID_WIDTH+GAP_WIDTH)+GAP_WIDTH) 。

假設現在蛇身是由三個藍色的格子組成的,我們不能只繪制三個格子,兩個紫色的空隙也一定要繪制,否則,還是之前說的,你根本不知道蛇身什么樣。如下圖,不畫縫隙雖然也能玩,但是體驗肯定不一樣。

Canvas,貪吃蛇 繪制相鄰格子之間間隙 Canvas,貪吃蛇 不繪制間隙

現在我們可以嘗試著畫一條蛇了。蛇身其實就是一個格子的集合,每個格子用包含兩個位置信息的數組表示,整條蛇可以用二維數組表示。

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <title>blog_snack</title>    <style>        #canvas {             background-color: #000;        }    </style></head><body>    <canvas id="canvas"></canvas>    <script>        const GRID_WIDTH = 10;  // 格子的邊長        const GAP_WIDTH = 2;    // 空隙的邊長        const ROW = 10;         // 一共有多少行格子&每行有多少個格子        let canvas = document.getElementById('canvas');        canvas.height = GRID_WIDTH * ROW + GAP_WIDTH * (ROW + 1);        canvas.width = GRID_WIDTH * ROW + GAP_WIDTH * (ROW + 1);        let ctx = canvas.getContext('2d');        let snack = [ [2, 3], [2, 4], [2, 5], [3, 5], [4, 5], [4, 4], [5, 4], [5, 5] ]; // 初始化一條
注:相關教程知識閱讀請移步到HTML教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 蓬安县| 房产| 洪湖市| 黑龙江省| 昭苏县| 互助| 望谟县| 白山市| 平潭县| 清镇市| 土默特左旗| 洪泽县| 屏山县| 昌乐县| 商都县| 外汇| 新野县| 洛浦县| 泾川县| 红原县| 团风县| 宁南县| 乌兰察布市| 大同市| 红原县| 兴安盟| 临海市| 荔浦县| 宁都县| 吉安市| 武陟县| 景宁| 宁德市| 涟水县| 牙克石市| 奉化市| 陆河县| 托克逊县| 星子县| 缙云县| 女性|