婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 快速實現一個簡單的canvas迷宮游戲的示例

快速實現一個簡單的canvas迷宮游戲的示例

熱門標簽:電銷機器人電話用什么卡 當涂高德地圖標注 黃島區地圖標注 南寧點撥外呼系統哪家公司做的好 四川點撥外呼系統 成都智能外呼系統平臺 江蘇智能電銷機器人哪家好 云南大理400電話申請官方 鎮江智能外呼系統有效果嗎

前言

(最近設計模式看的有點頭大,一直面對純js實在是有些枯燥-_-。所以寫一點有趣的東西調劑一下)
現在canvas已經不算新鮮了,不過由于日常業務中并不常用,所以實踐并不多,今天分享一下,如何實現簡單canvas迷宮。這個例子來源于《html5秘籍》第二版,代碼有稍微做了點調整。

由于中間有一步使用canvas獲取圖片信息的時候,必須使用服務器環境。所以我先寫了一個樣例扔在服務器上,大家可以先體驗一下效果(用成就感作為驅動力哈哈哈)

點我體驗

git地址

正文

實現這個小游戲也不難,讓我們想想,一個迷宮游戲有哪些基本要素。

首先當然得有個地圖,然后得有個移動的小人,這兩個我們利用cavans來繪制;

接下來是物體移動的程序,這個程序主要包括2個方面:

1.讓物體跟我們指定的指令來移動;
2.檢測物體是否碰到墻體或者出口。

繪制迷宮的地圖和移動的小人
繪制地圖的主要步驟是:

  1. 獲取一張地圖的圖片
  2. 利用cavans繪制圖像。

迷宮地圖的生成,可以借助谷歌的一個迷宮在線生成器來獲得。

繪制小人也是一樣直接找一個小人的圖片即可,不過這里要注意的是,要找正方形的圖片,因為一會我們需要做移動的碰撞檢測,方形比較好判斷。

接下來就要寫繪制迷宮和小人的主要函數

function drawMaze(mazeFile, startingX, startingY) {
  var imgMaze = new Image()
  imgMaze.onload = function () {
    // 畫布大小調整
    canvas.width = imgMaze.width
    canvas.height = imgMaze.height

    // 繪制笑臉
    var imgFace = document.getElementById("face")
    context.drawImage(imgMaze, 0, 0)

    x = startingX
    y = startingY
    context.drawImage(imgFace, x, y)
    context.stroke()
  }
  imgMaze.src = mazeFile
}

mazeFile是迷宮的圖片地址,startingX和startingY,是起始點的坐標。在這里圖片引入的方式用了2種,原因是小人的圖片我不經常更換,就直接寫在頁面里,迷宮的地圖打算做成可變的,所以在js里引入,你想把圖片都直接用js引入也沒有問題。其他部分比較簡單,不再贅述。

移動函數

移動的主要原理是:

接受指定的用戶輸入(在這里是響應方向鍵),轉換成對應的移動指令。然后周期性的檢查移動指令,繪制對應的目標位置。舉個簡單的例子:

比如每按下一次方向鍵上,就記錄下應該往上移動,然后每隔100毫秒檢查當前的移動指令,繪制應該移動的目標地點,重復這個過程。代碼也比較簡單:

// 移動函數
function processKey(e) {
  dx = 0
  dy = 0
  // 上下左右方向鍵檢測
  if (e.keyCode === 38) {
    dy = -1
  }
  if (e.keyCode === 40) {
    dy = 1
  }
  if (e.keyCode === 37) {
    dx = -1
  }
  if (e.keyCode === 39) {
    dx = 1
  }
}

// 繪制幀
function drawFrame() {
  if (dx != 0 || dy != 0) {
    // context.clearRect(x,y,canvas.width,canvas.height)
    // 繪制移動軌跡
    context.beginPath();
    context.fillStyle = "rgb(254,244,207)"
    context.rect(x, y, 15, 15)
    context.fill()
    x += dx
    y += dy
    // 碰撞檢測
    if (checkForCollision()) {
      x -= dx
      y -= dy
      dx = 0
      dy = 0
    }
    
    //繪制小人應該移動的地點
    var imgFace = document.getElementById('face')
    context.drawImage(imgFace, x, y)

    if (canvas.height - y < 17) {
      // isFirst = false
      alert('恭喜你通關 游戲結束')
      return false
    }
    // 這里如果重置的話變成非自動移動,也就是每按下一次方向鍵只前進一步,由于目前體驗不好所以先不做重置
    // dx = 0
    // dy = 0
  }
  setTimeout(drawFrame, 20)
}

