这是谷歌官方给我们提供的一个兼容低版本安卓设备的软件包,里面包囊了只有在安卓3.0以上可以使用的api。而viewpager就是其中之一利用它,我们可以做很多事情,从最简单的导航,到页面菜单等等。那如何使用它呢,与LisstView类似,我们也需要一个适配器,他就是PagerAdapter。看一下api的图片,

ViewPager的功能就是可以使视图滑动,就像Lanucher左右滑动那样。分三个步骤来使用它:

1.在住布局文件里加入

[html] view plaincopy

 
  1. <</span>android.support.v4.view.ViewPager    这个组件,注意这个组件是用来显示左右滑动的界面的,如果不加载xml布局文件,他是不会显示内容的。
  2. android:id="@+id/viewpager"
  3. android:layout_width="wrap_content"
  4. android:layout_height="wrap_content"
  5. android:layout_gravity="center" >

2.加载要显示的页卡,

[java] view plaincopy

 
  1. LayoutInflater lf = getLayoutInflater().from(this);
  2. view1 = lf.inflate(R.layout.layout1, null);
  3. view2 = lf.inflate(R.layout.layout2, null);
  4. view3 = lf.inflate(R.layout.layout3, null);
  5. viewList = new ArrayList();// 将要分页显示的View装入数组中
  6. viewList.add(view1);
  7. viewList.add(view2);
  8. viewList.add(view3);

3.在Activity里实例化ViewPager组件,并设置它的Adapter(就是PagerAdapter,方法与ListView一样的),在这里一般需要重写PagerAdapter。

[java] view plaincopy

 
  1. PagerAdapter pagerAdapter = new PagerAdapter() {
  2. @Override
  3. public boolean isViewFromObject(View arg0, Object arg1) {
  4. return arg0 == arg1;
  5. }
  6. @Override
  7. public int getCount() {
  8. return viewList.size();
  9. }
  10. @Override
  11. public void destroyItem(ViewGroup container, int position,
  12. Object object) {
  13. container.removeView(viewList.get(position));
  14. }
  15. @Override
  16. public int getItemPosition(Object object) {
  17. return super.getItemPosition(object);
  18. }
  19. @Override
  20. public CharSequence getPageTitle(int position) {
  21. return titleList.get(position);
  22. }
  23. @Override
  24. public Object instantiateItem(ViewGroup container, int position) {
  25. container.addView(viewList.get(position));
  26. weibo_button=(Button) findViewById(R.id.button1);
  27. weibo_button.setOnClickListener(new OnClickListener() {
  28. public void onClick(View v) {
  29. intent=new Intent(ViewPagerDemo.this,WeiBoActivity.class);
  30. startActivity(intent);
  31. }
  32. });
  33. return viewList.get(position);
  34. }
  35. };
  36. viewPager.setAdapter(pagerAdapter);

这是重写PagerAdapter的一个方法,我们还可以这样做:

[java] view plaincopy

 
  1. public class MyViewPagerAdapter extends PagerAdapter{
  2. private List mListViews;
  3. public MyViewPagerAdapter(List mListViews) {
  4. this.mListViews = mListViews;//构造方法,参数是我们的页卡,这样比较方便。
  5. }
  6. @Override
  7. public void destroyItem(ViewGroup container, int position, Object object)   {
  8. container.removeView(mListViews.get(position));//删除页卡
  9. }
  10. @Override
  11. public Object instantiateItem(ViewGroup container, int position) {  //这个方法用来实例化页卡
  12. container.addView(mListViews.get(position), 0);//添加页卡
  13. return mListViews.get(position);
  14. }
  15. @Override
  16. public int getCount() {
  17. return  mListViews.size();//返回页卡的数量
  18. }
  19. @Override
  20. public boolean isViewFromObject(View arg0, Object arg1) {
  21. return arg0==arg1;//官方提示这样写
  22. }
  23. }

大同小异,有一定很重要,就是我们需要重写哪些方法。从上面的图片可以看到,ViewPager的适配器是PagerAdapter,它是基类提供适配器来填充页面ViewPager内部,你很可能想要使用一个更具体的实现,如FragmentPagerAdapter或FragmentStatePagerAdapter。在这里需要说明一下,其实ViewPager应该和Fragment一起使用,至少谷歌官方是这么想的,但是在3.0之下,我们没有必要这么做。下面要注意,当你实现一个PagerAdapter,你必须至少覆盖以下方法:

