溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Android開(kāi)發(fā)中如何讓Gif動(dòng)畫(huà)動(dòng)起來(lái)

發(fā)布時(shí)間:2021-11-11 16:20:49 來(lái)源:億速云 閱讀:230 作者:柒染 欄目:移動(dòng)開(kāi)發(fā)

Android開(kāi)發(fā)中如何讓Gif動(dòng)畫(huà)動(dòng)起來(lái),針對(duì)這個(gè)問(wèn)題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問(wèn)題的小伙伴找到更簡(jiǎn)單易行的方法。

我們已經(jīng)連續(xù)推出《如何實(shí)現(xiàn)TCP和UDP傳輸》、《Android UI”設(shè)計(jì)官方教程》多個(gè)Android開(kāi)發(fā)教程,本文將為講解Android中Gif圖片播放的教程。Android 中是不支持直接使用Gif 圖片關(guān)聯(lián)播放幀動(dòng)畫(huà),如下動(dòng)畫(huà)在Android 中是無(wú)法播放的:

Android開(kāi)發(fā)中如何讓Gif動(dòng)畫(huà)動(dòng)起來(lái)

Android 提供了另外一種解決的辦法,就是使用AnimationDrawable 這一函數(shù)使其支持逐幀播放,但是如何把gif 圖片打散開(kāi)來(lái),成為每一幀的圖片呢?下面介紹兩種比較不錯(cuò)的軟件,可以幫我們打散圖片。

gifsplitter2.0

下載地址:gif分割

使用方法如下:

Android開(kāi)發(fā)中如何讓Gif動(dòng)畫(huà)動(dòng)起來(lái)

Android開(kāi)發(fā)中如何讓Gif動(dòng)畫(huà)動(dòng)起來(lái)

這一軟件分割圖片都是bmp圖片,圖片比較大,這里不推薦使用,盡量節(jié)省不必要的字節(jié),所以這里推薦使用如下 軟件

easygifanimator

軟件下載:動(dòng)畫(huà)分割器

使用方法如下:

Android開(kāi)發(fā)中如何讓Gif動(dòng)畫(huà)動(dòng)起來(lái)

Android開(kāi)發(fā)中如何讓Gif動(dòng)畫(huà)動(dòng)起來(lái)

點(diǎn)擊文件將幀文件導(dǎo)出即可

得到了幀文件后我們可以就編寫(xiě)代碼,在res目錄下新建anim動(dòng)畫(huà)文件夾,寫(xiě)下如下代碼

<?xml version="1.0" encoding="UTF-8"?> <animation-list android:oneshot="false"     xmlns:android="http://schemas.android.com/apk/res/android">
     <item android:duration="150" android:drawable="@drawable/xiu0" />     <item android:duration="150" android:drawable="@drawable/xiu1" />     <item android:duration="150" android:drawable="@drawable/xiu2" />     <item android:duration="150" android:drawable="@drawable/xiu3" /> </animation-list>

對(duì)應(yīng)的item 為順序的圖片從開(kāi)始到結(jié)束,duration為每張逐幀播放間隔,oneshot 為false 代表循環(huán)播放,設(shè)置為true 即播放一次即停止。

對(duì)應(yīng)Activity 代碼如下編寫(xiě):

import android.app.Activity;  import android.graphics.drawable.AnimationDrawable;  import android.os.Bundle;  import android.view.View;  import android.view.View.OnClickListener;  import android.widget.ImageView;   public class animActivity extends Activity implements OnClickListener {      ImageView iv = null;       /** Called when the activity is first created. */      @Override      public void onCreate(Bundle savedInstanceState) {          super.onCreate(savedInstanceState);          setContentView(R.layout.main);           iv = (ImageView) findViewById(R.id.ImageView01);          iv.setOnClickListener(this);      }       @Override      public void onClick(View v) {          // TODO Auto-generated method stub          AnimationDrawable anim = null;          Object ob = iv.getBackground();          anim = (AnimationDrawable) ob;          anim.stop();          anim.start();      }  }

使用AnimationDrawable 對(duì)象獲得圖片的圖片,然后指定這個(gè)AnimationDrawable 開(kāi)始播放動(dòng)畫(huà)

Tip:使用此方法不會(huì)默認(rèn)播放,必須要有事件觸發(fā)才可播放動(dòng)畫(huà),如上面的通過(guò)點(diǎn)擊監(jiān)聽(tīng)觸發(fā)動(dòng)畫(huà)的播放

那么如何使用圖片自動(dòng)播放呢?我們可以聯(lián)想一下,ProgressBar 是不是默認(rèn)的時(shí)候就會(huì)轉(zhuǎn),那就是那個(gè)圓形的進(jìn)度條,是的。我們可以對(duì)它進(jìn)行改造合它也可以自動(dòng)播放,在Values 文件下新建一個(gè)styles 文件,編寫(xiě)如下代碼 :

<?xml version="1.0" encoding="UTF-8"?> <resources>     <style name="animStyle" parent="@android:style/Widget.ProgressBar.Large">         <item name="android:indeterminateDrawable">@anim/test</item>     </style> </resources>

上面樣式文件自Widget.ProgressBar.Large 為其設(shè)置動(dòng)畫(huà)文件,我們?cè)赬ML中就可以通過(guò)設(shè)置它的樣式使其為我們工作

<ProgressBar android:id="@+id/ProgressBar01" style="@style/animStyle"     android:layout_width="128px" android:layout_height="128px"></ProgressBar>

OK,就是這么簡(jiǎn)單,下面看看運(yùn)行效果:

Android開(kāi)發(fā)中如何讓Gif動(dòng)畫(huà)動(dòng)起來(lái)

關(guān)于Android開(kāi)發(fā)中如何讓Gif動(dòng)畫(huà)動(dòng)起來(lái)問(wèn)題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒(méi)有解開(kāi),可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識(shí)。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI