知识的回顾:
ViewPager的作用:组要用来横向滑动 切换视图控件,用法和ListView非常的相似
---实现ViewPager的四大步.和ListView一样
1---实例化一个ViewPager对象
2--创建一个数据集合,集合中的元素为View类型
3--创建一个PagerAdapter适配器,并且实例化这个适配器
4--ViewPager对象绑定适配器,就可以实现导航页的左右滑动的效果
看了上面的讲解,接下来的就是代码的实现过程
--------------------------先写主Activity中的实现代码----------------------------
public class PagerActivity extends Activity
{
//声明一个ViewPager的对象
ViewPager viewpager;
//声明一个数据集合
List<View> list;
//声明一个适配器
MyPagerAdapter adapter;
View view1 =View.inflate(this, R.layout.pager_item, null);
View view2 =View.inflate(this, R.layout.pager_item, null);
list.add( view1);
list.add( view2);
}
----------------------------------------------------------------------------------------
下面的就是PagerActivity的布局属性
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.example.day8.PageActivity" >
<android.support.v4.view.ViewPager
android:id="@+id/pager_up"
android:layout_width="match_parent"
android:layout_height="match_parent" />
</RelativeLayout>
---------------------------------------------------------------
自定义适配器的代码实现
--------------------------------------------------------------
Public class MyPagerAdapter extends PagerAdapter
{
List(view) list;
public MyPagerAdaPter(List<View> list)
{
super();
this.list=list;
}
@Override
public Object instantiateItem(ViewGroup container, int position) {
//container就是ViewPager的对象实例,谁绑定了该Adapter的实例,那container就是谁
//让container添加我们数据集合中传过来的View对象
container.addView(list.get(position));
return list.get(position);
}
/***/
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
//从container中移除视图
container.removeView((View) object);
}
/**
*返回viewpager中需要显示数据的条数
**/
@Override
public int getCount() {
// TODO Auto-generated method stub
return list.size();
}
@Override
public boolean isViewFromObject(View arg0, Object arg1) {
// 谷歌推荐写法
return arg0==arg1;
}
}