# ZoomPreviewPicture **Repository Path**: kinggo/ZoomPreviewPicture ## Basic Information - **Project Name**: ZoomPreviewPicture - **Description**: 实现了点击小图放大至全屏预览,退出全屏恢复至原来位置这两个过程的动画过渡。 常见应用场景如微信朋友圈照片九宫格和微信聊天图片,视频,gif预览,某些手机系统相册等viewpager图片查看 缩放 拖拽下拉缩小退出(效果同微信图片浏览) - **Primary Language**: Unknown - **License**: Not specified - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2020-12-21 - **Last Updated**: 2020-12-21 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # ZoomPreviewPicture [![](https://jitpack.io/v/Lion7k/ZoomPreviewPicture.svg)](https://jitpack.io/#Lion7k/ZoomPreviewPicture) 本项目受Google官方demo Zooming a View 启发,实现了点击小图放大至全屏预览,退出全屏恢复至原来位置这两个过程的动画过渡。 常见应用场景如微信朋友圈照片九宫格和微信聊天图片,视频,gif预览,某些手机系统相册等viewpager图片查看 缩放 拖拽下拉缩小退出(效果同微信图片浏览) ### 特点 * 1.支持自定义图片加载框架。 * 2.支持重写activity,完成切换切换效果。 * 3.图片查看 缩放 拖拽下拉缩小退出。 * 4.支持自定义activity,Fragment。 * 5.支持视频和自定义视频播放控件。 * 6.支持类似微信朋友圈照片九宫格和微信聊天图片预览。 * 7.指示器类型选择 [圆点模式(贝塞尔圆点指示器)](https://github.com/yanyiqun001/bannerDot)和数字模式。 * 8.增加接口实体类。不在使用数据转化。 * 8.支持GIF显示。 ####效果如下: ![](gif/test.gif) ### 添加Gradle依赖 先在项目根目录的 build.gradle 的 repositories 添加: ``` allprojects { repositories { ... maven { url "https://jitpack.io" } } } ``` 然后在dependencies添加: ``` dependencies { ...        compile 'com.github.Lion7k:ZoomPreviewPicture:1.0.0' } ``` ### 1.本项目类库依赖第三库 >>>注意: 由于的[photoview](https://github.com/chrisbanes/PhotoView)有些事件冲突,将1.3.1版本源代码修改采用依赖本地。 ``` compile 'com.android.support:support-fragment:25.3.1' compile 'com.android.support:support-core-utils:25.3.1' ``` ### 2.示例代码 * >>注意:: 你实现自定义类,在你 app onCreate() 中 ```` @Override public void onCreate() { super.onCreate(); ZoomMediaLoader.getInstance().init(new TestImageLoader()); } ```` 1.使用方式 ``` GPreviewBuilder.from(GridViewCustomActivity.this)//activity实例必须 .to(CustomActivity.class)//自定义Activity 使用默认的预览不需要 .setData(mThumbViewInfoList)//集合 .setUserFragment(UserFragment.class)//自定义Fragment 使用默认的预览不需要 .setCurrentIndex(position) .setSingleFling(false)//是否在黑屏区域点击返回 .setDrag(false)//是否禁用图片拖拽返回 .setType(GPreviewBuilder.IndicatorType.Dot)//指示器类型 .start();//启动 ``` 2.列表控件item点击事件添加相应代码。 (RecyclerView为例,demo有(ListView和GridView和九宫格控件实例代码)) ``` mRecyclerView.addOnItemTouchListener(new OnItemClickListener() { @Override public void SimpleOnItemClick(BaseQuickAdapter baseQuickAdapter, View view, int position) { //在你点击时,调用computeBoundsBackward()方法 computeBoundsBackward(mGridLayoutManager.findFirstVisibleItemPosition()); GPreviewBuilder.from(RecycleViewActivity.this) .setData(mThumbViewInfoList) .setCurrentIndex(position) .setType(GPreviewBuilder.IndicatorType.Number) .start(); } }); /** ** 查找信息 * 从第一个完整可见item逆序遍历,如果初始位置为0,则不执行方法内循环 */ private void computeBoundsBackward(int firstCompletelyVisiblePos) { for (int i = firstCompletelyVisiblePos;i < mThumbViewInfoList.size(); i++) { View itemView = mGridLayoutManager.findViewByPosition(i); Rect bounds = new Rect(); if (itemView != null) { ImageView thumbView = (ImageView) itemView.findViewById(R.id.iv); thumbView.getGlobalVisibleRect(bounds); } mThumbViewInfoList.get(i).setBounds(bounds); } } ```` 2.构造实体类: 你的实体类实现IThumbViewInfo接口 >> **注意:IThumbViewInfo 实现 Parcelable 接口 注意序列化化** ````` public class UserViewInfo implements IThumbViewInfo { private String url; //图片地址 private Rect mBounds; // 记录坐标 private String user;// private String videoUrl;//视频链接 //不为空是视频 public UserViewInfo(String url) { this.url = url; } @Override public String getUrl() {//将你的图片地址字段返回 return url; } public void setUrl(String url) { this.url = url; } @Override public Rect getBounds() {//将你的图片显示坐标字段返回 return mBounds; } public void setBounds(Rect bounds) { mBounds = bounds; } } ````` ### 3.使用自定义图片加载配置 **注意这个必须实现哦。不然加载** * 1在你项目工程,创建一个类 实现接口IZoomMediaLoader接口 如下代码 demo 采用glide ,可以使用Picassor Imagloader 图片加载框架 ```` public class TestImageLoader implements IZoomMediaLoader { @Override public void displayImage(Fragment context, String path, final MySimpleTarget simpleTarget) { Glide.with(context).load(path).asBitmap().centerCrop().diskCacheStrategy(DiskCacheStrategy.SOURCE) .error(R.drawable.ic_default_image) .into(new SimpleTarget() { @Override public void onResourceReady(Bitmap resource, GlideAnimation glideAnimation) { simpleTarget.onResourceReady(resource); } @Override public void onLoadStarted(Drawable placeholder) { super.onLoadStarted(placeholder); simpleTarget.onLoadStarted(); } @Override public void onLoadFailed(Exception e, Drawable errorDrawable) { super.onLoadFailed(e, errorDrawable); simpleTarget.onLoadFailed(errorDrawable); } }); } @Override public void onStop(@NonNull Fragment context) { Glide.with(context).onStop(); } @Override public void clearMemory(@NonNull Context c) { Glide.get(c).clearMemory(); } ```` ### 4.视频的支持 1.自定义播放视频控制 ````` GPreviewBuilder.from(VideoViewActivity.this) .setData(mThumbViewInfoList) .setCurrentIndex(position) .setSingleFling(true) .setOnVideoPlayerListener(new VideoClickListener(){ @Override public void onPlayerVideo(String url) { Log.d("onPlayerVideo",url); Intent intent=new Intent(VideoViewActivity.this,VideoPlayerDetailedActivity.class); intent.putExtra("url",url); startActivity(intent); } }) .setType(GPreviewBuilder.IndicatorType.Number) .start(); ````` ### 5.自定义Activity,Fragment 1.实现自定义Activity,实现你业务操作例如加入标题栏,ViewPager切换动画等等 .![image.png](http://upload-images.jianshu.io/upload_images/1190712-fed3e16d9a686110.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240) 在你的布局中,引用类库核心布局 >> 2.实现自定义Fragment 实现自定义业务 例如 长按保存图片,编辑图片,对图片说明内容等等 图片缩放效果采用[PhotoView](https://github.com/chrisbanes/PhotoView) ![image.png](http://upload-images.jianshu.io/upload_images/1190712-d0175aaf2931116e.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240) >>需要布局自定义重写onCreateView()。引用你自定义布局中添加 >> 3 使用细节注意: >>1 **Activity和Fragment可以单独使用,也可以组合一起使用** >>2. **自定义使用布局时,不在子类使用setContentView()方法** >>3. **你在Activity 重写 setContentLayout(),返回你的自定义布局** >>4. **在你布局内容 使用include layout="@layout/activity_image_preview_photo" 预览布局添加你布局中** >>5. **GPreviewBuilder 调用 from()方法后,调用to();指向你.to(CustomActivity.class)自定义预览activity** >>6. **别忘了在AndroidManifest activity 使用主题** >> 示例: #### [九宫格图片控件来自laobie](https://github.com/laobie/NineGridImageView) #### 1.0.0 * 发布第一版