上述代碼中,移動函數比較簡單,繪制幀的函數里面比較重要的就是碰撞檢測函數,在下面詳細解釋。

碰撞檢測

要檢測物體與墻體是否碰撞,通常情況是要先把地圖信息保存到內存里,然后在移動物體時檢測是否與當前的某個墻體碰撞,但是由于我們的地圖背景是黑白迷宮,所以可以使用顏色來檢測碰撞。具體的做法是:

獲取當前物體的坐標位置,利用canvas檢測當前地圖上這個位置的顏色是否為黑色,如果是,說是是墻體,不應該執行移動,下面就是代碼:

function checkForCollision() {
  var imageData = context.getImageData(x - 1, y - 1, 15 + 2, 15 + 2)
  var pixels = imageData.data

  for (var i = 0, len = pixels.length; i < len; i++) {
    var red = pixels[i],
        green = pixels[i + 1]
        blue = pixels[i + 2]
        alpha = pixels[i + 3]

    // 檢測是否碰到黑色的墻
    if (red === 0 && green === 0 && blue === 0) {
      return true
    }
  }
  return false
}

在這里,15是小人的寬度,我們檢測小人兩側各1px范圍(對應代碼中的getImageData(x - 1, y - 1, 15 + 2, 15 + 2)可以稍微思考下這里為什么是+2),如果是黑色,說明檢測到碰撞。

其余

在代碼里,我加了一些其他的功能,比如提示答案等。至于更換地圖也比較簡單:把地圖對應的文件地址,起點坐標,答案圖片路徑等存在一個對象里,然后設置一個地圖數組,點擊的時候切換地圖并重新渲染就可以了。還有一些值得優化的地方,比如:

  1. 碰撞檢測在拐彎的地方體驗不佳;
  2. 當前情況運行時有軌跡,在答案模式下應該如何去掉軌跡?

有興趣的同學可以試著自己實現下。

小結

這個例子相對比較簡單,對js的要求不高,拿來玩一下還是挺不錯的。

然后依然是每次都一樣的結尾,如果內容有錯誤的地方歡迎指出;如果對你有幫助,歡迎點贊和收藏,轉載請征得同意后著明出處,如果有問題也歡迎私信交流,主頁有郵箱地址~溜了

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

標簽:十堰 廣西 淮安 南京 西寧 酒泉 咸寧 佳木斯

