av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

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

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

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

問題描述

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

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

問題解答

回答1:

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

var monster = { steps : {'walk' : { 'width' : '', //碰撞檢測時(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(){//用于繪制 } //......};//碰撞檢測一般都在游戲循環(huán)里單獨(dú)調(diào)用一個(gè)方法,通過循環(huán)獲取活動(dòng)對象的x,y,width,height來進(jìn)行檢測,這里你可以通過判斷一個(gè)矩形是否存在一個(gè)頂點(diǎn)在另一個(gè)矩形內(nèi)部來得知是否碰撞,當(dāng)然用sat也是可以的,不過麻煩了點(diǎn)

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

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 欧美成人一区二区三区片免费 | 日韩视频精品 | 色综合一区二区 | 三级免费| 精品9999| 涩爱av一区二区三区 | 中文字幕精品视频在线观看 | www.久久 | 玖玖在线精品 | 欧美黄色小视频 | 欧美日韩综合精品 | 中文字幕日韩欧美一区二区三区 | 欧美日韩综合 | 亚洲欧美一区二区三区1000 | 日韩中文字幕在线观看 | 日本成人在线网址 | 啪一啪 | 日韩精品一区二区三区视频播放 | 国产精品美女久久久久久免费 | 台湾av在线 | 尤物视频在线免费观看 | 99久久精品免费看国产四区 | 久久精品小短片 | 午夜av免费 | 91麻豆精品一区二区三区 | 九色av| 成人免费观看视频 | 国产精品亚洲综合 | 国产乱码精品一品二品 | 九色91视频 | 亚洲午夜av久久乱码 | 91久久精品国产91久久 | 亚洲国产福利视频 | 天天操天天干天天爽 | 亚洲成人免费视频在线 | 丝袜 亚洲 另类 欧美 综合 | 欧美精品一二区 | 久久人人网 | 亚洲欧美日本在线 | 久久躁日日躁aaaaxxxx | 中文字幕国产一区 |