仿微信朋友圈查看图片下拽返回。集成轻松,效果超赞~
程序员文章站
2022-05-13 08:14:46
...
ImageWatcher
大图查看,它能够
- 动画顺畅切换到查看状态,同样动画顺畅退出查看界面
- 左右滑动多图查看
- 仿微信下拽退出
对比之前1.0.3
,
- 修复-宽高计算错误导致起始图片位置显示错误。
- 优化-取消了无意义的旋转,提示下拽体验(放大且图片已显示顶端时亦可下拽)。
- 优化-支持显示本地图片。
- 新增-支持长图显示(beta)。 使用的网络图片,被屏蔽了请自己换地址,或提醒我。
- 新增-自定义loadingUI
- 新增-自定义indexUI
集成
Add it in your root build.gradle at the end of repositories:
allprojects {
repositories {
...
maven { url 'https://jitpack.io' }
}
}
Add the dependency
dependencies {
implementation 'com.github.iielse:ImageWatcher:1.1.0'
}
初始化API简介
name | description |
---|---|
*setLoader | *图片地址加载的实现者 |
setTranslucentStatus | 当没有使用透明状态栏,传入状态栏的高度 |
setErrorImageRes | 图片加载失败时显示的样子 |
setOnPictureLongPressListener | 长按回调 |
setIndexProvider | 自定义页码UI |
setLoadingUIProvider | 自定义加载UI |
setOnStateChangedListener | 开始显示和退出显示时的回调 |
项目地址
https://github.com/iielse/ImageWatcher#imagewatcher
初始化配置
Activity.onCreate()
vImageWatcher = ImageWatcherHelper.with(this) // 一般来讲,ImageWatcher尺寸占据全屏
.setLoader(new GlideImageWatcherLoader()) // demo中有简单实现
.setIndexProvider(new DotIndexProvider()) // 自定义
.create();
Activity.onBackPressed()
if (!vImageWatcher.handleBackPressed()) {
super.onBackPressed();
}
使用
ImageView clickedImage = 被点击的ImageView;
SparseArray<ImageView> mapping = new SparseArray<>(); // 这个请自行理解,
mapping.put(0, clickedImage);
List<Uri> dataList = 被显示的图片们;
vImageWatcher.show(clickedImage, mapping, dataList);