github地址:http://square.github.io/picasso/
Picasso不仅实现了图片异步加载的功能,还解决了android中加载图片时需要解决的一些常见问题:
1.在adapter中需要取消已经不在视野范围的ImageView图片资源的加载,否则会导致图片错位,Picasso已经解决了这个问题。
2.使用复杂的图片压缩转换来尽可能的减少内存消耗
3.自带内存和硬盘二级缓存功能
Picasso库的引入:1.在线搜索picasso库,加入到gradle再同步即可引入picasso库
2.加入源码,加入后出现错误,把测试相关的内容删除,删除OKHttpDownloader,也可以导入okhttp包,源码中设置图片下载器的代码如下:
static Downloader createDefaultDownloader(Context context) { if (SDK_INT >= GINGERBREAD) { try { Class.forName("com.squareup.okhttp.OkHttpClient"); return OkHttpLoaderCreator.create(context); } catch (ClassNotFoundException ignored) { } } return new UrlConnectionDownloader(context); }如果没有okhttp,把if语句注释,直接用默认的UrlConnectionDownloader进行图片下载
基本使用:
加载本地图片,并做压缩和旋转:
//加载本地图片 Picasso.with(this).load("file:///sdcard/Download/ddd.jpg").resize(100,100).rotate(180,0,0).into(mivPic);加载网络图片,并设置不使用内存缓存中查找也不存储内存缓存,对于本地缓存,如果用okhttp,可以设这两者,如果是默认的downloader,只能设置NO_CACHE:
//加载网络图片 Picasso.with(this). load(mstrNetUrl). //networkPolicy(NetworkPolicy.NO_CACHE,NetworkPolicy.NO_STORE). memoryPolicy(MemoryPolicy.NO_CACHE,MemoryPolicy.NO_STORE). into(mivPic);加载资源图片,并自定义转换器:
public void getResPic(View view) { //加载资源图片 Picasso.with(this).load(R.drawable.aaa).transform(new HalfTransformation()).into(mivPic); }自定义转换器对应的类
public class HalfTransformation implements Transformation{ @Override public Bitmap transform(Bitmap source) { Matrix matrix = new Matrix(); matrix.postScale(0.2f,0.2f); Bitmap newBitmap = Bitmap.createBitmap(source,0,0,source.getWidth(),source.getHeight(),matrix,true); source.recycle();//一定要回收原图 return newBitmap; } @Override public String key() { return "HalfTransformation"; } }
设置占位图片:
Picasso.
with
(context)
.load(url)
.placeholder(R.drawable.user_placeholder)
.error(R.drawable.user_placeholder_error)
.into(imageView);
glide
glide的用法跟picasso类似,不同点:
1.默认情况下,picasso加载整个图片到内存然后根据imageview大小调整,glide直接根据imageview大小加载调整后的图片,所以picasso图片质量好,内存消耗大,加载速度相对慢,glide图片质量相对差,内存消耗小,加载速度快
2.picasso缓存整个图片,只要是同一张图片,都会直接从缓存读取,glide根据imageview大小缓存不同大小图片,即使是同一个图片,显示的imageview大小不同,也会从新缓存
3.glide可以显示gif图片