Android通过ViewPager实现左右滑动切换图片

转自:http://jameszhao84.iteye.com/blog/1344584

想开发像人人网相册打开单张图片时候能左右滑动切换图片的效果,开始通过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就可以了。继承后需要重写如下四个方法。

 

 

类似于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 = BitmapFactory.decodeFile(mPaths.get(position));//载入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. }  
 
Xml代码   收藏代码
  1. <android.support.v4.view.ViewPager  
  2.     android:id="@+id/pager"  
  3.     android:layout_width="fill_parent"  
  4.     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. }  
 
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要禁用TabLayout与ViewPager的左右滑动切换功能,您可以自定义一个ViewPager的子类,并重写它的 `onInterceptTouchEvent` 方法。 首先,创建一个名为 `NonSwipeableViewPager` 的类,并继承自 ViewPager: ```java import android.content.Context; import android.util.AttributeSet; import android.view.MotionEvent; import androidx.annotation.NonNull; import androidx.annotation.Nullable; import androidx.viewpager.widget.ViewPager; public class NonSwipeableViewPager extends ViewPager { public NonSwipeableViewPager(@NonNull Context context) { super(context); } public NonSwipeableViewPager(@NonNull Context context, @Nullable AttributeSet attrs) { super(context, attrs); } @Override public boolean onInterceptTouchEvent(MotionEvent ev) { // 返回false,禁止ViewPager的左右滑动切换 return false; } @Override public boolean onTouchEvent(MotionEvent ev) { // 返回false,禁止ViewPager的左右滑动切换 return false; } } ``` 接下来,在您的布局文件中使用 `NonSwipeableViewPager` 替代原来的 ViewPager: ```xml <com.example.NonSwipeableViewPager android:id="@+id/viewPager" android:layout_width="match_parent" android:layout_height="match_parent" /> ``` 最后,通过以下方式将 TabLayout 与 NonSwipeableViewPager 绑定: ```java TabLayout tabLayout = findViewById(R.id.tabLayout); NonSwipeableViewPager viewPager = findViewById(R.id.viewPager); // 设置ViewPager的适配器 viewPager.setAdapter(adapter); // 将TabLayout与ViewPager关联起来 tabLayout.setupWithViewPager(viewPager); ``` 这样就可以禁用TabLayout与ViewPager的左右滑动切换功能了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值