首先在项目的build.gradle文件里引用
api 'com.ycjiang:ImagePreview:2.3.5'
然后在app.java文件中初始化:
ZoomMediaLoader.getInstance().init(new ImageLoader());
这里用到的ImageLoader:
public class ImageLoader implements IZoomMediaLoader {
@Override
public void displayImage(@NonNull Fragment context, @NonNull String path, final ImageView imageView, @NonNull final MySimpleTarget simpleTarget) {
Glide.with(context)
.asBitmap()
.load(path)
.apply(new RequestOptions().fitCenter())
.into(new SimpleTarget<Bitmap>() {
@Override
public void onResourceReady(@NonNull Bitmap resource, @Nullable Transition<? super Bitmap> transition) {
simpleTarget.onResourceReady();
imageView.setImageBitmap(resource);
}
});
}
@Override
public void displayGifImage(@NonNull Fragment context, @NonNull String path, ImageView imageView, @NonNull final MySimpleTarget simpleTarget) {
Glide.with(context)
.asGif()
.load(path)
//可以解决gif比较几种时 ,加载过慢 //DiskCacheStrategy.NONE
.apply(new RequestOptions().diskCacheStrategy(DiskCacheStrategy.RESOURCE).dontAnimate())
//去掉显示动画
.listener(new RequestListener<GifDrawable>() {
@Override
public boolean onLoadFailed(@Nullable GlideException e, Object model, Target<GifDrawable> target, boolean isFirstResource) {
simpleTarget.onResourceReady();
return false;
}
@Override
public boolean onResourceReady(GifDrawable resource, Object model, Target<GifDrawable> target, DataSource dataSource, boolean isFirstResource) {
simpleTarget.onLoadFailed(null);
return false;
}
})
.into(imageView);
}
@Override
public void onStop(@NonNull Fragment context) {
Glide.with(context).onStop();
}
@Override
public void clearMemory(@NonNull Context c) {
Glide.get(c).clearMemory();
}
}
使用时点击的imageview点击事件:
view1.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
//组织数据
List<UserViewInfo> mThumbViewInfoList = new ArrayList<>(); // 这个最好定义成成员变量
for (int i = 0; i < images.length; i++) {
// Rect bounds = new Rect();
UserViewInfo item = new UserViewInfo(images[i]);
mThumbViewInfoList.add(item);
}
computeBoundsBackward(linearLayout,mThumbViewInfoList);
GPreviewBuilder.from(FarmExpertDetailActivity.this).setData(mThumbViewInfoList).setCurrentIndex((int) view.getTag())
.setSingleFling(true)//是否在黑屏区域点击返回
.setDrag(false)//是否禁用图片拖拽返回
.setType(GPreviewBuilder.IndicatorType.Number)//指示器类型
.start();//启动
}
});
computeBoundsBackward() 方法:
/**
* 查找信息
* @param list 图片集合
*/
private void computeBoundsBackward(LinearLayout linearLayout,List<UserViewInfo> list) {
for (int i = 0;i < linearLayout.getChildCount(); i++) {
View itemView = linearLayout.getChildAt(i);
Rect bounds = new Rect();
if (itemView != null) {
ImageView thumbView = itemView.findViewById(R.id.iamge_view);
thumbView.getGlobalVisibleRect(bounds);
}
list.get(i).setBounds(bounds);
// list.get(i).setUrl(list.get(i).getUrl());
}
}
这个computeBoundsBackward方法是为了定位全屏动画的起始位置,以及退出全屏查看时动画的结束位置,如果没有这个方法的话,动画起始位置和结束位置为屏幕的左上角,另外如果图片list过多超出一个屏幕,如果在全屏状态查看到超出屏幕的图片,动画结束位置也为左上角。
另外computeBoundsBackward是根据图片展示方式自己编写的,具体怎么写可以参考github上的demo或者下方的链接下载: