您的位置:首页 > 移动开发 > Android开发

Android之Fresco(facebook的强大Android图片加载的框架)

2017-03-17 17:45 387 查看
Fresco是Facebook最新推出的一款用于Android应用中展示图片的强大图片库,可以从网络、本地存储和本地资源中加载图片。其中的Drawees可以显示占位符,直到图片加载完成。而当图片从屏幕上消失时,会自动释放内存。

Fresco是Facebook开源Android平台上一个强大的图片加载库,也是迄今为止Android平台上最强大的图片加载库。

Fresco是一个强大的图片加载组件。使用它之后,你不需要再去关心图片的加载和显示这些繁琐的事情!支持Android2.3及以后的版本。

Fresco源码:https://github.com/facebook/fresco

Fresco官方文档(中文):https://www.fresco-cn.org/

Fresco源码在线查看:http://frescolib.org/javadoc/reference/packages.html

gradle引入(当然你也可以引入高版本)

compile'com.facebook.fresco:fresco:0.12.0'
//支持GIF动图,需要添加
compile'com.facebook.fresco:animated-gif:0.12.0'

运行效果图:(注:此案例只完成了图中相应功能,Fresco更多功能去官方查看,讲解详细)

      


特性

1:内存管理

解压后的图片,即Android中的Bitmap,占用大量的内存。大的内存占用势必引发更加频繁的GC。在5.0以下,GC将会显著地引发界面卡顿。

在5.0以下系统,Fresco将图片放到一个特别的内存区域。当然,在图片不显示的时候,占用的内存会自动被释放。这会使得APP更加流畅,减少因图片内存占用而引发的OOM。

Fresco在低端机器上表现一样出色,你再也不用因图片内存占用而思前想后。

2:图片加载

Fresco的ImagePipeline允许你用很多种方式来自定义图片加载过程,比如:

为同一个图片指定不同的远程路径,或者使用已经存在本地缓存中的图片

先显示一个低清晰度的图片,等高清图下载完之后再显示高清图

加载完成回调通知

对于本地图,如有EXIF缩略图,在大图加载完成之前,可先显示缩略图

缩放或者旋转图片

对已下载的图片再次处理

支持WebP解码,即使在早先对WebP支持不完善的Android系统上也能正常使用!

3:图片绘制

Fresco的Drawees设计,带来一些有用的特性:

自定义居中焦点

圆角图,当然圆圈也行

下载失败之后,点击重现下载

自定义占位图,自定义overlay,或者进度条

指定用户按压时的overlay

4:图片的渐进式呈现

渐进式的JPEG图片格式已经流行数年了,渐进式图片格式先呈现大致的图片轮廓,然后随着图片下载的继续,呈现逐渐清晰的图片,这对于移动设备,尤其是慢网络有极大的利好,可带来更好的用户体验。

Android本身的图片库不支持此格式,但是Fresco支持。使用时,和往常一样,仅仅需要提供一个图片的URI即可,剩下的事情,Fresco会处理

5:动图加载

加载Gif图和WebP动图在任何一个Android开发者眼里看来都是一件非常头疼的事情。每一帧都是一张很大的
Bitmap
,每一个动画都有很多帧。Fresco让你没有这些烦恼,它处理好每一帧并管理好你的内存。

代码:(属性可根据需要设置注:android:layout_height="200dp"的属性值不能为:wrap_content)

<!--fresco:actualImageScaleType:实际加载的图片的伸缩样式
fresco:backgroundImage:底层图片资源
fresco:fadeDuration:进度条和占位符图片逐渐消失、加载的图片逐渐显示的时间间隔
fresco:failureImage:加载失败时显示的图片资源
fresco:failureImageScaleType:加载失败时加载的图片的伸缩样式
fresco:overlayImage:在显示的图片表层覆盖一张图片的图片资源
fresco:placeholderImage:占位符图片资源
fresco:placeholderImageScaleType:占位符图片的伸缩样式
fresco:progressBarAutoRotateInterval:进度条图片转动周期
fresco:progressBarImage:进度条图片资源
fresco:progressBarImageScaleType:进度条图片的伸缩样式
fresco:retryImage:提示重新加载的图片资源
fresco:retryImageScaleType:提示重新加载的图片的伸缩样式
fresco:roundAsCircle:将图片剪切成圆形
fresco:viewAspectRatio:图片宽高比-->

