Unity3d 的序列幀動(dòng)畫

最近項(xiàng)目中用到了很多序列幀動(dòng)畫紊馏,之前看教程也接觸過序列幀動(dòng)畫硬贯,但當(dāng)時(shí)沒用到,就沒仔細(xì)研究掸驱,這次就借著這個(gè)機(jī)會(huì)好好總結(jié)一下序列幀動(dòng)畫窘哈。

思路

序列幀動(dòng)畫的原理很好理解,首先必須要有一個(gè)載體亭敢,一般是一個(gè)圖片滚婉,然后申請(qǐng)一個(gè)數(shù)組或List<sprite>用來存放序列幀,然后再根據(jù)需要遍歷這個(gè)數(shù)組替換載體的圖片源帅刀,這樣就實(shí)現(xiàn)動(dòng)畫效果了让腹。

代碼


public class Anim : MonoBehaviour {

    public float animSpeed = 10;  //動(dòng)畫播放速度 默認(rèn)1秒播放10幀圖片
    private float animTimeInterval = 0;  //幀與幀間隔的時(shí)間
   
    public SpriteRenderer animRenderer;//動(dòng)畫載體的渲染器
   
    public Sprite[] SpriteArray; //序列幀數(shù)組
    private int frameIndex = 0;  //幀索引
    private int animLength = 0;  //多少幀
    private float animTimer = 0; //動(dòng)畫時(shí)間計(jì)時(shí)器

   // Use this for initialization
    void Start () {
        animTimeInterval = 1 / animSpeed;//得到每一幀的時(shí)間間隔
        animLength = SpriteArray.Length; //得到幀數(shù)
       
    }

    // Update is called once per frame
    void Update()
    {
        animTimer += Time.deltaTime;
        if (animTimer > animTimeInterval)
        {
            animTimer -= animTimeInterval;//當(dāng)計(jì)時(shí)器減去一個(gè)周期的時(shí)間
            frameIndex++;//當(dāng)幀數(shù)自增(播放下一幀)
            frameIndex %= animLength;//判斷是否到達(dá)最大幀數(shù),到了就從新開始  這里是循環(huán)播放的
            animRenderer.sprite = SpriteArray[frameIndex]; //替換圖片實(shí)現(xiàn)動(dòng)畫
        }      

    }
}

其他形式

基于上面的代碼還可以添加一些其他動(dòng)畫的功能扣溺,比如暫停/停止(添加bool變量骇窍,Pause方法內(nèi)判斷是否暫停)快進(jìn)慢進(jìn)(方法內(nèi)調(diào)節(jié)每秒播放的幀數(shù))主要通過對(duì)這個(gè)類變量的控制來實(shí)現(xiàn)的,NGUI里有SpriteAnimation锥余,UI SpriteAnimation等內(nèi)置的序列幀動(dòng)畫腳本腹纳,里面的序列幀動(dòng)畫的功能比較全,有感興趣的可以去看下NGUI的源碼驱犹。
除了spriterenderer嘲恍,texturerenderer和ui sprite也可以實(shí)現(xiàn)序列幀動(dòng)畫,效果差不多

一些思考

在最近項(xiàng)目中遇到的序列幀動(dòng)畫是全屏的雄驹,圖片都很大佃牛,第一次加載時(shí)非常卡医舆,這個(gè)問題后來通過兩個(gè)途徑解決的俘侠,在這里說一下

  • 在可以接受的情況下降低畫質(zhì)

1.png

如圖,調(diào)節(jié)MaxSize屬性能控制畫質(zhì)蔬将,縮小圖片的大小

  • 分割序列幀數(shù)組

因?yàn)樾蛄袔诓シ徘靶枰燃虞d進(jìn)數(shù)組里面爷速,圖片多了內(nèi)存占用過大就很卡,因此可以優(yōu)化資源加載算法實(shí)現(xiàn)分階段加載視頻霞怀,具體代碼就不寫了惫东,這里我說一下思路:有500幀圖片,不要一次加載完里烦,100幀100幀的加載凿蒜,第一個(gè)100幀播放到50幀的時(shí)候開始加載第二個(gè)100幀,以此類推胁黑,這樣就分散了對(duì)系統(tǒng)資源的占用废封,響應(yīng)的會(huì)流暢一些。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末丧蘸,一起剝皮案震驚了整個(gè)濱河市漂洋,隨后出現(xiàn)的幾起案子遥皂,更是在濱河造成了極大的恐慌,老刑警劉巖刽漂,帶你破解...
    沈念sama閱讀 218,607評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件演训,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡贝咙,警方通過查閱死者的電腦和手機(jī)样悟,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,239評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來庭猩,“玉大人窟她,你說我怎么就攤上這事“” “怎么了震糖?”我有些...
    開封第一講書人閱讀 164,960評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)趴腋。 經(jīng)常有香客問我吊说,道長(zhǎng),這世上最難降的妖魔是什么优炬? 我笑而不...
    開封第一講書人閱讀 58,750評(píng)論 1 294
  • 正文 為了忘掉前任颁井,我火速辦了婚禮,結(jié)果婚禮上穿剖,老公的妹妹穿的比我還像新娘蚤蔓。我一直安慰自己,他們只是感情好糊余,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,764評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著单寂,像睡著了一般贬芥。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上宣决,一...
    開封第一講書人閱讀 51,604評(píng)論 1 305
  • 那天蘸劈,我揣著相機(jī)與錄音,去河邊找鬼尊沸。 笑死威沫,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的洼专。 我是一名探鬼主播棒掠,決...
    沈念sama閱讀 40,347評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼屁商!你這毒婦竟也來了烟很?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,253評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎雾袱,沒想到半個(gè)月后恤筛,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,702評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡芹橡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,893評(píng)論 3 336
  • 正文 我和宋清朗相戀三年毒坛,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片林说。...
    茶點(diǎn)故事閱讀 40,015評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡煎殷,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出述么,到底是詐尸還是另有隱情蝌数,我是刑警寧澤,帶...
    沈念sama閱讀 35,734評(píng)論 5 346
  • 正文 年R本政府宣布度秘,位于F島的核電站顶伞,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏剑梳。R本人自食惡果不足惜唆貌,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,352評(píng)論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望垢乙。 院中可真熱鬧锨咙,春花似錦、人聲如沸追逮。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,934評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽钮孵。三九已至骂倘,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間巴席,已是汗流浹背历涝。 一陣腳步聲響...
    開封第一講書人閱讀 33,052評(píng)論 1 270
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留漾唉,地道東北人荧库。 一個(gè)月前我還...
    沈念sama閱讀 48,216評(píng)論 3 371
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像赵刑,于是被迫代替她去往敵國(guó)和親分衫。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,969評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫(kù)料睛、插件丐箩、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,105評(píng)論 4 62
  • 該學(xué)的事不能錯(cuò)過摇邦,該走的路不得不走
    糖遇杜盎司蜜閱讀 153評(píng)論 0 0
  • 王一些閱讀 146評(píng)論 0 1
  • 任時(shí)光匆匆,歲月如梭屎勘,青春不在施籍,容顏已老。 曾經(jīng)朦朧的我們概漱,再也回不到過去丑慎,那份童真的心是那么的天真可...
    心歸塵之閱讀 311評(píng)論 0 1