可实现功能效果说明:

  可实现多张图片点击放大,手指控制,左右滑动,多张图片点击任意位置定位显示任意位置图片;无动画,可自己加

效果图:

                           

核心代码:

viewpager:

public class PhotoViewPager extends ViewPager {public PhotoViewPager(Context context) {super(context);}public PhotoViewPager(Context context, AttributeSet attrs) {super(context, attrs);}@Overridepublic boolean onInterceptTouchEvent(MotionEvent ev) {try {return super.onInterceptTouchEvent(ev);} catch (IllegalArgumentException e) {e.printStackTrace();return false;}}
}

adapter:

public class MyImageAdapter extends PagerAdapter {public static final String TAG = MyImageAdapter.class.getSimpleName();private List<String> imageUrls;private AppCompatActivity activity;public MyImageAdapter(List<String> imageUrls, AppCompatActivity activity) {this.imageUrls = imageUrls;this.activity = activity;}@Overridepublic Object instantiateItem(ViewGroup container, int position) {String url = imageUrls.get(position);PhotoView photoView = new PhotoView(activity);Picasso.with(activity).load(url).into(photoView);container.addView(photoView);photoView.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View view) {Log.d(TAG, "onClick: ");activity.finish();}});return photoView;}@Overridepublic int getCount() {return imageUrls != null ? imageUrls.size() : 0;}@Overridepublic boolean isViewFromObject(View view, Object object) {return view == object;}@Overridepublic void destroyItem(ViewGroup container, int position, Object object) {container.removeView((View) object);}@Overridepublic int getItemPosition(Object object) {return POSITION_NONE;}
}

photoViewActivity

public class PhotoViewActivity extends AppCompatActivity implements View.OnClickListener {public static final String TAG = PhotoViewActivity.class.getSimpleName();private PhotoViewPager mViewPager;private int currentPosition;private MyImageAdapter adapter;private TextView mTvImageCount;private TextView mTvSaveImage;private List<String> Urls;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_photo_view);initView();initData();}private void initView() {mViewPager = (PhotoViewPager) findViewById(R.id.view_pager_photo);mTvImageCount = (TextView) findViewById(R.id.tv_image_count);mTvSaveImage = (TextView) findViewById(R.id.tv_save_image_photo);mTvSaveImage.setOnClickListener(this);}private void initData() {Intent intent = getIntent();currentPosition = intent.getIntExtra("currentPosition", 0);HomeQuestionListModel.DataBeanX DataBean = ((HomeQuestionListModel.DataBeanX) intent.getSerializableExtra("questionlistdataBean"));Urls = DataBean.getAttach().getImage().getOri();adapter = new MyImageAdapter(Urls, this);mViewPager.setAdapter(adapter);mViewPager.setCurrentItem(currentPosition, false);mTvImageCount.setText(currentPosition+1 + "/" + Urls.size());mViewPager.addOnPageChangeListener(new ViewPager.SimpleOnPageChangeListener() {@Overridepublic void onPageSelected(int position) {super.onPageSelected(position);currentPosition = position;mTvImageCount.setText(currentPosition + 1 + "/" + Urls.size());}});}@Overridepublic void onClick(View view) {switch (view.getId()) {case R.id.tv_save_image_photo://save image break;}}
}

图片列表页面跳转:

private void statPhotoViewActivity(int position) {Intent intent = new Intent(this, PhotoViewActivity.class);Bundle bundle = new Bundle();bundle.putSerializable("dataBean", mData);intent.putExtras(bundle);intent.putExtra("currentPosition", position);startActivity(intent);}

TitleLayout——一个Android轻松实现通用、标准、支持沉浸式状态栏的标题栏库

转载于:https://www.cnblogs.com/shen-hua/p/6634440.html

Android使用ViewPager+PhotoView实现图片查看器相关推荐

  1. Android写的一个设置图片查看器,可以调整透明度

    先来看看效果吧: main.xml代码如下: 1 <?xml version="1.0" encoding="utf-8"?> 2 <Line ...

  2. 【Android实战】Gallary+ImageSwicther图片查看器