从上面的例子中可以看到,我们最少也是实现了上面四个方法,当然如果你想让程序更健壮或是功能更全面,你可以重写其他的方法。下面看一下第一个完整的示例代码:

  主页面Activity:
[java] view plaincopy

 
  1. package com.example.viewpagerdemo;
  2. import java.util.ArrayList;
  3. import java.util.List;
  4. import android.os.Bundle;
  5. import android.app.Activity;
  6. import android.content.Context;
  7. import android.content.Intent;
  8. import android.support.v4.view.PagerAdapter;
  9. import android.support.v4.view.PagerTabStrip;
  10. import android.support.v4.view.PagerTitleStrip;
  11. import android.support.v4.view.ViewPager;
  12. import android.util.AttributeSet;
  13. import android.view.LayoutInflater;
  14. import android.view.Menu;
  15. import android.view.View;
  16. import android.view.View.OnClickListener;
  17. import android.view.ViewGroup;
  18. import android.widget.Button;
  19. public class ViewPagerDemo extends Activity {
  20. private View view1, view2, view3;//需要滑动的页卡
  21. private ViewPager viewPager;//viewpager
  22. private PagerTitleStrip pagerTitleStrip;//viewpager的标题
  23. private PagerTabStrip pagerTabStrip;//一个viewpager的指示器,效果就是一个横的粗的下划线
  24. private List viewList;//把需要滑动的页卡添加到这个list中
  25. private List titleList;//viewpager的标题
  26. private Button weibo_button;//button对象,一会用来进入第二个Viewpager的示例
  27. private Intent intent;
  28. @Override
  29. public void onCreate(Bundle savedInstanceState) {
  30. super.onCreate(savedInstanceState);
  31. setContentView(R.layout.activity_view_pager_demo);
  32. initView();
  33. }
  34. view1 = findViewById(R.layout.layout1);
  35. view2 = findViewById(R.layout.layout2);
  36. view3 = findViewById(R.layout.layout3);
  37. LayoutInflater lf = getLayoutInflater().from(this);
  38. view1 = lf.inflate(R.layout.layout1, null);
  39. view2 = lf.inflate(R.layout.layout2, null);
  40. view3 = lf.inflate(R.layout.layout3, null);
  41. viewList = new ArrayList();// 将要分页显示的View装入数组中
  42. viewList.add(view1);
  43. viewList.add(view2);
  44. viewList.add(view3);
  45. titleList = new ArrayList();// 每个页面的Title数据
  46. titleList.add("wp");
  47. titleList.add("jy");
  48. titleList.add("jh");
  49. PagerAdapter pagerAdapter = new PagerAdapter() {
  50. @Override
  51. public boolean isViewFromObject(View arg0, Object arg1) {
  52. return arg0 == arg1;
  53. }
  54. @Override
  55. public int getCount() {
  56. return viewList.size();
  57. }
  58. @Override
  59. public void destroyItem(ViewGroup container, int position,
  60. Object object) {
  61. container.removeView(viewList.get(position));
  62. }
  63. @Override
  64. public int getItemPosition(Object object) {
  65. return super.getItemPosition(object);
  66. }
  67. @Override
  68. public CharSequence getPageTitle(int position) {
  69. return titleList.get(position);//直接用适配器来完成标题的显示,所以从上面可以看到,我们没有使用PagerTitleStrip。当然你可以使用。
  70. }
  71. @Override
  72. public Object instantiateItem(ViewGroup container, int position) {
  73. container.addView(viewList.get(position));
  74. weibo_button=(Button) findViewById(R.id.button1);//这个需要注意,我们是在重写adapter里面实例化button组件的,如果你在onCreate()方法里这样做会报错的。
  75. weibo_button.setOnClickListener(new OnClickListener() {
  76. public void onClick(View v) {
  77. intent=new Intent(ViewPagerDemo.this,WeiBoActivity.class);
  78. startActivity(intent);
  79. }
  80. });
  81. return viewList.get(position);
  82. }
  83. };
  84. viewPager.setAdapter(pagerAdapter);
  85. }
  86. @Override
  87. public boolean onCreateOptionsMenu(Menu menu) {
  88. getMenuInflater().inflate(R.menu.activity_view_pager_demo, menu);
  89. return true;
  90. }
  91. }
  它的布局文件:

