色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

javascript - 如何為大量的sprite添加碰撞檢測(cè)框?

瀏覽:77日期:2022-12-02 08:58:50

問(wèn)題描述

我有一張精靈表,里面的每幀都有不同的尺寸,如下圖:javascript - 如何為大量的sprite添加碰撞檢測(cè)框?

現(xiàn)在我想為它們添加碰撞檢測(cè)框,但圖片較多,而且碰撞的位置不限于圖片邊框,請(qǐng)問(wèn)這種情況如何添加檢測(cè)框,是否需要給每幀按需求添加?添加完成后又如何獲取碰撞框的位置?有沒(méi)有工具可以實(shí)現(xiàn)?非常感謝~

問(wèn)題解答

回答1:

基本上游戲開發(fā)最難的部分之一就是碰撞檢測(cè)了,你如何選擇碰撞檢測(cè)請(qǐng)務(wù)必根據(jù)你項(xiàng)目的需求來(lái)決定,一般對(duì)于多邊形用得比較多的是分離軸定理(SAT),像你這種如果要求不是特別高的話用正常等大的矩形檢測(cè)就好了,如果非要變化的話就為每個(gè)狀態(tài)保存一個(gè)碰撞檢測(cè)框用于碰撞檢測(cè),比如說(shuō):

var monster = { steps : {'walk' : { 'width' : '', //碰撞檢測(cè)時(shí)用于計(jì)算的寬度 'height' : '', //高度 'imgs' : [] //精靈,可能'walk'這個(gè)動(dòng)作中包含了多幀,進(jìn)行游戲循環(huán)的時(shí)候需要逐步變化 'idx' : 0 //用于判斷imgs當(dāng)前到哪個(gè)步驟的下標(biāo)索引},'jump' : { //同樣的},'run' : { //等等}//........ }, //保存不同狀態(tài)下的顯示效果和碰撞邊框 'currentStatus' : 'walk', //當(dāng)前的狀態(tài),方便相關(guān)功能的載入 'setup' : function(){this.x += '';this.y += ’’;//用于計(jì)算和更新位置 }, 'draw' : function(){//用于繪制 } //......};//碰撞檢測(cè)一般都在游戲循環(huán)里單獨(dú)調(diào)用一個(gè)方法,通過(guò)循環(huán)獲取活動(dòng)對(duì)象的x,y,width,height來(lái)進(jìn)行檢測(cè),這里你可以通過(guò)判斷一個(gè)矩形是否存在一個(gè)頂點(diǎn)在另一個(gè)矩形內(nèi)部來(lái)得知是否碰撞,當(dāng)然用sat也是可以的,不過(guò)麻煩了點(diǎn)

當(dāng)然我這里僅僅給你參考意見,我不是主攻游戲開發(fā),以前有興趣的時(shí)候自學(xué)過(guò)一段時(shí)間,如果有什么地方有問(wèn)題歡迎指出來(lái),就這樣吧。

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 一级一片一_级一片一 | 欧美一级毛片欧美一级成人毛片 | 欧美一级高清片 | 久久不见久久见免费影院 | 美女毛片大全 | a男人的天堂久久a毛片 | 亚洲美女视频一区二区三区 | 日韩一区国产二区欧美三区 | 国产日韩久久久久69影院 | 国产一区二三区 | 一级毛片区 | 中文字幕乱| 看一级特黄a大片国产 | 午夜日本一区二区三区 | 亚州久久| 国产一区二区三区免费 | 中文字幕欧美在线观看 | 亚洲欧美另类色妞网站 | 久久99亚洲精品久久99 | 一级片免| 欧美一级精品高清在线观看 | 中文字幕精品一区二区三区视频 | 日本aaa成人毛片 | 香蕉福利久久福利久久香蕉 | 国产91丝袜美腿在线观看 | 99热99操99射| 免费观看一级欧美大 | 99视频免费在线 | 国产激情自拍 | 2345成人高清毛片 | 欧美亚洲综合另类在线观看 | 国产午夜亚洲精品第一区 | 国产一区二区亚洲精品天堂 | 国产精品自在线 | 久久亚洲国产成人影院 | 182福利视频 | 国产做国产爱免费视频 | 91男女视频 | 成人男女网18免费看 | 成人公开免费视频 | 手机看片日韩国产 |