免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 4222 | 回复: 1
打印 上一主题 下一主题

Android通过ViewPager实现左右滑动切换图片 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-01-13 16:02 |只看该作者 |倒序浏览
Android通过ViewPager实现左右滑动切换图片







想开发像人人网相册打开单张图片时候能左右滑动切换图片的效果,开始通过FlipperView实现,不能跟手拖动,效果不好,而且需要自己写很多代码来控制FlipperView中的View。后来发现Android 3.0之后的SDK中提供了android-support-v4包用以实现版本兼容,让老版本系统下的应用通过加入jar包实现扩展,得到新版的各种技术优势,例如Fragment等。



ViewPager是android-support-v4.jar包中的一个系统控件,继承自ViewGroup,专门用以实现左右滑动切换View的效果,使用时需要首先在Project->properties->Java Build Path->Libraries->Add External Jars中加入sdk目录下的extras/android/support/v4/android-support-v4.jar(如果找不到,则需要用sdk manager下载android support package)。加入这个jar包之后就可以使用ViewPager类了。



ViewPager的使用类似于ListView,需要有对应的Adapter进行数据绑定,实现图片切换仅需要继承PaperAdapter就可以了。继承后需要重写如下四个方法。
  1. instantiateItem(ViewGroup, int)
  2. destroyItem(ViewGroup, int, Object)
  3. getCount()
  4. isViewFromObject(View, Object)
复制代码
类似于BaseAdapter,其中instantiateItem方法用来得到每个View,destroyItem用以控制当某个View不需要的时候的回收处理。isViewFromObject用来实现判断View和Object是否为同一个View。


Java代码
  1. import java.io.FileNotFoundException;   
  2. import java.util.List;   
  3.   
  4. import android.content.Context;   
  5. import android.graphics.Bitmap;   
  6. import android.net.Uri;   
  7. import android.support.v4.view.PagerAdapter;   
  8. import android.support.v4.view.ViewPager;   
  9. import android.view.View;   
  10. import android.view.ViewGroup;   
  11. import android.widget.ImageView;   
  12.   
  13. public class TestAdapter extends PagerAdapter {   
  14.   
  15.     private List<String> mPaths;   
  16.       
  17.     private Context mContext;   
  18.       
  19.     public TestAdapter(Context cx) {   
  20.         mContext = cx.getApplicationContext();   
  21.     }   
  22.       
  23.     public void change(List<String> paths) {   
  24.         mPaths = paths;   
  25.     }   
  26.       
  27.     @Override  
  28.     public int getCount() {   
  29.         // TODO Auto-generated method stub   
  30.         return mPaths.size();   
  31.     }   
  32.   
  33.     @Override  
  34.     public boolean isViewFromObject(View view, Object obj) {   
  35.         // TODO Auto-generated method stub   
  36.         return view == (View) obj;   
  37.     }   
  38.   
  39.     @Override  
  40.     public Object instantiateItem (ViewGroup container, int position) {   
  41.         ImageView iv = new ImageView(mContext);   
  42.         try {   
  43.             Bitmap bm = ImageFile.getBitmapSample(mContext, Uri.parse(mPaths.get(position)), 320, 480);//载入bitmap   
  44.             iv.setImageBitmap(bm);   
  45.         } catch (FileNotFoundException e) {   
  46.             // TODO Auto-generated catch block   
  47.             e.printStackTrace();   
  48.         } catch (OutOfMemoryError e) {   
  49.             // TODO Auto-generated catch block   
  50.             e.printStackTrace();   
  51.         }   
  52.         ((ViewPager)container).addView(iv, 0);   
  53.         return iv;   
  54.     }   
  55.       
  56.     @Override  
  57.     public void destroyItem (ViewGroup container, int position, Object object) {   
  58.         container.removeView((View)object);   
  59.     }   
  60. }  

  61. import java.io.FileNotFoundException;
  62. import java.util.List;

  63. import android.content.Context;
  64. import android.graphics.Bitmap;
  65. import android.net.Uri;
  66. import android.support.v4.view.PagerAdapter;
  67. import android.support.v4.view.ViewPager;
  68. import android.view.View;
  69. import android.view.ViewGroup;
  70. import android.widget.ImageView;

  71. public class TestAdapter extends PagerAdapter {

  72.         private List<String> mPaths;
  73.        
  74.         private Context mContext;
  75.        
  76.         public TestAdapter(Context cx) {
  77.                 mContext = cx.getApplicationContext();
  78.         }
  79.        
  80.         public void change(List<String> paths) {
  81.                 mPaths = paths;
  82.         }
  83.        
  84.         @Override
  85.         public int getCount() {
  86.                 // TODO Auto-generated method stub
  87.                 return mPaths.size();
  88.         }

  89.         @Override
  90.         public boolean isViewFromObject(View view, Object obj) {
  91.                 // TODO Auto-generated method stub
  92.                 return view == (View) obj;
  93.         }

  94.         @Override
  95.         public Object instantiateItem (ViewGroup container, int position) {
  96.                 ImageView iv = new ImageView(mContext);
  97.                 try {
  98.                         Bitmap bm = ImageFile.getBitmapSample(mContext, Uri.parse(mPaths.get(position)), 320, 480);//载入bitmap
  99.                         iv.setImageBitmap(bm);
  100.                 } catch (FileNotFoundException e) {
  101.                         // TODO Auto-generated catch block
  102.                         e.printStackTrace();
  103.                 } catch (OutOfMemoryError e) {
  104.                         // TODO Auto-generated catch block
  105.                         e.printStackTrace();
  106.                 }
  107.                 ((ViewPager)container).addView(iv, 0);
  108.                 return iv;
  109.         }
  110.        
  111.         @Override
  112.         public void destroyItem (ViewGroup container, int position, Object object) {
  113.                 container.removeView((View)object);
  114.         }
  115. }
复制代码
Xml代码
  1. <android.support.v4.view.ViewPager  
  2.     android:id="@+id/pager"  
  3.     android:layout_width="fill_parent"  
  4.     android:layout_height="fill_parent" />  

  5.     <android.support.v4.view.ViewPager
  6.         android:id="@+id/pager"
  7.         android:layout_width="fill_parent"
  8.         android:layout_height="fill_parent" />
复制代码
Activity:
Java代码
  1. @Override  
  2. public void onCreate(Bundle savedInstanceState) {   
  3.     super.onCreate(savedInstanceState);   
  4.     setContentView(R.layout.main);   
  5.     mViewPager = (ViewPager)findViewById(R.id.pager);   
  6.     mAdapter = new TestAdapter(this);   
  7.     mViewPager.setAdapter(mAdapter);   
  8.     mAdapter.change(getList());   
  9. }   
  10.   
  11. private List<String> getList() {   
  12.     List<String> list = new ArrayList<String>();   
  13.     list.add("file:///sdcard/Sunset.jpg");   
  14.     list.add("file:///sdcard/Winter.jpg");   
  15.     list.add("file:///sdcard/Water lilies.jpg");   
  16.     list.add("file:///sdcard/Blue hills.jpg");   
  17.     return list;   
  18. }  
复制代码

论坛徽章:
0
2 [报告]
发表于 2012-01-13 16:02 |只看该作者
谢谢分享
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP