由Fragment搭建起来的动态UI

本文通过ViewPager和FragmentPageAdapter实现滑动切换页面的效果。解释了ViewPager作为页面切换组件的工作原理,包括其缓存机制,并详细介绍了PagerAdapter的相关重写方法。同时,展示了项目的工程目录结构和部分关键代码,最后提供了实现效果的预览。
摘要由CSDN通过智能技术生成

本节引言:

本节我们将会实现ViewPager来实现滑动切换页面的效果!

大部分朋友都知道这个ViewPager是什么东西吧,如果 
不知道没关系,下面我们简单的来介绍一个这个控件!


1.ViewPager简单介绍


1)是怎么样的一个控件?

答:一个页面切换的组件,我们可以往里面填充多个View,然后我们可以通过触摸屏幕左右滑动 
切换不同的View,和前面学习的ListView一样,我们需要一个Adapter(适配器),将要显示的View和 
我们的ViewPager进行绑定,而ViewPager有他自己特定的Adapter——PagerAdapter!另外,Google 
官方是建议我们使用Fragment来填充ViewPager的,这样可以更加方便的生成每个Page以及管理 
每个Page的生命周期!当然它给我们提供了两个不同的Adapter,他们分别是: 
FragmentPageAdapterFragmentStatePagerAdapter! 
而我们本节用到的则是前者:FragmentPageAdapter! 
另外要说一点的是ViewPager的缓存机制: 
ViewPager会缓存当前页,前一页,以及后一页,比如有1,2,3,4这四个页面: 
当我们处于第一页:缓存1,2 
——> 处于第二页:缓存 1,2,3 
——> 处于第三页:缓存2,3,4 
——> 处于第四页缓存3,4这样!

2)使用PagerAdapter要重写相关方法:

  • getCount( ):获得viewpager中有多少个view
  • destroyItem( ):移除一个给定位置的页面。适配器有责任从容器中删除这个视图。这是为了确保 
    在finishUpdate(viewGroup)返回时视图能够被移除。
  • instantiateItem( ):①将给定位置的view添加到ViewGroup(容器)中,创建并显示出来 
    ②返回一个代表新增页面的Object(key),通常都是直接返回view本身就可以了, 
    当然你也可以自定义自己的key,但是key和每个view要一一对应的关系
  • isViewFromObject( ):判断instantiateItem(ViewGroup, int)函数所返回来的Key与一个页面视图是否是 <
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值