Fresco 加载 渐进式图片的简单使用

GItHub  地址:https://www.fresco-cn.org/docs/index.html 

先上图




 首先先添加依赖  

//静态图的依赖
implementation 'com.facebook.fresco:fresco:0.12.0'
// 支持 GIF 动图,需要添加
compile 'com.facebook.fresco:animated-gif:0.12.0'
implementation 'com.android.support:support-v4:27.1.1'

XML 文件

<com.facebook.drawee.view.SimpleDraweeView
    android:layout_width="400dp"
    android:layout_height="300dp"
    android:id="@+id/sdv"
    fresco:placeholderImage="@drawable/holder"
    fresco:failureImage="@drawable/err"
    fresco:retryImage="@drawable/res"
    fresco:roundAsCircle="true"
     />

    placeholderImage  是等待加载时的图片

   failureImage   是加载失败时的图片  (网络异常情况下)

    retryImage   是重新加载时显示的图片

 **

强制性的宽高

你必须声明 android:layout_widthandroid:layout_height。如果没有在XML中声明这两个属性,将无法正确加载图像。

wrap_content

Drawees 不支持 wrap_content 属性。


初始化Fresco

public class Myapp extends Application {
    @Override
    public void onCreate() {
        super.onCreate();
        //初始化Fresco
        Fresco.initialize(this);
    }
}   

清单文件中  加上权限和  注册App

android:name=".Myapp"

  最后是 java代码

 
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;

import com.facebook.drawee.backends.pipeline.Fresco;
import com.facebook.drawee.controller.AbstractDraweeController;
import com.facebook.drawee.view.SimpleDraweeView;

public class MainActivity extends AppCompatActivity {

    private SimpleDraweeView sdv;
    //gif 
    private String URL_="https://img3.duitang.com/uploads/item/201605/14/20160514165650_RHr3n.gif";

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        initView();
        AbstractDraweeController controller = Fresco.newDraweeControllerBuilder()
                //图片地址
                .setUri(URL_)
                //播放gif 图片
                .setAutoPlayAnimations(true)
                //点击重新加载时 可以重新加载4 次 
                .setTapToRetryEnabled(true)
                .build();

       sdv.setController(controller);
    }

    private void initView() {
        sdv = (SimpleDraweeView) findViewById(R.id.sdv);
    }
}
 
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Jonly_W

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值