前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Android开发之ViewPager简单使用

Android开发之ViewPager简单使用

作者头像
YungFan
发布2018-04-24 15:01:05
7570
发布2018-04-24 15:01:05
举报
文章被收录于专栏:学海无涯学海无涯
什么是ViewPager?

ViewPager(android.support.v4.view.ViewPager)是android扩展包v4包中的类,这个类可以让用户左右切换当前的view,实现滑动切换的效果,在使用这个类之前,必须明白:

  • ViewPager类直接继承了ViewGroup类,也就是说它和我们经常打交道的LinearLayout一样,都是一个容器,需要在里面添加我们想要显示的内容。
  • ViewPager类需要一个PagerAdapter适配器类给它提供数据,这个和ListView类似。
使用步骤
  • 1.在布局文件里加入
代码语言:javascript
复制
<android.support.v4.view.ViewPager 
     android:id="@+id/viewpager"     
     android:layout_width="wrap_content"    
     android:layout_height="wrap_content"   
     android:layout_gravity="center" >  
 </android.support.v4.view.ViewPager>
  • 2.加载要显示的Views,通过动态加载布局得到一个个View
代码语言:javascript
复制
LayoutInflater lf = getLayoutInflater().from(MainActivity.this);    
View view1 = lf.inflate(R.layout.f1, null);
View view2 = lf.inflate(R.layout.f2, null);
View view3 = lf.inflate(R.layout.f3, null);
viewContainter  = new ArrayList<View>();// 将要分页显示的View装入数组中          
viewContainter .add(view1); 
viewContainter .add(view2);
viewContainter .add(view3);
  • 3.用PagerAdapter关联上面的View和ViewPager
代码语言:javascript
复制
//直接继承PagerAdapter,至少必须重写下面的四个方法,否则会报错
pager.setAdapter(new PagerAdapter()
        {

            // viewpager中的要显示的View的总数量
            @Override
            public int getCount()
            {
                return viewContainter.size();
            }

            // 滑动切换的时候销毁当前的View
            @Override
            public void destroyItem(ViewGroup container, int position,
                    Object object)
            {
                container.removeView(viewContainter.get(position));
            }

            // 每次滑动的时候生成的View
            @Override
            public Object instantiateItem(ViewGroup container, int position)
            {
                    container.addView(viewContainter.get(position));
                return viewContainter.get(position);
            }
           // 官方建议这样写
            @Override
            public boolean isViewFromObject(View arg0, Object arg1)
            {
                return arg0 == arg1;
            }
        });

这样就可以实现滑动效果了

适合场景
  • 引导页
  • 页卡滑动(如网易新闻)
One more thing

官方建议ViewPager配合Fragment使用,后面会继续补上~~~

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2016.03.29 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 什么是ViewPager?
  • 使用步骤
  • 适合场景
  • One more thing
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档