web-dev-qa-db-fra.com

lire l'image Gif téléchargée dans Android

Je télécharge une image GIF depuis mon serveur sur mon application, puis je la montre avec ImageView mais elle n'était pas animée. Existe-t-il un autre moyen de lire les images animées téléchargées - Image GIF . Merci d'avance .

16
neeraj

J'utilise la vue personnalisée ci-dessous au lieu de la vue Image.

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 ​​Layout:

<com.test.sample.SampleView
Android:id="@+id/gif_view"
Android:layout_width="wrap_content"
Android:layout_height="wrap_content" />
10
Om Narain Shukla

Après quelques recherches, il semble que la meilleure solution (ou la plus simple) consiste à utiliser une WebView: 

ex: 

placez le fichier myAnimatedGif.gif dans le dossier assets. 

créer une vue web xml: 

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

puis chargez le fichier gif dans la vue Web: 

    WebView view = (WebView) findViewById(R.id.myWebView);
    view.loadUrl("file:///Android_asset/myAnimatedGif.gif");

Prendre plaisir !

Une autre solution consiste à utiliser ce type de bibliothèque: https://github.com/koral--/Android-gif-drawable

1
Tobliug

Vous pouvez y parvenir avec une WebView. Voici ce que j'utilise:

Un LinearLayout personnalisé qui ancre une classe 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");       
    }
}

Le fichier XML R.layout.Spinner:

<?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>

Vous pouvez utiliser comme

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

Vous pouvez appeler refresh sur spinner pour garantir la lecture de l'image:

spinner.refresh();

J'espère que cela pourra aider.

0
Oluwatumbi