Unity3D中暫停時的動畫及粒子效果實現
暫停是遊戲中經常出現的功能,而Unity3D中對於暫停的處理並不是很理想。一般的做法是將Time.timeScale
設定為0。Unity的文件中對於這種情況有以下描述;
The scale at which the time is passing. This can be used for slow motion effects….When timeScale is set to zero the game is basically paused …
timeScale表示遊戲中時間流逝快慢的尺度。文件中明確表示,這個引數是用來做慢動作效果的。對於將timeScale設定為0的情況,僅只有一個補充說明。在實際使用中,通過設定timeScale來實現慢動作特效,是一種相當簡潔且不帶任何毒副作用的方法,但是當將timeScale設定為0來實現暫停時,由於時間不再流逝,所有和時間有關的功能痘將停止,有些時候這正是我們想要的,因為畢竟是暫停。但是副作用也隨之而來,在暫停時各種動畫和粒子效果都將無法播放(因為是時間相關的),FixedUpdate也將不再被呼叫。
換句話說,最大的影響是,在timeScale=0的暫停情況下,你將無法實現暫停選單的動畫以及各種漂亮的點選效果。
但是並非真的沒辦法,關於timeScale的文件下就有提示:
Except for realtimeSinceStartup, timeScale affects all the time and delta time measuring variables of the Time class.
因為 realtimeSinceStartup
和 timeScale
無關,因此也就成了解決在暫停下的動畫和粒子效果的救命稻草。對於Unity動畫,在每一幀,根據實際時間尋找相應幀並取樣顯示的方法來模擬動畫:
AnimationState _currState = animation[clipName];
bool isPlaying = true;
float _progressTime = 0F;
float _timeAtLastFrame = 0F;
float _timeAtCurrentFrame = 0F;
bool _inReversePlaying = false;
float _deltaTime = 0F;
animation.Play(clipName);
_timeAtLastFrame = Time.realtimeSinceStartup;
while (isPlaying) {
_timeAtCurrentFrame = Time.realtimeSinceStartup;
_deltaTime = _timeAtCurrentFrame - _timeAtLastFrame;
_timeAtLastFrame = _timeAtCurrentFrame;
_progressTime += _deltaTime;
_currState.normalizedTime = _inReversePlaying ? 1.0f - (_progressTime / _currState.length) : _progressTime / _currState.length; animation.Sample(); //…repeat or over by wrap mode }
對於粒子效果,同樣進行計時,並通過粒子系統的Simulate方法來模擬對應時間的粒子狀態來完成效果,比如對於Legacy粒子,使Emitter在timeScale=0
暫停時繼續有效發射並顯示效果:
_deltaTime = Time.realtimeSinceStartup - _timeAtLastFrame;_timeAtLastFrame = Time.realtimeSinceStartup;if (Time.timeScale == 0 ){ _emitter.Simulate(_deltaTime); _emitter.emit = true;}
核心的程式碼基本都在上面了,可以根據這個思路完成實現。完整的程式碼和示例工程我放到了github上,有需要的朋友可以去檢視,也
相關文章
- CSS3實現王者匹配時的粒子動畫效果CSSS3動畫
- Flutter動畫實現粒子漂浮效果Flutter動畫
- CSS 滑鼠懸浮動畫暫停效果CSS動畫
- flutter實現B站播放器暫停時的header效果Flutter播放器Header
- Android自定義View——從零開始實現可暫停的旋轉動畫效果AndroidView動畫
- CSS3中用background-image實現粒子動畫效果CSSS3動畫
- 教你如何用WPF實現文字粒子閃爍動畫效果動畫
- 粒子效果動畫使用總結動畫
- vue+樹莓派實現實時視訊播放暫停Vue樹莓派
- 有趣的CSS題目(14): 純 CSS 方式實現 CSS 動畫的暫停與播放!CSS動畫
- OpenJDK 17中的Shenandoah可實現亞毫秒級GC暫停JDKNaNGC
- 通過video實現視訊暫停時出現圖片IDE
- Canvas 實現炫麗的粒子運動效果(粒子生成文字)Canvas
- css3 動畫的暫停和重新開始CSSS3動畫
- HTML CSS 實現滑鼠懸停時圖片拉近效果HTMLCSS
- React實現動畫效果React動畫
- Javascript實現動畫效果JavaScript動畫
- PPT中如何實現川流不息的動畫效果動畫
- mpvue小程式迴圈動畫開啟暫停Vue動畫
- 微信小程式iOS端如何暫停animated動畫微信小程式iOS動畫
- ManualResetEvent實現執行緒的暫停與恢復執行緒
- 短視訊直播原始碼,視訊計時效果,可隨時按鍵暫停原始碼
- 實現漫天飛雪的動畫效果動畫
- canvas實現具有粒子效果的動態進度條Canvas
- 談談一些有趣的CSS題目(十四)–純CSS方式實現CSS動畫的暫停與播放!CSS動畫
- 用JavaScript實現動畫效果 (轉)JavaScript動畫
- 暫停,掉線,遊戲工作室的現實難題遊戲
- 使用SVG實現的一個Android播放/暫停按鈕SVGAndroid
- SharedHashMap是更低延遲無GC暫停的Map實現HashMapGC
- Fiori裡花瓣的動畫效果實現原理動畫
- activity切換無動畫效果的實現動畫
- 5分鐘用動效工廠實現粒子動畫動畫
- jQuery具有暫停功效果新聞列表向上滾動jQuery
- 動畫合成小技巧!CSS 實現動感的倒數計時效果動畫CSS
- Android中ScrollView實現拖拽反彈效果動畫AndroidView動畫
- 輕鬆搞定動畫!17個有趣實用的CSS 3懸停效果教程動畫CSS
- 實驗,暫停oracle後臺程式Oracle
- OpenGL ES3 0實現簡單粒子火焰效果S3