<com.facebook.drawee.view.SimpleDraweeView
android:id="@+id/id_main_sdv_sdv"
android:layout_width="match_parent"
android:layout_height="200dp"
fresco:actualImageScaleType="focusCrop"
fresco:fadeDuration="3000"
fresco:failureImage="@mipmap/ic_launcher"
fresco:failureImageScaleType="centerInside"
fresco:placeholderImage="@mipmap/ic_launcher"
fresco:placeholderImageScaleType="fitCenter"
fresco:progressBarAutoRotateInterval="1000"
fresco:progressBarImage="@drawable/aa"
fresco:progressBarImageScaleType="centerInside"
fresco:retryImage="@mipmap/ic_launcher"
fresco:retryImageScaleType="centerCrop"
fresco:roundAsCircle="false"
fresco:viewAspectRatio="1.6"/>


加载方式1:

SimpleDraweeViewsdv=(SimpleDraweeView)findViewById(R.id.id_main_sdv_sdv);
Uriuri=Uri.parse("http://image5.tuku.cn/pic/wallpaper/fengjing/menghuandaziranmeijingbizhi/009.jpg");
sdv.setImageURI(uri);


加载方式2:

SimpleDraweeViewsdv2=(SimpleDraweeView)findViewById(R.id.id_main_sdv_sdv2);
sdv2.setImageURI("http://img.my.csdn.net/uploads/201407/26/1406383243_5120.jpg");


加载方式3:


simpleDraweeView1=(SimpleDraweeView)findViewById(R.id.user_avator);
simpleDraweeView1.setController(Fresco.newDraweeControllerBuilder()
.setImageRequest(
ImageRequestBuilder.newBuilderWithSource(
Uri.parse("http://avatar.csdn.net/8/6/0/1_dickyqie.jpg"))
.setProgressiveRenderingEnabled(true)
.build())
.setOldController(simpleDraweeView1.getController())
.build());


加载方式gif图片:



Uriuri=Uri.parse("http://ww1.sinaimg.cn/mw600/6345d84ejw1dvxp9dioykg.gif");
simpleDraweeView2=(SimpleDraweeView)findViewById(R.id.user_avator2);
DraweeControllerdraweeController1=Fresco.newDraweeControllerBuilder().setUri(uri).setAutoPlayAnimations(true).build();
simpleDraweeView2.setController(draweeController1);
simpleDraweeView2.setOnTouchListener(this);


代码设置属性:



//代码设置SimpleDraweeView的属性(会覆盖XML设置的所有属性,即在XML中有在这里没有的属性都会失效)
//注意:一个GenericDraweeHierarchy是不能被多个SimpleDraweeView共用的
SimpleDraweeViewsdv=(SimpleDraweeView)findViewById(R.id.id_main_sdv_sdv);
GenericDraweeHierarchyhierarchy=newGenericDraweeHierarchyBuilder(getResources())
.setFadeDuration(3000)
.setPlaceholderImage(R.mipmap.ic_launcher)
.setPlaceholderImageScaleType(ScalingUtils.ScaleType.FIT_XY)
.setProgressBarImage(newProgressBarDrawable())//显示进度条(Fresco自带的进度条)
.build();
//设置图片圆角
RoundingParamsroundingParams=newRoundingParams();
roundingParams.setRoundAsCircle(false);//不将图片剪切成圆形
roundingParams.setCornersRadius(200);
hierarchy.setRoundingParams(roundingParams);
sdv.setHierarchy(hierarchy);





源码点击下载:https://github.com/DickyQie/android-network-image-loading

其他网络图片加载方式,请看

Android之网络图片加载的5种模式

Android之网络图片框架UniversalImageLoader和结合LruCache缓存图片

Android图片加载框架之Picasso非常好的图片加载缓存库

Android之Glide(非常好用的图片加载框架)


                                            
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: