看板 GameDesign 關於我們 聯絡資訊
大家好 小弟正在使用Unity上進行2D動作遊戲開發 目前在角色的移動 跳躍之類的動作 都是透過計算速度並在update的時候更新 可是許多技能都帶有位移的效果 這些位移通常與物理系統並不相關 而且位置的變化需要與動畫保持一致 想請問這類型的移動是透過什麼方式去處理? 舉個例子: 像是昇龍拳 在使用的時候角色會向右上方 沿著類似指數函數的路徑移動 在這段時間所有移動都是固定的 並且與物理無關 技能結束後的下墜才會回到物理系統計算 -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 140.113.122.77 ※ 文章網址: https://www.ptt.cc/bbs/GameDesign/M.1542541506.A.B02.html
dklassic: 不確定是不是常用的方法,不過我會用另一個 Game Object11/18 20:53
dklassic: 當作玩家真正的位置,然後角色動畫只是一個跟著玩家位置11/18 20:53
dklassic: 跑的另一個 Game Object11/18 20:53
不太能理解你的做法是要達到什麼效果... 一般在gameobject上放動畫不就是這樣了嗎? ※ 編輯: RoastSaury (101.8.214.130), 11/18/2018 21:40:21
cjcat2266: 不同狀態下有個負責更新速度和位置的virtual function 11/18 23:34
cjcat2266: (或用switch或其他方法達到等同效果),一般狀態下用速 11/18 23:34
cjcat2266: 度更新位置,特殊狀態可以直接更新位置或對速度做客製 11/18 23:34
cjcat2266: 化更新。另外,除非主打物理模擬且模擬浮動性可接受, 11/18 23:34
cjcat2266: 負責不建議用泛用型物理引擎處理動作遊戲的核心機制, 11/18 23:34
cjcat2266: 建議用客製特化碰撞偵測 11/18 23:34
cjcat2266: 不同狀態中也可以做短時間animation blend,消除不想要 11/18 23:35
cjcat2266: 的視覺不連續性 11/18 23:35
dklassic: 等等,我也不知道我剛剛理解成什麼了 XD 如果是平地結構 11/19 00:23
dklassic: 的話直接把下落動畫也一起做完,如果有著陸高度問題的 11/19 00:23
dklassic: 話你直接寫個加速度公式把人往下移,然後偵測跟地面的碰 11/19 00:23
dklassic: 撞就好了。物理引擎帶來的結果不好預期 11/19 00:23
看來我問題問的不夠好XD 我目前是自己使用物理公式以及客製碰撞 角色基本的移動 跳躍 以及對碰撞處理都OK了 Cj大的做法的話 和我預期的蠻接近的 只是若是要直接更新位置 勢必要紀錄每個時間點角色應該出現的座標 感覺會 很麻煩(吧) 客製速度也考慮過 但感覺位置不太容易受控制 於是才上來詢問有沒有更輕鬆一點的解法 另外 想請問最簡潔地取得當前animation的frame的方式是? 還是真的只能用animator.GetCurrentAnimatorStateInfo(0).normalizedTime? 這東西真的有夠醜的啦 ※ 編輯: RoastSaury (140.113.122.77), 11/19/2018 00:51:37
wix3000: 自己寫一個 extension function啊y11/19 02:50
wix3000: public static float NormalizedTime(this Animator ani)11/19 02:51
這樣也只是包起來而已吧? ※ 編輯: RoastSaury (140.113.122.75), 11/19/2018 04:24:15
cjcat2266: 是包成比較好看的API沒錯啊,除非能更動Unity底層的ani 11/19 07:37
cjcat2266: m資料儲存模式,那就只能靠重新包裝 11/19 07:37
cjcat2266: 另外,勢必要紀錄角色位置的意思是?不論是數學式可以 11/19 07:40
cjcat2266: 表的動態或對anim取樣,最少都只需要開始時間吧 11/19 07:40
cjcat2266: 還有開始位置 11/19 07:45
cjcat2266: 紀錄的意思是說製作客製取樣點函式嗎?那實質上應該可11/19 07:52
cjcat2266: 以用播放特定anim來實作,這個特殊狀態就是一個特定ani11/19 07:52
cjcat2266: m state這樣11/19 07:52
嗯我就是取樣的意思 我想到的另一個問題是 如果是類似這種取樣的方式去位移 移動時與地圖物件的互動可能會很差 (因為移動都寫死了)
cjcat2266: 回頭一下,取frame的方式之所以是那樣,是因為Unity的11/19 08:01
cjcat2266: 動畫系統是使用層式狀態機模型,用層式模型是為了支援a11/19 08:01
cjcat2266: nim blending,為達到圓滑anim的必備模型,而用狀態機11/19 08:01
cjcat2266: 則是泛用anim系統的常見選擇,我認為還算合理啦11/19 08:01
juicefish: tween之類的東西?11/19 08:36
cjcat2266: 推樓上,特殊狀態下也可用tween,如果是客製移動曲線,11/19 08:56
cjcat2266: 也可override個客製tween11/19 08:56
Tween我還真的沒用過 來研究一下好了 ※ 編輯: RoastSaury (140.113.136.220), 11/19/2018 10:33:25
cjcat2266: 會上面的推文回文,取樣其實不代表寫死位移,可以寫成11/19 12:27
cjcat2266: 每次取樣時取相對位移來更新位置,同時對環境做互動11/19 12:27
我的認知是 因為移動不再是透過速度去更新 在遇到障礙物的時候很難透過改變位移量 去表現出「受到阻擋」的狀態 因為已經沒有移動的函數了 ※ 編輯: RoastSaury (101.9.160.213), 11/19/2018 15:03:25
cjcat2266: 應該還是可行。如果障礙是剛體,那可以試試移除障礙接 11/19 15:27
cjcat2266: 觸面法線方向的移動分量,然後依據要保留多少慣性而縮 11/19 15:27
cjcat2266: 放接觸面切面分量,該比例也可以隨時間做圓滑處理,看11/19 15:27
cjcat2266: 起來就不會突兀。如果是軟性障礙,那可以嘗試對位移量11/19 15:27
cjcat2266: 做縮放,加上對碰撞面法線方向稍作偏移,製造出排斥力11/19 15:28
cjcat2266: 的感覺。真要從速度下手,剛體障礙則用上述位移更新方11/19 15:28
cjcat2266: 式去反推,軟體障礙就隨意囉11/19 15:28
cjcat2266: 我有做過類似的效果,我覺得看起來還行。要點是其中會11/19 15:32
cjcat2266: 牽扯到的比例參數,用了本身已是C1圓滑度的數值彈簧做11/19 15:32
cjcat2266: 圓滑處理,就感覺蠻順暢的11/19 15:32
wix3000: 沒有什麼問題是中介層解決不了的,如果有,就再包一層11/19 23:08
聽不太懂XD 先謝謝各位的回答 我目前先嘗試在不同時間點切換初速跟加速度看看 如果有問題再跟各位大大請教 謝謝~ ※ 編輯: RoastSaury (101.13.82.147), 11/20/2018 14:50:03
NCTU87: 推烤魚 11/21 21:54
j60708123: 是烤魚 11/21 21:58
QQron: 寫一個StateMachineBehaviour,用normalizedTimed控制時間 11/26 01:20
QQron: 這樣就很好對應動畫 至於移動方式很多種,不喜歡velocity 11/26 01:22
QQron: 就直接修改animator.transform.position 11/26 01:22