一. Glide加载
Glide.with(this).load("http://p0.qhimg.com/t015f3654b694ad2f8a.jpg").into(imageView);
效果图
compile files('libs/glide-3.7.0.jar')
二. Picasso
Picasso.with(getApplicationContext()) //
.load("http://p0.qhimg.com/t015f3654b694ad2f8a.jpg") //加载地址
.placeholder(R.mipmap.ic_launcher)
//占位图
.error(R.mipmap.ic_launcher) //加载失败的图
.fit() //充满
.tag(getApplicationContext()) //标记
.into(imageView);//加载到的ImageView
在Build注入
// 首先在项目中引入picasso(以gradle为例)
// compile 'com.squareup.picasso:picasso:2.5.2'
三. ImageLoader
要使用ImageLoader必须先实现全局的实例化,这样可以避免每次使用都要重复代码 我们自定义一个MyApplication继承自Application,代码如下
- 然后需要在Manifest文件中写上代码:
//就是这一行代码,要加在application标签下
android:name=".MyApplication"
Build注入:
//ImageLoader
// compile 'com.nostra13.universalimageloader:universal-image-loader:1.9.5' • 然后再代码中使用就可以了
• String urls = "http://p0.qhimg.com/t015f3654b694ad2f8a.jpg"; DisplayImageOptions options = new DisplayImageOptions.Builder() .cacheInMemory(true)//在内存中缓存 .cacheOnDisc(true)//存储卡的缓存,需要添加相应的存储卡读写权限 .showImageOnFail(R.mipmap.ic_launcher)//加载失败的显示的图片 .showImageOnLoading(R.mipmap.ic_launcher)//加载过程中显示的图片 .build(); ImageLoader.getInstance().displayImage(urls, imageView, options);//加载图片
四. Fresco
- 这个框架可以用于加载网络上的gif图片 使用这个框架需要导入两个包
- 同时我们在布局中引入这个框架中自带的SimpleDraweeView控件
- 注意这个使用的时候不要将它的宽高设置为包含内容,它不支持这个属性,我们必须设置具体的宽高才可以
public class MainActivity extends AppCompatActivity implements View.OnClickListener {
//注意导的哪一个包名,有恨多个,别混乱了
//一共导入了两个包啊,千万记住了啊,用来加载gif动图的框架
private Button button, button2;
private SimpleDraweeView simpleDraweeView;
//simpleDraweeView控件不支持包含内容的宽高设置,必须设置明确的大小 protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
//由于我们在布局中使用了第三方框架的控件,所以我们必须在设置布局之前进行第三方框架的initialize()方法
Fresco.initialize(this);
setContentView(R.layout.activity_main); init();
} private void init() {
button = (Button) findViewById(.button);
button.setOnClickListener(this);
simpleDraweeView = (SimpleDraweeView) findViewById(.simpleDraweeView);
} @Override
public void onClick(View v) {
switch (v.getId()) {
case .button:
DraweeController animatedGifController = Fresco.newDraweeControllerBuilder()
//设置使其支持动画
.setAutoPlayAnimations(true)
.setUri(Uri.parse("http://img4.duitang.com/uploads/item/201306/10/20130610100354_3WrWN.gif"))
.build();
simpleDraweeView.setController(animatedGifController);
break;
}
}
}
• 关于SimpleDraweeView 的相关属性 fresco是自定义的属性标签
• xmlns:fresco="http:///apk/res-auto"
1
<com.facebook.drawee.view.SimpleDraweeView
android:id="@+id/my_image_view"
android:layout_width="20dp"
android:layout_height="20dp"
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"
fresco:retryImageScaleType="centerCrop"
fresco:progressBarImage="@drawable/progress_bar"
fresco:progressBarImageScaleType="centerInside"
fresco:progressBarAutoRotateInterval="1000"
fresco:backgroundImage="@color/blue"
fresco:overlayImage="@drawable/watermark"
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"
/>
fadeDuration 淡入淡出的时间
actualImageScaleType 图片的填充方式
placeholderImage 预加载图片
placeholderImageScaleType 预加载图片填充方式
failureImage 加载失败图片
failureImageScaleType 失败图片填充方式
retryImage 重试图片
retryImageScaleType 重试图片填充方式
progressBarImage 加载进度图片
progressBarImageScaleType 进度图片填充方式
progressBarAutoRotateInterval 自动旋转间隔
backgroundImage 背景图片
overlayImage 覆盖图片
pressedStateOverlayImage 按下时覆盖图
roundAsCircle 是否为圆形图
roundedCornerRadius 圆角弧度
roundTopLeft 左上角弧度
roundWithOverlayColor 圆角的覆盖色
roundingBorderWidth 圆角的边框宽度
roundingBorderColor 圆角边框颜色
如果用此框架加载静态图片的话,直接使用此框架的空间setImageUri的方法就可以了
五. PhotoView
- 关于这个框架的使用在这里 https:///chrisbanes/PhotoView
Drawable bitmap = getResources().getDrawable(R.mipmap.ic_launcher);
imageView.setImageDrawable(bitmap);
PhotoViewAttacher mAttacher = new PhotoViewAttacher(imageView);
这里需要注意
// If you later call mImageView.setImageDrawable/setImageBitmap/setImageResource/etc then you just need to call
mAttacher.update();
六. Xutils
Build注入:
// xutils
compile 'org.xutils:xutils:3.3.38'在Application 进行注册
public class App extends BaseApplication {
@Override
public void onCreate() {
super.onCreate(); //TODO 注册Xutils
x.Ext.init(this); }
}用法:
//TODO xUTILS
//xUtils绑定网络图片
//第一个参数是ImageView对象
//第二个参数是URL字符串地址
// x.image().bind(rxdq_big_img, "http://p0.so.qhmsg.com/sdr/600_900_/t01d43698fbeca29695.jpg");
请左上角 关注下 或右上角点个赞吧 ?