1.ImageLoaderhtml
首先:之前本身一直是使用ImageLoader的,,ImageLoader你们都是知道的,使用最普遍,使用方式也是最灵活的,,但后续出现了不少图片加载框架,本身也没去体验, 有一天,当ImageLoader没法知足,或者看到别人的项目框架图片加载比本身更佳流畅的时候,就研究了一下如今最流行的几种图片加载方式。android
Universal Image Loader:一个强大的图片加载库,包含各类各样的配置,最老牌,使用也最普遍。 Picasso: Square出品,必属精品。和OkHttp搭配起来更配呦! Volley ImageLoader:Google官方出品,惋惜不能加载本地图片~ Fresco:Facebook出的,天生骄傲!不是通常的强大。 Glide:Google推荐的图片加载库,专一于流畅的滚动。
1.volley-imageloader
基于volley的 图片框架,使用须要本身配置,由于volley自身是不带图片加载的配置,这里就不作详细介绍了。git
2.picasso 是square公司开源的一个Android图形缓存库使用也很是简单github
使用方式: (1) 导入外部库 compile 'com.squareup.picasso:picasso:2.5.2' (2) Picasso.with(context).load("加载地址").placeholder("加载前显示的图片").error("错误显示的图片").centerCrop("类型吧").resize("大小").into("要显示的Image"); 优势: (1)在adapter中须要取消已经不在视野范围的ImageView图片资源的加载,不然会致使图片错位,Picasso已经解决了这个问题。 (2)使用复杂的图片压缩转换来尽量的减小内存消耗 (3)自带内存和硬盘二级缓存功能 部分解决方案:[解决方案](http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2014/0731/1639.html)
3.glide 像是picasso的高仿版,使用方式 如出一辙几乎,,但我的推荐使用glide,自我测试,内存消耗极小,加载速度快于picasso ,更适合使用在滑动listview 里面的图片,google推荐的,,如今作的小应用都是用了glide缓存
使用方式: (1)导入外部库 compile 'com.github.bumptech.glide:glide:3.6.1' (2)Glide.with(mContext).load(url).placeholder(R.drawable.loading_spinner) .crossFade().into(myImageView);//crossFade()渐现效果 部分解决方案:[解决Listview里面image没法设置set, 或者返回drawbler返回本身设置一些效果等](http://www.wtoutiao.com/p/z53DE5.html)
4.fresco是facebook推出的一款强大的android图片处理库, 太强大了,可是惟一的缺点就是太大了,使用后app至少增长2M,不适合小应用使用app
使用方式 : 1.导入外部库 compile 'com.facebook.fresco:fresco:0.6.0' //0.8.0 2.Application初始化 Fresco.initialize(this);//强大的图片加载框架 3.开始使用: <com.facebook.drawee.view.SimpleDraweeView android:id="@+id/find_head_img" android:layout_width="60dp" android:layout_height="60dp" android:layout_marginRight="@dimen/padding_size" fresco:failureImage="@drawable/user_head_img" fresco:placeholderImage="@drawable/user_head_img" /> 针对 fresco 本身封装了几个小工具 /** * 普通显示 * */ public static void showFescoBitmap(SimpleDraweeView drawee,String url){ //方法二 ImageRequest request = ImageRequestBuilder.newBuilderWithSource(Uri.parse(url)) .setAutoRotateEnabled(true)//自动旋转 .setProgressiveRenderingEnabled(false)//是否支持渐进式加载 .build(); DraweeController draweeController= Fresco.newDraweeControllerBuilder() .setImageRequest(request) .setOldController(drawee.getController())//可节省没必要要的内存 .setAutoPlayAnimations(true) .build(); drawee.setController(draweeController); } /** * 普通显示 * */ public static void showFescoBitmap2(Context context,SimpleDraweeView drawee,String url,int drawId){ ImageRequest request = ImageRequestBuilder.newBuilderWithSource(Uri.parse(url)) .setAutoRotateEnabled(true)//自动旋转 .setProgressiveRenderingEnabled(false)//是否支持渐进式加载 .build(); DraweeController draweeController= Fresco.newDraweeControllerBuilder() .setTapToRetryEnabled(true)//加载失败时,会重试4次 .setImageRequest(request) .setAutoPlayAnimations(true) .build(); GenericDraweeHierarchyBuilder builder =//用来设置加载失败,加载中,加载前图片,等效果 new GenericDraweeHierarchyBuilder(context.getResources()); GenericDraweeHierarchy hierarchy = builder .setFadeDuration(300) .setPlaceholderImage(context.getResources().getDrawable(drawId)) .setFailureImage(context.getResources().getDrawable(drawId)) // .setOverlays(overlaysList) .build(); drawee.setHierarchy(hierarchy); drawee.setController(draweeController); } /** * 显示圆角 * */ public static void showFescoRoundBitmap(SimpleDraweeView draweeView,String url){ DraweeController draweeController2 = Fresco.newDraweeControllerBuilder().setUri(Uri.parse(url)).setAutoPlayAnimations(true).build(); draweeView.setController(draweeController2); RoundingParams mRoundParams2 = RoundingParams.fromCornersRadius(7f); mRoundParams2.setRoundAsCircle(true);//圆圈 - 设置roundAsCircle为true mRoundParams2.setBorder(Color.parseColor("#ffffff"),3);//显示边框的颜色 //mRoundParams2.setOverlayColor(Color.parseColor("#ffffff"));//用来绘制非圆角颜色 draweeView.getHierarchy().setRoundingParams(mRoundParams2); } /** * 解决图片缩放 * */ public static void showFescoScrolBitmap(SimpleDraweeView draweeView,String url,int width,int height){ ImageRequest request = ImageRequestBuilder.newBuilderWithSource(Uri.parse(url)) .setResizeOptions(new ResizeOptions(width, height)) .build(); PipelineDraweeController controller = (PipelineDraweeController) Fresco.newDraweeControllerBuilder() .setOldController(draweeView.getController()) .setImageRequest(request) .build(); draweeView.setController(controller); }