javascript - 如何為大量的sprite添加碰撞檢測框?
問題描述
我有一張精靈表,里面的每幀都有不同的尺寸,如下圖:
現(xiàn)在我想為它們添加碰撞檢測框,但圖片較多,而且碰撞的位置不限于圖片邊框,請問這種情況如何添加檢測框,是否需要給每幀按需求添加?添加完成后又如何獲取碰撞框的位置?有沒有工具可以實(shí)現(xiàn)?非常感謝~
問題解答
回答1:基本上游戲開發(fā)最難的部分之一就是碰撞檢測了,你如何選擇碰撞檢測請務(wù)必根據(jù)你項目的需求來決定,一般對于多邊形用得比較多的是分離軸定理(SAT),像你這種如果要求不是特別高的話用正常等大的矩形檢測就好了,如果非要變化的話就為每個狀態(tài)保存一個碰撞檢測框用于碰撞檢測,比如說:
var monster = { steps : {'walk' : { 'width' : '', //碰撞檢測時用于計算的寬度 'height' : '', //高度 'imgs' : [] //精靈,可能'walk'這個動作中包含了多幀,進(jìn)行游戲循環(huán)的時候需要逐步變化 'idx' : 0 //用于判斷imgs當(dāng)前到哪個步驟的下標(biāo)索引},'jump' : { //同樣的},'run' : { //等等}//........ }, //保存不同狀態(tài)下的顯示效果和碰撞邊框 'currentStatus' : 'walk', //當(dāng)前的狀態(tài),方便相關(guān)功能的載入 'setup' : function(){this.x += '';this.y += ’’;//用于計算和更新位置 }, 'draw' : function(){//用于繪制 } //......};//碰撞檢測一般都在游戲循環(huán)里單獨(dú)調(diào)用一個方法,通過循環(huán)獲取活動對象的x,y,width,height來進(jìn)行檢測,這里你可以通過判斷一個矩形是否存在一個頂點(diǎn)在另一個矩形內(nèi)部來得知是否碰撞,當(dāng)然用sat也是可以的,不過麻煩了點(diǎn)
當(dāng)然我這里僅僅給你參考意見,我不是主攻游戲開發(fā),以前有興趣的時候自學(xué)過一段時間,如果有什么地方有問題歡迎指出來,就這樣吧。
相關(guān)文章:
1. 大家都用什么工具管理mysql數(shù)據(jù)庫?2. java - jdbc如何返回自動定義的bean3. javascript - 按鈕鏈接到另一個網(wǎng)址 怎么通過百度統(tǒng)計計算按鈕的點(diǎn)擊數(shù)量4. 請教一個mysql去重取最新記錄5. 怎么php怎么通過數(shù)組顯示sql查詢結(jié)果呢,查詢結(jié)果有多條,如圖。6. python - 為什么match匹配出來的結(jié)果是<_sre.SRE_Match object; span=(0, 54), match=’’>7. mysql的循環(huán)語句問題8. python - 請問這兩個地方是為什么呢?9. mysql優(yōu)化 - mysql 一張表如果不能確保字段列長度一致,是不是就不需要用到char。10. mysql updtae追加數(shù)據(jù)sql語句
