Fresco使用简单加载gif图片

1.使用哪个依赖就添加哪个

implementation 'com.facebook.fresco:fresco:0.14.1'
    //下面的依赖根据需求,用到哪个模块,就导入对应的依赖即可.
    // 仅支持 WebP 静态图,需要添加
    //implementation 'com.facebook.fresco:webpsupport:0.14.1'
    // 支持 GIF 动图,需要添加
    implementation 'com.facebook.fresco:animated-gif:0.14.1'
    // 支持 WebP 静态图及 WebP 动图,需要添加
    //implementation 'com.facebook.fresco:animated-webp:0.14.1'
    //implementation 'com.facebook.fresco:webpsupport:0.14.1'
    // 在 API < 14 上的机器支持 WebP 时,需要添加
    //implementation 'com.facebook.fresco:animated-base-support:0.14.1'

权限

<uses-permission android:name="android.permission.INTERNET"/>

新建app

public class app extends Application {
    @Override
    public void onCreate() {
        super.onCreate();
        Fresco.initialize(this);
    }
}

别忘了在添加权限里面初始化app 

布局文件把app改成如下

xmlns:fresco="http://schemas.android.com/apk/res-auto"
 <com.facebook.drawee.view.SimpleDraweeView
        android:layout_width="match_parent"
        android:id="@+id/img"
        android:layout_height="match_parent" />
package majunbao.bwie.com.demo_fresco;

import android.net.Uri;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import com.facebook.drawee.backends.pipeline.Fresco;
import com.facebook.drawee.interfaces.DraweeController;
import com.facebook.drawee.view.SimpleDraweeView;

public class MainActivity extends AppCompatActivity {

    private SimpleDraweeView img;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        //加载网络图片的网址
        Uri uri = Uri.parse("https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1535551551658&di=934935e17256ee57ed0416598b78154e&imgtype=0&src=http%3A%2F%2Fs6.sinaimg.cn%2Fmw690%2F0062ywFUgy6Y2pBG8Vn65%26690");
//初始化控件
        img = findViewById(R.id.img);

        DraweeController draweeController =
                Fresco.newDraweeControllerBuilder()
                .setUri(uri)
                .setAutoPlayAnimations(true) // 设置加载图片完成后是否直接进行播放
                .build();

        img.setController(draweeController);
//加载图片
        //img.setImageURI(uri);
      /*  注意:如果项目中使用了OkHttp需要进行替换(因为Fresco底层网络用的是okhttp,不做修改会出现jar包冲突)
        OkHttp2版本:compile "com.facebook.fresco:imagepipeline-okhttp:0.12.0+"
        OkHttp3版本::compile "com.facebook.fresco:imagepipeline-okhttp3:0.12.0+"*/
    }
}

属性


fresco:fadeDuration="300" // 淡入淡出的持续时间
fresco:actualImageScaleType="focusCrop"  // 实际图像的缩放类型
fresco:placeholderImage="@color/wait_color"  //占位图
fresco:placeholderImageScaleType="fitCenter" //占位图的缩放类型
fresco:failureImage="@drawable/error" //下载失败显示的图片
fresco:failureImageScaleType="centerInside" //失败图的缩放类型
fresco:retryImage="@drawable/retrying"
//图片加载失败时显示,提示用户点击重新加载,重复加载4次还是没有加载出来的时候才会显示failureImage的图片
fresco:retryImageScaleType="centerCrop" //重新加载的图片缩放类型
fresco:progressBarImage="@drawable/progress_bar" //进度条图片
fresco:progressBarImageScaleType="centerInside"
fresco:progressBarAutoRotateInterval="1000"
//进度图自动旋转间隔时间(单位:毫秒ms)
fresco:backgroundImage="@color/blue"
//背景图片,这里的背景图片首先被绘制
fresco:overlayImage="@drawable/watermark"
// 设置叠加图,在xml中只能设置一张叠加图片,如果需要多张图片的话,需要在java代码中设置哦
fresco:pressedStateOverlayImage="@color/red"
// 设置点击状态下的叠加图
fresco:roundAsCircle="false" //设置为圆形图
fresco:roundedCornerRadius="1dp" // 圆角半径
fresco:roundTopLeft="true" // 左上角是否为圆角
fresco:roundTopRight="false"
fresco:roundBottomLeft="false"
fresco:roundBottomRight="true"
fresco:roundWithOverlayColor="@color/corner_color"
fresco:roundingBorderWidth="2dp" //边框的宽度
fresco:roundingBorderColor="@color/border_color" //边框颜色

猜你喜欢

转载自blog.csdn.net/nideyida1/article/details/82191518