在安卓设备上播放已下载的GIF图片

20

我在我的应用程序中从服务器下载GIF图像,然后使用ImageView显示它,但它没有动画效果。是否有其他方法可以播放已下载的动画GIF图像。提前致谢。


我正在寻找一个问题:在Android应用程序中播放GIF - Roy Doron
3个回答

10

我正在使用下面的自定义视图而不是图片视图。

public class SampleView extends View {

    private Movie mMovie;
    private long mMovieStart;

    public SampleView(Context context) {
        super(context);
        setFocusable(true);

        java.io.InputStream is;
        is = context.getResources().openRawResource(R.drawable.girl_dances);
        mMovie = Movie.decodeStream(is); 
    }

    public SampleView(Context context, AttributeSet attrSet) {
        super(context, attrSet);
        setFocusable(true);

        java.io.InputStream is;
        is = context.getResources().openRawResource(R.drawable.girl_dances);
        mMovie = Movie.decodeStream(is);
    }

    public SampleView(Context context, AttributeSet attrSet, int defStyle) {
        super(context, attrSet, defStyle);
        setFocusable(true);

        java.io.InputStream is;
        is = context.getResources().openRawResource(R.drawable.girl_dances);
        mMovie = Movie.decodeStream(is);
    }

    @Override
    protected void onDraw(Canvas canvas) {
        canvas.drawColor(0x00000000);

        Paint p = new Paint();
        p.setAntiAlias(true);

        long now = android.os.SystemClock.uptimeMillis();
        if (mMovieStart == 0) { // first time
            mMovieStart = now;
        }
        if (mMovie != null) {
            int dur = mMovie.duration();
            if (dur == 0) {
                dur = 1000;
            }
            int relTime = (int) ((now - mMovieStart) % dur);
            mMovie.setTime(relTime);
            mMovie.draw(canvas, getWidth() / 2 - mMovie.width() / 2,
                    getHeight() / 2 - mMovie.height() / 2);
            invalidate();
        }
    }
    }

XML布局:

<com.test.sample.SampleView
android:id="@+id/gif_view"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />

4
无法传递 gif 资源,会显示 "Expected resource of type. raw..."。我使用 Android Studio 和 Android API16。 - Ispas Claudiu

2

经过一些研究,似乎最好(或最简单)的解决方案是使用 WebView:

例如:

将 myAnimatedGif.gif 文件放入 assets 文件夹中。

创建一个 XML WebView:

<WebView
    android:id="@+id/myWebView"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"/>

然后将gif文件加载到Web视图中:
    WebView view = (WebView) findViewById(R.id.myWebView);
    view.loadUrl("file:///android_asset/myAnimatedGif.gif");

享受吧!

另一种解决方案是使用这种类型的库: https://github.com/koral--/android-gif-drawable


1
这个可以运行!但是你必须把你的myAnimatedGif.gif放在app/src/main/assets中。 - Chinibin

0
你可以通过 WebView 实现这个功能。 以下是我使用的代码:

一个自定义的 LinearLayout,用于锚定 WebView 类

import android.view.View;
import android.webkit.WebView;
import android.widget.LinearLayout;
import android.widget.TextView;

public class Spinner extends LinearLayout{

    public Spinner(Context context) {
        super(context);
        // TODO Auto-generated constructor stub
        View.inflate(context, R.layout.spiner, this);
        WebView web = (WebView) findViewById(R.id.web);
        web.loadUrl("file:///android_asset/booting.gif");
    }
    public void setText(String text){
        TextView t = (TextView) findViewById(R.id.txtloading);
        t.setText(text);
    }
    public void refresh(){
        WebView web = (WebView) findViewById(R.id.web);
        web.loadUrl("file:///android_asset/booting.gif");       
    }
}

R.layout.Spinner XML文件:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="horizontal"
    android:gravity="center|center_vertical"
    android:padding="10dp">
    <WebView android:id="@+id/web" 
        android:layout_width="24dp"
        android:layout_height="12dp"
        />

    <TextView
        android:id="@+id/txtloading"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Loading..."
        />

</LinearLayout>

你可以使用如下代码:

Spinner spinner = new Spinner(this);
myContainer.addView(spinner);

您可以调用Spinner上的refresh方法来确保图像播放:
spinner.refresh();

希望这有所帮助。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接