`
wen742538485
  • 浏览: 237434 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

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就可以了。继承后需要重写如下四个方法。





instantiateItem(ViewGroup, int)
destroyItem(ViewGroup, int, Object)
getCount()
isViewFromObject(View, Object)
类似于BaseAdapter,其中instantiateItem方法用来得到每个View,destroyItem用以控制当某个View不需要的时候的回收处理。isViewFromObject用来实现判断View和Object是否为同一个View。


Java代码 
import java.io.FileNotFoundException;  
import java.util.List;  
 
import android.content.Context;  
import android.graphics.Bitmap;  
import android.net.Uri;  
import android.support.v4.view.PagerAdapter;  
import android.support.v4.view.ViewPager;  
import android.view.View;  
import android.view.ViewGroup;  
import android.widget.ImageView;  
 
public class TestAdapter extends PagerAdapter {  
 
    private List<String> mPaths;  
      
    private Context mContext;  
      
    public TestAdapter(Context cx) {  
        mContext = cx.getApplicationContext();  
    }  
      
    public void change(List<String> paths) {  
        mPaths = paths;  
    }  
      
    @Override 
    public int getCount() {  
        // TODO Auto-generated method stub  
        return mPaths.size();  
    }  
 
    @Override 
    public boolean isViewFromObject(View view, Object obj) {  
        // TODO Auto-generated method stub  
        return view == (View) obj;  
    }  
 
    @Override 
    public Object instantiateItem (ViewGroup container, int position) {  
        ImageView iv = new ImageView(mContext);  
        try {  
            Bitmap bm = BitmapFactory.decodeFile(mPaths.get(position));//载入bitmap  
            iv.setImageBitmap(bm);  
        } catch (FileNotFoundException e) {  
            // TODO Auto-generated catch block  
            e.printStackTrace();  
        } catch (OutOfMemoryError e) {  
            // TODO Auto-generated catch block  
            e.printStackTrace();  
        }  
        ((ViewPager)container).addView(iv, 0);  
        return iv;  
    }  
      
    @Override 
    public void destroyItem (ViewGroup container, int position, Object object) {  
        container.removeView((View)object);  
    }  


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

import android.content.Context;
import android.graphics.Bitmap;
import android.net.Uri;
import android.support.v4.view.PagerAdapter;
import android.support.v4.view.ViewPager;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;

public class TestAdapter extends PagerAdapter {

private List<String> mPaths;

private Context mContext;

public TestAdapter(Context cx) {
mContext = cx.getApplicationContext();
}

public void change(List<String> paths) {
mPaths = paths;
}

@Override
public int getCount() {
// TODO Auto-generated method stub
return mPaths.size();
}

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

@Override
public Object instantiateItem (ViewGroup container, int position) {
ImageView iv = new ImageView(mContext);
try {
Bitmap bm = BitmapFactory.decodeFile(mPaths.get(position));//载入bitmap
iv.setImageBitmap(bm);
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (OutOfMemoryError e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
((ViewPager)container).addView(iv, 0);
return iv;
}

@Override
public void destroyItem (ViewGroup container, int position, Object object) {
container.removeView((View)object);
}
}

Xml代码 
<android.support.v4.view.ViewPager 
    android:id="@+id/pager" 
    android:layout_width="fill_parent" 
    android:layout_height="fill_parent" /> 

    <android.support.v4.view.ViewPager
        android:id="@+id/pager"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent" />

Activity:
Java代码 
@Override 
public void onCreate(Bundle savedInstanceState) {  
    super.onCreate(savedInstanceState);  
    setContentView(R.layout.main);  
    mViewPager = (ViewPager)findViewById(R.id.pager);  
    mAdapter = new TestAdapter(this);  
    mViewPager.setAdapter(mAdapter);  
    mAdapter.change(getList());  
}  
 
private List<String> getList() {  
    List<String> list = new ArrayList<String>();  
    list.add("file:///sdcard/Sunset.jpg");  
    list.add("file:///sdcard/Winter.jpg");  
    list.add("file:///sdcard/Water lilies.jpg");  
    list.add("file:///sdcard/Blue hills.jpg");  
    return list;  

分享到:
评论

相关推荐

    android点击查看大图,ViewPager实现左右滑动切换、缩放图片

    本示例主要讲解如何使用ViewPager实现左右滑动切换图片,并结合手势操作支持图片的缩放。以下是对这个功能的详细解析: 首先,`ViewPager`是Android SDK中的一个控件,它允许用户在多个页面间进行左右滑动切换。在...

    Android ViewPager多页面滑动切换以及动画效果

    Android ViewPager实现仿QQ多页面滑动切换以及动画效果

    android——viewpager实现左右滑动

    标题“android——viewpager实现左右滑动”表明我们将探讨如何使用ViewPager来实现类似微信标签栏的滑动功能。下面将详细介绍ViewPager的基本用法、相关组件以及实现这一功能的关键步骤。 首先,ViewPager是Android...

    Android应用源码使用ViewPager实现左右滑动翻页.zip

    这份"Android应用源码使用ViewPager实现左右滑动翻页"的资源提供了详细的实例代码,非常适合开发者进行参考和学习。 1. **ViewPager简介** ViewPager是Android Support Library中的一个控件,它允许我们在水平方向...

    android 使用viewpager实现图片轮播,左右可以无限制滑动

    `ViewPager`是一个强大的视图容器,它可以用来展示多个页面,并且用户可以左右滑动切换页面,非常适合用于创建滑动浏览的图片轮播。 **一、ViewPager简介** `ViewPager`是Android SDK中的`android.support.v4.view....

    Android ViewPager实现左右循环滑动及轮播效果

    在Android开发中,ViewPager是一个非常重要的组件,常用于展示多个页面并允许用户通过左右滑动切换页面。在标题“Android ViewPager实现左右循环滑动及轮播效果”中,提到的关键技术点是使ViewPager具备循环滑动和...

    Android自定义ViewPager实现纵向滑动翻页效果

    Android自定义ViewPager实现纵向滑动翻页效果是指在Android开发中实现ViewPager的纵向滑动翻页效果,达到类似抖音的视屏切换效果。这个效果通过自定义ViewPager实现,主要思路是交换Touch事件的x、y坐标,并实现...

    Android ViewPager实现圆点导航左右滑动和Fragment页面切换

    在Android开发中,`ViewPager` 是一个非常重要的组件,它允许用户通过左右滑动来浏览多个页面,通常用于实现滑动切换的界面效果。在这个示例中,我们结合`ViewPager`、`Fragment`、`PagerAdapter` 和 `...

    Android开发ViewPager实现左右滑动+自动切换+退出提示

    Android利用ViewPager实现功能: 1、实现左右滑动(基本功能) 2、自动切换界面功能 3、退出提示功能(即2秒内按两次退出键退出程序) 4、显示gif动画 代码里有执行顺序提示,适合初学者。

    Android使用ViewPager实现左右滑动翻页.zip

    本项目旨在教你如何在Android应用中使用ViewPager来实现左右滑动翻页的功能。 首先,我们需要了解ViewPager的基本概念。ViewPager是Android Support Library中的一个控件,它可以加载和管理多个Fragment或View,...

    android 之ViewPager左右滑动切换界面

    在本篇文章中,我们将深入探讨如何在Android应用中使用ViewPager实现左右滑动切换界面,并对相关源码进行解析。 首先,我们需要了解ViewPager的基本用法。ViewPager通常与PagerAdapter一起使用,PagerAdapter是...

    用TabLayout,ViewPager实现左右滑动切换页面的效果

    学习android两周多了,这几天在根据产品的...Demo主要用到的知识点包括:TabLayout, ViewPager,左右滑动切换tab界面,点击选项卡也可切换界面,一个activity包含多个fragment。tab页界面布局一致,但加载数据不同。

    Android ViewPager和Fragment 实现滑动切换页面

    在Android应用开发中,`ViewPager`和`Fragment`是两个重要的组件,它们常被结合使用以实现用户界面的滑动切换效果。`ViewPager`提供了一个可以左右滑动查看多个页面的容器,而`Fragment`则作为Activity的部分内容,...

    Android封装自定义ViewPager实现左右自动切换和手势滑动效果

    在Android开发中,ViewPager是一个非常常用的组件,常用于展示多个页面并进行平滑的左右滑动切换。然而,原生的ViewPager并不支持自动切换和某些特定的手势操作,因此开发者经常需要对其进行封装来满足这些需求。这...

    PhotoView和ViewPager实现图片左右滑动和放大缩小功能

    将 **PhotoView** 和 **ViewPager** 结合使用,我们可以实现一个强大的图片浏览界面,用户不仅可以左右滑动切换图片,还可以对单个图片进行放大缩小的操作。具体实现步骤如下: 1. 首先,在项目中引入 `androidx....

    Android ViewPager实现左右滑动

    为了让标题跟随ViewPager滑动,我们需要在PagerAdapter中实现`getPageTitle()`方法,返回每个页面的标题。TabLayout会自动根据这个方法的返回值更新标题。 如果你的项目中使用了`MyViewPager`这个自定义的ViewPager...

    android viewpager左右无限滑动

    在Android开发中,ViewPager是一个非常重要的组件,常用于实现页面间的滑动切换,例如在应用的Tab布局或者图片轮播中。"android viewpager 左右无限滑动"这一主题,意味着我们要创建一个可以无限制地向左或向右滑动...

    Android项目使用ViewPager实现左右滑动翻页.rar

    在Android开发中,ViewPager是一个非常重要的组件,它用于创建可以左右滑动的页面视图,常用于实现类似轮播图、Tab切换等效果。本项目就是以ViewPager为核心,实现了一个可以左右滑动翻页的应用。下面我们将深入探讨...

Global site tag (gtag.js) - Google Analytics