大家好,相信大家用的ListView控件一定很多的,是竖向滑动的,复用convertView,我们可以加载成千上万的数据,但有时候我们会有 这个需求比如相册,我们想横向滑动,并且数据有好多,这时候ViewPager控件就派上用场了,ViewPager使用时候我们需要导入第三方包 android-support-v4.jar包,这是谷歌提供的,这个包里有Fragment ViewPager等控件,用户导入这个包,在3.0以前就可以使用Fragment控件了~
下面就开始讲下ViewPager的用 法,ViewPager和ViewFlipper用法类似,但是更好用,左右滑动效果好,而且有类似于ListView的Adapter--- PagerAdapter基类,这样的话可以回收内存,复用等。PagerAdapter的几个方法里常用的有:
- void destroyItem(View container, int position, Object object)
-
- 这里是左右滑动的时候,回收较早前的itemView.
- int getCount()
- ViewPager里显示内容的条数.
- Object instantiateItem(View container, int position)
- 始化ItemView.
为 了让大家容易掌握,我写了一个简单的例子,简单实现相册横向滑动功能,首先自定义了ViewPager的itemView---- ViewPagerItemView,这里做了初始化View的定义,以及回收内存重新加载等,数据源是JSONObject.其次是实现了 PagerAdapter的适配器ViewPagerAdater,这里的数据源是JSONArray.然后ViewPager在名为 ViewPagerDemoActivity.java的Activity里显示。下面是具体实现步骤:
第一步:新建一个Android工程ViewPagerDemoActivity,目录结构如下图所示:
第二步:新建一个ViewPagerItemView.java这里是相册的ItemView,代码如下:
其中ViewPagerItemView使用的xml文件viewpager_itemView.xml代码如下:
- <?xml version="1.0" encoding="utf-8"?>
- <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- >
-
- <ImageView
- android:id="@+id/album_imgview"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- android:contentDescription="@string/app_name"
- android:scaleType="fitXY"
- />
-
- <TextView
- android:id="@+id/album_name"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:layout_gravity="bottom|center_horizontal"
- android:textColor="#B2191919"
- />
- </FrameLayout>
第三步:新建一个ViewPagerAdapter.java继承与PagerAdapter,代码如下:
第四步:修改主Activity类ViewPagerDemoActivity.java代码如下:
- package com.tutor.viewpager;
-
- import org.json.JSONArray;
- import org.json.JSONException;
- import org.json.JSONObject;
-
- import android.app.Activity;
- import android.os.Bundle;
- import android.support.v4.view.ViewPager;
-
- public class ViewPagerDemoActivity extends Activity {
-
-
- private static final int ALBUM_COUNT = 100;
-
-
- private static final int ALBUM_RES[] = {
- R.drawable.test1,R.drawable.test2,R.drawable.test3,
- R.drawable.test4,R.drawable.test5,R.drawable.test6
- };
-
- private ViewPager mViewPager;
-
-
- private ViewPagerAdapter mViewPagerAdapter;
-
-
- private JSONArray mJsonArray;
-
-
- @Override
- public void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.main);
-
- setupViews();
- }
-
- private void setupViews(){
-
- mJsonArray = new JSONArray();
- for(int i = 0;i<ALBUM_COUNT; i++){
- JSONObject object = new JSONObject();
- try {
- object.put("resid", ALBUM_RES[i % ALBUM_RES.length]);
- object.put("name", "Album " + i);
- mJsonArray.put(object);
- } catch (JSONException e) {
- e.printStackTrace();
- }
-
- }
- mViewPager = (ViewPager)findViewById(R.id.viewpager);
- mViewPagerAdapter = new ViewPagerAdapter(this, mJsonArray);
- mViewPager.setAdapter(mViewPagerAdapter);
- }
- }
其中main.xml布局代码如下:
- <?xml version="1.0" encoding="utf-8"?>
- <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- android:orientation="vertical" >
-
- <android.support.v4.view.ViewPager
- android:id="@+id/viewpager"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- />
-
- </LinearLayout>
第五步运行查看效果:
运行效果1 运行效果2
OK,今天就写到这里,代码注释写的也比较清楚,大家有什么疑问的,可以留言!下面的链接是源代码,供新手们学习用,今天就讲到这里,谢谢大家!!!
源代码点击进入==>