/BigImageViewPager

🔥🔥🔥 BigImage ImageView ViewPager 支持超长图、超大图的图片浏览器,优化内存,支持手势放大、下拉关闭、查看原图、加载百分比、保存图片等功能。现已支持androidx。

Primary LanguageJavaOtherNOASSERTION

BigImage + ImageView + ViewPager = BigImageViewPager

一个图片浏览器,支持超大图、超长图、支持手势放大、支持查看原图、下载、加载百分比进度显示。采用区块复用加载,优化内存占用,有效避免OOM。支持手势下拉退出。

注意:本框架支持网络图片、本地图片、支持gif动图、支持Android 12。

后续可能会仅维护androidx版本,support请尽快迁移到androidx。参考官方迁移文档:https://developer.android.google.cn/jetpack/androidx/migrate

框架特性

  • 支持网络图片、本地图片;
  • 支持https图片;
  • 支持缩放比例、缩放动画时间的设置;
  • 支持手势下拉关闭;
  • 支持多种加载策略:(仅普清、仅原图、手动模式、网络自适应)
  • 支持多种类型图片(超大图、超长图、超宽图、小图、gif动图)
  • 支持查看原图,支持查看原图时百分比进度的展示;
  • 看图体验优化:长图拉到屏幕宽度显示、宽图双击放大到屏幕高度显示、gif图放大到屏幕宽度显示;
  • 自动根据Exif信息旋转图片进行显示;
  • 支持图片的下载,可设置保存到的路径(默认在存储根目录新建文件夹)
  • 支持多种界面的自定义(具体可查看Demo)
  • 支持加载失败时占位图的设置;
  • 针对保存图片进行优化,文件扩展名使用文件头部Mime信息进行设置,不用担心gif保存成jpeg;
  • 支持自定义查看原图时的百分比View;
  • 支持BMP格式的图片;
  • 支持Android 12;
  • 支持自定义GlideUrl,对于变化的url也不用担心了;

用法

一、添加依赖

Step 1. 在你project层级的build.gradle中,添加仓库地址:

allprojects {
    repositories {
        ...
        maven { url 'https://jitpack.io' }
    }
}

Step 2. 在你主module的build.gradle中添加依赖:

此处显示的是本框架的最新版本号:
⚠️注意:glide v3版本不再维护,最终版本为v3_4.0.2。建议使用androidx版本。
androidx用户  :   使用  androidx-6.2.0
对于glide4.x  :   使用        v4_6.1.3
dependencies {

  // ① 针对androidx用户,需要添加以下依赖:

  // glide
  implementation 'com.github.bumptech.glide:glide:4.11.0'
  annotationProcessor 'com.github.bumptech.glide:compiler:4.11.0'
  implementation 'com.github.bumptech.glide:okhttp3-integration:4.11.0'
  // 查看大图
  implementation 'com.github.SherlockGougou:BigImageViewPager:androidx-6.2.0'

================================分割线==================================

  // ② 针对glide v4 版本【建议项目尽快迁移到androix,后续此库的support版本会停更】,需要添加以下依赖:

  // glide
  implementation 'com.github.bumptech.glide:glide:4.9.0'
  annotationProcessor 'com.github.bumptech.glide:compiler:4.9.0'
  implementation 'com.github.bumptech.glide:okhttp3-integration:4.9.0'
  // 查看大图
  implementation 'com.github.SherlockGougou:BigImageViewPager:v4_6.1.3'

================================分割线==================================
}

Step 3. 在你的主module里,添加自定义AppGlideModule。你需要继承AppGlideModule并添加以下代码到对应的重载方法中,例如:

@GlideModule
public class MyAppGlideModule extends AppGlideModule {
  @Override
  public void registerComponents(@NonNull Context context, @NonNull Glide glide, @NonNull Registry registry) {
    super.registerComponents(context, glide, registry);

    // 替换底层网络框架为okhttp3,这步很重要!如果不添加会无法正常显示原图的加载百分比,或者卡在1%
    // 如果你的app中已经存在了自定义的GlideModule,你只需要把这一行代码,添加到对应的重载方法中即可。
    registry.replace(GlideUrl.class, InputStream.class, new OkHttpUrlLoader.Factory(ProgressManager.getOkHttpClient()));
  }
}

Step 4. 以上操作完成后,请点击顶部按钮:Build->Rebuild Project,等待重建完成,至此,框架添加完成。如遇到任何问题,请附带截图提issues,我会及时回复,或添加底部QQ群,进行交流。

二、调用方式

1:生成图片源:(如果你有缩略图和原图两种路径,请使用下面的方式,进行图片List的生成;如果你是本地图片或者没有原图缩略图之分,可以跳过这一步)

		ImageInfo imageInfo;
		final List<ImageInfo> imageInfoList = new ArrayList<>();
		for (String image : images) {
			imageInfo = new ImageInfo();
			imageInfo.setOriginUrl(url);// 原图url
			imageInfo.setThumbnailUrl(thumbUrl);// 缩略图url
			imageInfoList.add(imageInfo);
		}

