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里面加入命名空间
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"
>
在命名空间里面加入
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)
;