[java] view plaincopy

 
 

转自:http://blog.sina.com.cn/s/blog_6933d7330101ae9g.html

Android ViewPager使用详解(转)的更多相关文章

  1. Android ViewPager使用详解

    这是谷歌官方给我们提供的一个兼容低版本安卓设备的软件包,里面包囊了只有在安卓3.0以上可以使用的api.而viewpager就是其中之一利用它,我们可以做很多事情,从最简单的导航,到页面菜单等等.那如 ...

  2. 【Android 界面效果21】Android ViewPager使用详解

    这是谷歌官方给我们提供的一个兼容低版本安卓设备的软件包,里面包囊了只有在安卓3.0以上可以使用的api.而viewpager就是其中之一利用它,我们可以做很多事情,从最简单的导航,到页面菜单等等.那如 ...

  3. Android 自定义 View 详解

    View 的绘制系列文章: Android View 绘制流程之 DecorView 与 ViewRootImpl Android View 的绘制流程之 Measure 过程详解 (一) Andro ...

  4. android:ToolBar详解

    android:ToolBar详解(手把手教程) 泡在网上的日子 发表于 2014-11-18 12:49 第 124857 次阅读 ToolBar 42 来源 http://blog.mosil.b ...

  5. Android之canvas详解

    首先说一下canvas类: Class Overview The Canvas class holds the "draw" calls. To draw something, y ...

  6. 【转】Android Canvas绘图详解(图文)

    转自:http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2012/1212/703.html Android Canvas绘图详解(图文) 泡 ...

  7. Android 核心分析 之八Android 启动过程详解

    Android 启动过程详解 Android从Linux系统启动有4个步骤: (1) init进程启动 (2) Native服务启动 (3) System Server,Android服务启动 (4) ...

  8. Android GLSurfaceView用法详解(二)

    输入如何处理       若是开发一个交互型的应用(如游戏),通常需要子类化 GLSurfaceView,由此可以获取输入事件.下面有个例子: java代码: package eoe.ClearTes ...

  9. Android编译过程详解(一)

    Android编译过程详解(一) 注:本文转载自Android编译过程详解(一):http://www.cnblogs.com/mr-raptor/archive/2012/06/07/2540359 ...

随机推荐

  1. jQuery数组($.each,$.grep,$.map,$.merge,$.inArray,$.unique,$.makeArray)处理函数详解

    1. $.each(array, [callback]) 遍历[常用] 解释: 不同于例遍jQuery对象的$().each()方法,此方法可用于例遍任何对象.回调函数拥有两个参数:第一个为对象的成员 ...

  2. Portal

    https://chenliang0571.wordpress.com/2013/12/08/openwrt-wifidog-wifi-hotspots/http://www.h3c.com.cn/M ...

  3. hdu4117

    题意:给出一串单词,每个有一个权值.顺序不变的情况下,删掉一些,使得相邻两单词,前一个是后一个的子串.同时要求使得剩余单词权值和最大.求最大是多少. 分析: AC自动机+线段树+DP. 这是一个比较复 ...

  4. javascript 导出Excel

    测试兼容IE google 火狐浏览器.看到的朋友也许你某一天也会需要. //obj是table表格外面嵌套div id function saveCode(obj) { try { var strH ...

  5. string literals may have at most 255 elements

    一行中的字符超出 255 时候发生这个错误 解决方式: 一行的字符串分成两行 并 + 连接 **** 将字符串分成两个用"+"连接起来

  6. html 中绑定事件 this的指向

    var m=function(){ alert(2);    }    var obj={        A:function(){        },        m:function(){    ...

  7. window.location.href url含中文服务器收到乱码问题解决

    中文乱码问题 window.location.href url含中文服务器收到乱码问题解决 (1).页面中先对中文进行编码. 如:window.location.href = url+"&a ...

  8. 如何获得images.xcassets 中图片的路径?

    UIImage加载图片的方式以及Images.xcassets对于加载方法的影响 重点: Images.xcassets中的图片资源只能通过imageNamed:方法加载,通过NSBundle的pat ...

  9. yii 多模板

    main.php: //替换所有模板 //加载文件名为first的模板 //       'theme'=>'theme1', 'components'=>array(           ...

  10. UVa815_Flooded!

    #include <iostream> //#include <fstream> #include <iomanip> #include <cstdio> ...