巨人網絡通訊聲明:本文標題《快速實現一個簡單的canvas迷宮游戲的示例》,本文關鍵詞  快速,實現,一個,簡單,的,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《快速實現一個簡單的canvas迷宮游戲的示例》相關的同類信息!
  • 本頁收集關于快速實現一個簡單的canvas迷宮游戲的示例的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美日韩日本视频| 亚洲美女免费在线| 成人污污视频在线观看| 国产精品18久久久久久久久久久久 | 亚洲精品一区二区三区影院| 亚洲激情综合网| 青青青伊人色综合久久| 亚洲成av人片观看| 欧美一区二区三区视频免费| 丝袜美腿成人在线| 国产欧美精品一区二区色综合| 国产主播一区二区| 久久9热精品视频| 免费成人在线播放| 中文字幕五月欧美| 亚洲黄色av一区| 国产成a人亚洲精品| 2023国产精品视频| 91精品国产入口在线| 欧美一级电影网站| 91精品国产综合久久精品| 久久先锋影音av鲁色资源| 久久综合久久久久88| 91麻豆精品国产自产在线| 久久国产精品第一页| 麻豆精品一区二区av白丝在线| 综合亚洲深深色噜噜狠狠网站| 久久精品一二三| 精品制服美女久久| 亚洲综合在线第一页| 亚洲精品一区二区三区影院 | 一区二区在线观看免费| 国产欧美一区二区三区沐欲| 国产精品不卡一区二区三区| 国产精品亲子伦对白| 久久伊人蜜桃av一区二区| 日韩美女在线视频| 成人app在线| 蜜臀a∨国产成人精品| 激情成人午夜视频| 国产激情一区二区三区四区| 成人午夜在线播放| 精品99一区二区| 国产精品色在线| 五月天一区二区三区| 久久99精品一区二区三区| 国产成人av网站| 成人黄色在线看| proumb性欧美在线观看| 午夜视频在线观看一区| 性做久久久久久免费观看| 午夜精品久久一牛影视| 国产自产v一区二区三区c| 色综合久久中文综合久久97| 欧美高清精品3d| 国产乱码精品1区2区3区| 成人免费av网站| 欧美电影一区二区| 国产农村妇女毛片精品久久麻豆| 亚洲影视在线观看| 九色|91porny| 在线亚洲精品福利网址导航| 日韩精品在线看片z| 亚洲精品中文在线影院| 免费精品99久久国产综合精品| 国产mv日韩mv欧美| 国产成人精品亚洲午夜麻豆| 欧美色偷偷大香| 国产亚洲欧美在线| 韩国v欧美v亚洲v日本v| 欧美午夜影院一区| 久久国产日韩欧美精品| 91国产精品成人| 日韩免费看网站| 亚洲成人免费影院| 国产成人免费xxxxxxxx| 日韩一区二区在线看| 日本乱人伦一区| 亚洲一二三四在线| 精品成人a区在线观看| 国产无一区二区| 亚洲图片激情小说| 成人中文字幕合集| 国产精品视频线看| 国产成人免费在线观看不卡| 日韩亚洲欧美高清| 青青国产91久久久久久| 91亚洲永久精品| 日韩欧美电影一区| 图片区小说区区亚洲影院| 丁香婷婷综合色啪| 日韩午夜电影在线观看| 日韩**一区毛片| 欧美一区二区三区思思人| 日韩影视精彩在线| 91精品国产欧美一区二区18| 日韩高清一级片| 欧美精品日韩一区| 免费欧美日韩国产三级电影| 欧美三级电影网站| 日本aⅴ亚洲精品中文乱码| 蜜臀av性久久久久蜜臀aⅴ| 欧美三级电影网| 日本不卡一二三| xnxx国产精品| 国产成人午夜视频| 亚洲欧美日本在线| 欧美蜜桃一区二区三区| 91在线观看高清| 日韩毛片在线免费观看| 懂色av中文字幕一区二区三区| 亚洲国产精品激情在线观看| 91在线porny国产在线看| 一区二区三区中文字幕在线观看| 欧美色视频在线观看| 蜜桃免费网站一区二区三区| 久久久久久久久免费| 91影院在线观看| 亚洲一区在线视频| 日韩精品一区二| 成人午夜激情影院| 国产精品另类一区| 欧美性猛交xxxx乱大交退制版| 亚洲视频你懂的| 日韩欧美国产精品一区| 国产一区999| 亚洲人123区| 欧美成人综合网站| 99国产精品国产精品毛片| 视频一区在线视频| 国产日韩欧美电影| 欧美三级电影在线看| 国产精品资源在线| 夜夜嗨av一区二区三区网页 | 一区二区三区在线高清| 91国在线观看| 国产精品18久久久久久久久久久久 | 99免费精品视频| 日韩avvvv在线播放| 久久先锋资源网| 欧美一区二区三区在线观看视频| 粉嫩av一区二区三区粉嫩| 亚洲国产视频直播| 国产日韩欧美一区二区三区综合| 91精品在线麻豆| av中文字幕在线不卡| 经典三级视频一区| 欧美一卡二卡在线观看| 岛国一区二区在线观看| 美女一区二区视频| 一区二区三区四区av| 国产欧美日韩麻豆91| 日韩午夜电影在线观看| 欧美视频中文一区二区三区在线观看| 国产成人在线影院| 久久精品国产亚洲aⅴ| 日日摸夜夜添夜夜添精品视频| 亚洲欧美国产高清| 欧美tickling挠脚心丨vk| 欧美日韩一区二区三区四区五区| 国产成人一区在线| 国产精品网友自拍| 欧美成人精品二区三区99精品| 亚洲精品一区二区三区精华液| 日韩午夜在线影院| 91麻豆123| 久久精品国产一区二区三| 三级欧美韩日大片在线看| 亚洲狠狠爱一区二区三区| 一区二区视频在线看| 一区二区欧美视频| 亚洲国产精品久久久久婷婷884 | 一区二区三区在线视频播放| 久久久久国色av免费看影院| 欧美大片拔萝卜| 日韩欧美国产系列| 精品国产区一区| 精品成人在线观看| 亚洲日本一区二区三区| 一级日本不卡的影视| 视频精品一区二区| 美女视频网站黄色亚洲| 狠狠色丁香婷婷综合| 国产精品一二三在| 不卡av电影在线播放| 国产盗摄女厕一区二区三区| 粉嫩久久99精品久久久久久夜| 97se亚洲国产综合自在线不卡| 91精品福利视频| 欧美一区二区黄色| 国产亚洲一区二区三区在线观看| 日本一区二区三区高清不卡| 亚洲天堂a在线| 七七婷婷婷婷精品国产| 免费观看91视频大全| 国产sm精品调教视频网站| 色综合激情五月| 91精品国产麻豆国产自产在线 | 美国欧美日韩国产在线播放| 麻豆精品久久精品色综合|