因为viewpager是在support-v4包下面的,所以需要找到这个类然后复制它的名字后在布局文件中添加viewpager的布局:
<android.support.v4.view.ViewPager
android:layout_height="fill_parent"
android:layout_width="fill_parent"
android:id="@+id/vp_guide"
>
</android.support.v4.view.ViewPager>
首先初始化viewpager的控件:
ViewPager mViewPager = (ViewPager) findViewById(R.id.vp_guide);
viewpager中加载数据就要用到了adapter,而viewpager中的adapter是继承PagerAdapter的。所以需要自定义adapter:
GuidePagerAdpter mAdpter = new GuidePagerAdpter();
mViewPager.setAdapter(mAdpter);
这里的GuidePagerAdpter就是自定义的adapter,继承于PagerAdapter:
class GuidePagerAdpter extends PagerAdapter{
@Override
public int getCount() {
return imageViewList.size();
}
@Override
public boolean isViewFromObject(View arg0, Object arg1) {
return arg0 == arg1;
}
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
container.removeView((View)object);
}
@Override
public Object instantiateItem(ViewGroup container, int position) {
//向ViewPager中添加一个ImageView
ImageView iv = imageViewList.get(position);
container.addView(iv);
//把添加的ImageView返回回去
return iv;
}
}
这样简单地viewpager加载数据就实现了。但是viewpager本身就有一个特点,就是会预加载第二个页面的数据,从某方面来说这会浪费用户的流量。所以有时候需要我们来优化:
mViewPager.setOnPageChangeListener(this);
这里我们可以监听viewpager的页面改变状态,从而在选中页面的时候选择加载数据,而不是在当前页面的。这样的话我们需要当前类引用一个接口OnPageChangeListener,这样的话会提供三个方法。因此我们只需要在选中的页面加载数据就可以了。
@Override
public void onPageScrollStateChanged(int arg0) {
// TODO Auto-generated method stub
}
@Override
public void onPageScrolled(int arg0, float arg1, int arg2) {
// TODO Auto-generated method stub
}
/**
* 当页面被选中是触发此方法,position就是当前的页面索引
*/
@Override
public void onPageSelected(int arg0) {
pagerList.get(arg0).initData();//把当前选中的页面的数据加载了
}
21万+

被折叠的 条评论
为什么被折叠?