    仿照如今各大新闻站点图片新闻的浏览模式,上面展示详细图片(ImageSwitch),以下是能够滑动的小图片(Gallery). 当中须要注意的是ImageSwitch须要定义一个工厂返回的组件,而且能 ...

  3. 图片查看器:Android支持图片查看、缩放、滑动的PhotoView

    上效果: Android 图片查看器Demo效果 导入PhotoView,导入Glide. maven { url "https://jitpack.io" }implementa ...

  4. Android仿微信朋友圈图片展示效果,图片查看器

    现在越来越多的APP都会有图片展示,这里是模仿微信朋友圈图片展示效果,图片查看器. 主要分为4部分: 1.透明Activity 2.计算gridView下iamgeView Item所在位置 3.一张 ...

  5. android 图片查看器

    android实现的图片查看器 public class MainActivity extends AppCompatActivity {private EditText et_new_path;pr ...

  6. Android简易图片管理器,一个简单仿微信朋友圈的图片查看器 PhotoViewer

    PhotoViewer 该图片查看器是模仿微信朋友圈查看图片编写 allprojects { repositories { ... maven { url 'https://jitpack.io' } ...

  7. android仿空间照片查看器,PhotoViewer 一个简单仿微信朋友圈的图片查看器

    该图片查看器是模仿微信朋友圈查看图片编写 allprojects { repositories { ... maven { url 'https://jitpack.io' } } } lastRel ...

  8. 图片查看器 PhotoView

    一.使图片能够全部显示在自定义 View 中 1.自定义 View 采用自定义View继承AppCompatImageView,重写构造方法: public class PhotoView exten ...

  9. Android仿微信朋友圈图片查看器

    转载请注明出处:http://blog.csdn.net/allen315410/article/details/40264551 看博文之前,希望大家先打开自己的微信点到朋友圈中去,仔细观察是不是发 ...

最新文章

  1. 中大型网站静态资源优化及存储
  2. linux 定位 踩内存_运维必备的问题定位工具及案例分析
  3. html5怎么设置勾选,word文档怎么设置输入勾选框
  4. Linux基础篇之文本、数据流处理命令(sed uniq grep awk wc)
  5. How to find Material based on Sales Organization and Distribution Channel
  6. 【HDU - 1530】Maximum Clique(最大团问题,图论)
  7. android的自定义字体,Android 自定义字体方案
  8. 中国女子高尔夫球场市场趋势报告、技术动态创新及市场预测
  9. 【渝粤题库】 陕西师范大学 210006幼儿园课程作业(高起专)
  10. XDOJ 回文数 C语言
  11. 腾讯社交广告大赛总结
  12. 在win10下,xilinx公司FPGA下载器上,指示灯不亮,设备管理器中驱动显示正常,下载器无法识别到期间
  13. lasso回归python代码_LASSO回归代码实现 坚韧不拔|静水流深|读书|写作|博雅|数据分析|Python|商业|独立·独特·自立门户 kebook...
  14. STM32-RS485通信软硬件实现
  15. vulnhub--Funbox: Scriptkiddie
  16. getway网关路由配置的两种方式
  17. Linux(CentOS)安装MySQL教程
  18. hdu 4544 优先队列+贪心
  19. 2021年双流永安中学高考成绩查询,双流永安中学2020年高考升学率高不高?
  20. 华为开发者大会2021鸿蒙系统,鸿蒙2.0来了!华为开发者大会HDC 2020宣布

热门文章

  1. 公共技术点之 Java 反射 Reflection
  2. 中国计算机学会CCF推荐国际学术会议和期刊目录-人机交互与普适计算
  3. 程序员面试题精选100题(15)-含有指针成员的类的拷贝[C/C++/C#]
  4. 如何设计一门语言(一)——什么是坑(a)
  5. 编程之美-队列中取最大值操作问题
  6. Android 9 的非 SDK 接口限制 | 中文教学视频
  7. Spring Boot 多模块与 Maven 私有仓库
  8. (诊断)No module named MySQLdb
  9. 图像处理之log---log算子
  10. XenServer中Windows 7与XP多vCPU支持配置