2:最简单的调用方式:

        // 最简单的调用,即可实现大部分需求,如需定制,可参考下一步的自定义代码:

        ImagePreview
            .getInstance()
            // 上下文,必须是activity,不需要担心内存泄漏,本框架已经处理好;
            .setContext(MainActivity.this)

            // 设置从第几张开始看(索引从0开始)
            .setIndex(0)

            //=================================================================================================
            // 有三种设置数据集合的方式,根据自己的需求进行三选一:
            // 1:第一步生成的imageInfo List
            .setImageInfoList(imageInfoList)

            // 2:直接传url List
            //.setImageList(List<String> imageList)

            // 3:只有一张图片的情况,可以直接传入这张图片的url
            //.setImage(String image)
            //=================================================================================================

            // 开启预览
            .start();

            // 默认配置为:
            //      显示顶部进度指示器、
            //      显示右侧下载按钮、
            //      隐藏左侧关闭按钮、
            //      开启点击图片关闭、
            //      关闭下拉图片关闭、
            //      加载方式为手动模式
            //      加载原图的百分比在底部
接口说明:
方法名 功能 说明
setBigImageClickListener 设置图片点击事件 默认null
setBigImageLongClickListener 设置图片长按事件 默认null
setBigImagePageChangeListener 设置页面切换监听 默认null
setDownloadClickListener 设置点击下载监听 默认null,可选是否拦截下载行为
setCloseIconResId 设置关闭按钮的Drawable资源id 默认内置R.drawable.ic_action_close
setContext 设置上下文 不允许为空
setDownIconResId 设置下载按钮的Drawable资源id R.drawable.icon_download_new
setEnableClickClose 设置是否开启点击图片退出 默认true
setEnableDragClose 设置是否开启下拉图片退出 默认false
setEnableUpDragClose 设置是否开启上拉图片退出 默认false
setEnableDragCloseIgnoreScale 是否忽略缩放启用拉动关闭 默认false
setErrorPlaceHolder 设置加载失败的占位图资源id 默认内置R.drawable.load_failed
setFolderName 设置下载到的文件夹名称 默认保存Picture文件夹中
setImage 设置单张图片地址 三选一
setImageInfoList 设置图片Bean集合 三选一
setImageList 设置图片地址集合 三选一
setIndex 设置开始的索引 从0开始
setLoadStrategy 设置加载策略 详见加载策略说明
setOnOriginProgressListener 设置原图加载进度回调 加载原图的百分比进度
setProgressLayoutId 自定义百分比布局 详细见demo
setShowCloseButton 设置是否显示关闭按钮 默认false,不显示
setShowDownButton 设置是否显示下载按钮 默认true,显示
setShowIndicator 设置是否显示顶部的进度指示器 默认true,显示
setIndicatorShapeResId 设置顶部指示器背景shape 默认自带灰色圆角shape,设置为0时不显示背景
setShowErrorToast 设置是否显示加载失败的Toast 默认false,不显示
setZoomTransitionDuration 设置图片缩放动画时长 默认200ms
setCustomGlideUrlClzPath 设置自定义key计算的类路径 默认GlideUrl.class
start 开启看图 最后调用
3:自定义多种配置:

请参考Demo:https://github.com/SherlockGougou/BigImageViewPager/blob/androidx/sample/src/main/java/cc/shinichi/bigimageviewpager/MainActivity.java#L289

4:加载策略介绍
  public enum LoadStrategy {
    /**
     * 仅加载原图;会强制隐藏查看原图按钮
     */
    AlwaysOrigin,

    /**
     * 仅加载普清;会强制隐藏查看原图按钮
     */
    AlwaysThumb,

    /**
     * 根据网络自适应加载,WiFi原图,流量普清;会强制隐藏查看原图按钮
     */
    NetworkAuto,

    /**
     * 手动模式:默认普清,点击按钮再加载原图;会根据原图、缩略图url是否一样来判断是否显示查看原图按钮
     */
    Default
  }

  注:以上所有方式,如果原图缓存存在的情况,会默认加载原图缓存保证清晰度;且原图缓存只要存在,就不会显示查看原图按钮。
5:自定义百分比View

详细操作请参考Demo:https://github.com/SherlockGougou/BigImageViewPager/blob/master/sample/src/main/java/cc/shinichi/bigimageviewpager/MainActivity.java#L291

6:Q&A

1.查看原图卡在1%? 答:请仔细查看以上第三步的操作。

推荐扫描二维码进行安装体验:

GitHub源码

https://github.com/SherlockGougou/BigImageViewPager

致谢

Bug反馈、增加需求,加 QQ 交流群

LICENSE

Copyright (C) 2018 SherlockGougou qinglingou@gmail.com

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

        http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.