安卓图片加载框架Fresco



Fresco中文官网: https://www.fresco-cn.org/
Fresco是Facebook开发的一款开源框架 号称目前最强的Android图片加载库在内存方面表现的极为优秀
支持Android2.3及以后的版本
首先先上一组加载图片的代码,不加任何修饰
依赖: implementation 'com.facebook.fresco:fresco:0.12.0'
支持动态图的依赖: implementation 'com.facebook.fresco:animated-gif:0.12.0'
创建一个初始化类 并在清单文件中初始化
public class App extends Application {
@Override
public void onCreate () {
super .onCreate() ;
Fresco. initialize ( this ) ;
}
}

在xml里面加入命名空间
<LinearLayout xmlns:android= "http://schemas.android.com/apk/res/android" xmlns:fresco= "http://schemas.android.com/apk/res-auto" android:layout_height= "match_parent" android:layout_width= "match_parent" >
在命名空间里面加入
<com.facebook.drawee.view.SimpleDraweeView
android :layout_width= "400dp"
android :layout_height= "match_parent"
android :id= "@+id/ima"
fresco :placeholderImage= "@mipmap/ic_launcher" />
MainActivity里面 加载图片 fresco不支持相对路径的URL只支持绝对路径
Uri uri = Uri. parse ( "http://dynamic-image.yesky.com/740x-/uploadImages/2015/163/50/690V3VHW0P77.jpg" ) ;
SimpleDraweeView draweeView = (SimpleDraweeView) findViewById(R.id. ima ) ;
DraweeController controller = Fresco. newDraweeControllerBuilder ()
.setUri(uri)
.setAutoPlayAnimations( true )
.build() ;
draweeView.setController(controller) ;

简单的加载图片的代码写完了 最后别忘记添加网络权限啊

下面是一些在xml里面添加的图片配置
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"   //边框颜色

有时候需要加载很多图片,这个时候如果网络情况不是很好的情况下,一直显示占位图,体验也不是很好,我们可以先显示一个低分辨率的图片,等到大图加载完成之后,在显示真正的图片。
DraweeController controller = Fresco. newDraweeControllerBuilder ()
.setLowResImageRequest(ImageRequest. fromUri (uri))
.setImageRequest(ImageRequest. fromUri (uri))
.setOldController(draweeView.getController())
.build() ;
draweeView.setController(controller) ;







猜你喜欢

转载自blog.csdn.net/anqidaimaasm/article/details/80595344