ViewPager入门

来源:互联网 发布:mkwebview Js交互 编辑:程序博客网 时间:2024/06/04 18:24

因为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();//把当前选中的页面的数据加载了    }
0 0
原创粉丝点击