下载地址如下:
http://square.github.io/picasso/
最基本的用法:
Picasso.with(context).load("http://i.imgur.com/DvpvklR.png").into(imageView);
Picasso不仅实现了图片异步加载的功能,还解决了android中加载图片时需要解决的一些常见问题:
1.在adapter中需要取消已经不在视野范围的ImageView图片资源的加载,否则会导致图片错位,Picasso已经解决了这个问题;
2.使用复杂的图片压缩转换来尽可能的减少内存消耗;
3.自带内存和硬盘二级缓存功能;
4.图形转换操作,如变换大小,旋转等,提供了接口来让用户可以自定义转换操作;
5.加载载网络或本地资源。
Adapter的重用会被自动检测到,Picasso会取消上次的加载
@Override public void getView(int position, View convertView, ViewGroup parent) { SquaredImageView view = (SquaredImageView) convertView; if (view == null) { view = new SquaredImageView(context); } String url = getItem(position); Picasso.with(context).load(url).into(view); }
图片转换:转换图片以适应布局大小并减少内存占用
Picasso.with(context) .load(url)//加载URL .resize(48, 48)//裁剪后的宽、高大小 .centerCrop()//中心裁剪 .into(imageView);//插入到imageview
Place holders-空白或者错误占位图片:
picasso提供了两种占位图片,未加载完成或者加载发生错误的时需要一张图片作为提示,如果加载发生错误会重复三次请求,三次都失败才会显示erro Place holder 。
Picasso.with(context) .load(url)//加载URL .placeholder(R.drawable.user_placeholder)//空白是插入的图片资源 .error(R.drawable.user_placeholder_error)//加载错误插入的图片资源 .into(imageView);//插入到imageview
资源文件的加载:
除了加载网络图片,picasso还支持加载Resources, assets, files, content providers中的资源文件,可以在打".load"时IDE提示中查看。
Picasso.with(context).load(R.drawable.landing_screen).into(imageView1); Picasso.with(context).load(new File(...)).into(imageView2);