一个图片查看器 , app到处都是 , 但那是别人的.
现在的一些app中经常会遇到这样的要求, 像gallery一样展示图片 , 其中还支持缩放等操作.
关于缩放事件的处理,可以使用github:photoview, 虽然有些情况不是很理想,已经相当不错了.
而gallery浏览的方式倒是成了一个主要的问题 .
因为手机内存的限制,解析一张图片,rgb565的配置,大图片消耗的内存也不小,像左右滑动的,一般会有三张图片,这是主要的难点了.
viewpager可以很容易的实现这种 swipe功能.左右滑动,可以自动销毁 多余的图片资源 .
新浪官方的微博程序的图片浏览方式就很不错.今天介绍的处理方式,也可以实现类似的效果,虽然不知道它是不是这样处理的.
class SamplePagerAdapter extends PagerAdapter implements ViewPager.OnPageChangeListener
先建立一个适配器,
mAdapter=new SamplePagerAdapter();
mViewPager.setAdapter(mAdapter);
mViewPager.setOnPageChangeListener(mAdapter);
初始化.
@Override
public View instantiateItem(ViewGroup container, int position) {
ImagePageView photoView=new ImagePageView(container.getContext());
photoView.setPicture(mPictureList.get(position));
photoView.update();
container.addView(photoView, ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT);
mFragmentArray.put(position, new WeakReference<View>(photoView));
return photoView;
}
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
Log.d(TAG, "destroyItem:"+object);
container.removeView((View) object);
final WeakReference<View> mWeakFragment=mFragmentArray.get(position);
if (mWeakFragment!=null) {
mWeakFragment.clear();
}
将多余的页面销毁.减少内在的占用.
}
@Override
public boolean isViewFromObject(View view, Object object) {
return view==object;
}
也许有人会问, 这就是简单的方式了,没有什么特别的.在photoView.update();实现下载,显示大图片就行了.
要是这样的话,我就没有必要再写下去了.
如果只是这样,可以试试,当三张大的gif图片,在一般的机器上,同时动画.效果如何,至少我在9500上,边下载,边动画,还是非常慢的.
主要的思想就是在当前之外 的页面,显示缩略图,只加载当前的pager中的大图片,当滑过一个页面时,重新调整显示大图的页面与小图的页面.以高效地应用系统资源.所以OnPageChangeListener很重要.
@Override
public void onPageSelected(int i) {
Log.d(TAG, "onPageSelected."+i);
int size=mFragmentArray.size();
for (int k=0; k<size; k++) {
int key=mFragmentArray.keyAt(k);
WeakReference<View> viewWeakReference=mFragmentArray.get(key);
if (null!=viewWeakReference&&null!=viewWeakReference.get()) {
Log.d(TAG, "key:"+key+" view:"+viewWeakReference.get());
ImagePageView imagePageView=(ImagePageView) viewWeakReference.get();
if (key==i) {
imagePageView.setResId(imagePageView.getPicture().originalId);
imagePageView.update();
} else {
imagePageView.setResId(imagePageView.getPicture().thumbId);
imagePageView.update();
}
} else {
Log.d(TAG, "key:"+key);
}
}
}
viewpager与普通的linearlayout不同,像listview一样,如果直接获取它的child,会有想不到的结果.
所以预先把一些页面用弱引用存起来.
然后读取其中的,非当前页面就加载缩略图,是当前页面就加载大图.
于是imagePageView.update();这个方法就要修改了.
示例中使用的方式:用drawable中的大图与小图区分加载效果的 . 已经集成到我的微博程序中.还有细节未完善
这就解决了资源释放的问题.
另外,进入图片查看程序不是从第一张开始,而是从某张开始的,这时不能在oncreate中设置viewpager.显示位置,
可以添加监听:
mViewPager.getViewTreeObserver().addOnPreDrawListener(new ViewTreeObserver.OnPreDrawListener() {
@Override
public boolean onPreDraw() {
Log.d(TAG, "onPreDraw:");
mViewPager.getViewTreeObserver().removeOnPreDrawListener(this);
if (index==0) {//显示第一张,默认进来的,我在这里的调用是因为instantiateItem中photoView.update();未加载大图,是加载小图.
mAdapter.onPageSelected(index);
} else {
mViewPager.setCurrentItem(index);
}
return true;
}
});
分享到:
相关推荐
在Android开发中,ViewPager是一个非常实用的基础组件,它允许用户通过左右滑动在多个界面之间切换,通常用于引导页、图片浏览、页面切换等场景。随着社交媒体应用的流行,如微信朋友圈的图片和视频轮播功能受到了...
ZoomPhotoPlace本项目是仿微博及猫眼查看图片的动画效果,使用viewpager查看图片放大,可以报道查看当前回到图片位置## 图片效果初始化...返回动画 /** * 关闭图片查看器Viewpager */ private void closeViewPager() {
【ViewPager网络图片无限循环】是Android开发中一种常见的应用场景,主要用于展示大量的图片资源,比如在瀑布流、轮播图等组件中。ViewPager结合适配器(Adapter)和数据加载库,如Picasso或Glide,可以实现从网络...
ViewPager是Android平台中一个强大的视图滑动组件,常用于实现页面间的滑动切换效果,例如在应用的启动页、图片轮播或者Tab标签页等场景。它允许用户通过手势左右滑动来浏览多个相邻的页面,每个页面可以是任何类型...
本教程将详细介绍如何使用ViewPager实现图片切换的功能。 首先,我们需要理解ViewPager的基本原理。ViewPager是Android Support Library中的一个控件,它可以缓存相邻的页面,提供平滑的页面滚动体验。它与...
`ViewPager`是一个可以左右滑动查看多个`Fragment`或`View`的容器。在图片轮播的场景中,每个`Fragment`或`View`通常会显示一张图片。`ViewPager`通过`PagerAdapter`来管理这些页面,`PagerAdapter`负责创建和销毁...
在Android开发中,`ViewPager`是一个非常常用的组件,它用于创建滑动查看多个页面的界面。结合网络图片加载库,如Volley,可以实现动态加载网络图片的效果,从而提升用户体验。下面将详细介绍如何使用`ViewPager`和...
在Android开发中,ViewPager是一个非常重要的...用户可以左右滑动ViewPager来查看不同页面的内容,每个页面由一张图片和相应的文字组成。这种布局方式在许多Android应用中都非常常见,为用户提供了一种流畅的交互体验。
本项目"viewpager实现图片自动轮播,带小点标明当前位置"正是利用ViewPager的特性,构建了一个图片自动轮播的功能,并且在底部添加了小点指示器来展示当前显示的图片位置。下面我们将详细探讨这个知识点。 首先,...
要实现图片查看大图并支持手势缩放,我们通常会用到`ImageView`和`ScaleGestureDetector`。`ImageView`是展示图片的基本组件,而`ScaleGestureDetector`可以帮助我们检测用户的缩放手势,从而实现图片的放大和缩小。...
PhotoView 继承自 ImageView,并添加了手势检测和处理逻辑,使得用户可以通过简单的触摸手势来查看和操作图片,提供了一种类似于 Google Photos 或其他图片查看应用的体验。 **ViewPager** 是 Android 支持库中的一...
在Android开发中,实现一个美观且功能完善的图片轮播组件是常见的需求,通常我们使用`ViewPager`来达成这一目标。`ViewPager`是一个强大的视图容器,它可以用来展示多个页面,并且用户可以左右滑动切换页面,非常...
【标题】"Viewpager加载网络图片轮播"涉及的关键知识点主要集中在Android开发中关于Viewpager组件的使用以及网络图片的加载。Viewpager是Android SDK提供的一种用于实现滑动页面效果的控件,常用于实现类似轮播图、...
本实例将详细介绍如何利用ViewPager实现图片的循环播放功能。 首先,我们需要理解ViewPager的基本原理。ViewPager是Android Support Library中的一个控件,它可以承载多个Fragment或者View,并根据用户的滑动操作在...
标题“使用ViewPager实现图片的滑动”涉及到的是Android开发中的一个常见功能,即在移动设备上创建一个可以左右滑动查看多个图片的界面。ViewPager是Android SDK中的一个强大的控件,它允许用户通过水平滑动手势来...
在ViewPager中,用户可以左右滑动查看相邻的页面。 为了实现图片的无限循环,我们不能简单地设置固定数量的页面,因为这样会导致用户在滑动到第一张或最后一张图片时无法继续滑动。我们需要一种方式让第一张图片...
ViewPager是Android SDK中的一个强大的组件,主要用于创建滑动查看多个页面的用户界面,通常用于实现类似相册或者卡片式浏览的效果。在这个场景中,它被用来实现3D的视觉体验,为用户提供更加生动和吸引人的交互。 ...
"photoview+viewpager 图片查看器"是利用两个关键库——PhotoView和ViewPager,来实现这样的功能。这两个库为用户提供了一种流畅、可缩放的图片浏览体验,同时也支持手势滑动切换图片。 首先,PhotoView是一个开源...
本教程将详细讲解如何使用ViewPager结合Handler实现图片自动切换的功能。 首先,我们需要了解ViewPager的基本用法。ViewPager是Android Support Library中的一个控件,它允许用户通过左右滑动来浏览多个页面。每个...
在Android开发中,ViewPager是一种非常常用的组件,常用于实现页面间的滑动切换效果,比如在应用的引导页、图片浏览器或者Tab布局中。本话题主要围绕如何利用ViewPager实现图片的滑动显示以及缩放功能,包括手势操作...