温馨提示:这篇文章已超过437天没有更新,请注意相关的内容是否还可用!
摘要:,,本文简要介绍了 Android 开发中 ViewPager 的使用方法。ViewPager 是一种滑动页面控件,能够方便地实现页面间的滑动切换。本文内容包括 ViewPager 的基本特性、如何将其添加到项目中、配置页面适配器以及处理页面滑动事件。通过本文,开发者可以快速了解并应用 ViewPager,提升 Android 应用的用户体验。
在Android 3.0之后,Android系统引入了一个名为ViewPager的UI控件,ViewPager是一个简单的页面切换组件,我们可以往里面填充多个View,然后通过左右滑动来切换不同的View,我们可以通过ViewPager的setPageTransformer方法为ViewPager设置切换时的动画效果,我们也介绍了如何使用ViewPager来实现APP的引导页或者图片轮播的功能,因为ViewPager是在Android 3.0后引入的,如果在低版本下使用,需要引入v4兼容包,我们将详细学习这个控件的基本用法。
ViewPager的简单介绍
ViewPager就是一个简单的页面切换组件,我们可以往里面填充多个View,然后左右滑动从而切换不同的View,我们可以通过适配器(Adapter)将我们的View和ViewPager进行绑定,而ViewPager则有一个特定的适配器——PagerAdapter,Google官方建议我们使用Fragment来填充ViewPager,这样可以更加方便的生成每个Page,以及管理每个Page的生命周期。
我们简要地分析两个常用的适配器:FragmentPageAdapter和FragmentStatePagerAdapter。
FragmentPageAdapter这种适配器只会缓存当前的Fragment以及左边和右边的Fragment,总共会缓存3个Fragment,当处于某页面时,会缓存相邻的两个页面。
FragmentStatePagerAdapter当Fragment对用户不可见时,整个Fragment会被销毁,只会保存Fragment的状态,当页面需要重新显示时,会生成新的页面。
PagerAdapter的使用
我们先来介绍最普通的PagerAdapter,如果想使用这个PagerAdapter需要重写下面的四个方法,这只是官方建议,实际上我们只需重写getCount()和isViewFromObject()就可以了。
getCount(): 获得viewpager中有多少个view。
destroyItem(): 移除一个给定位置的页面,适配器负责从容器中删除这个视图,这是为了确保在finishUpdate(viewGroup)返回时视图能够被移除。
另外两个方法则是涉及到一个key的东西:
instantiateItem(): ①将给定位置的view添加到ViewGroup(容器)中,创建并显示出来。②返回一个代表新增页面的Object(key),通常都是直接返回view本身就可以了,当然你也可以自定义自己的key,但是key和每个view要一一对应的关系。
isViewFromObject(): 判断instantiateItem(ViewGroup, int)函数所返回来的Key与一个页面视图是否是代表的同一个视图(即它们是否是对应的,对应的表示同一个View)。
使用示例1:最简单用法
运行效果图:
(这里插入图片)
关键部分代码:
是每个View的布局,这里提供三个布局文件:view_one.xml、view_two.xml和view_three.xml。
编写一个自定义的PagerAdapter:MyPagerAdapter.java。
在Activity中,和之前学的ListView一样,我们需要一个容器来显示ViewPager,以及一个ViewPager对象来管理滑动事件,OneActivity.java中包含了具体的实现代码。
就是跟随着ViewPager滑动而滑动的标题啦,这两个是官方提供的,一个是普通文字,一个是带有下划线,以及可以点击文字切换页面,下面我们来写个简单的例子~
运行效果图:
(这里插入图片)
关键代码实现:这部分主要是布局文件和Activity文件的实现,其中PagerTitleStrip所在Activity的布局为activity_two.xml,而PagerTabStrip所在的布局为activity_three.xml,接着编写自定义的PagerAdapter(MyPagerAdapter2.java),最后TwoActivity.java中包含了具体的实现代码。
使用示例3:ViewPager实现TabHost的效果:
运行效果图: (这里插入图片) 顶部是一个LinearLayout包含三个TextView,下面是一个滑动的ImageView和我们的ViewPager,实现逻辑解析:首先我们需要让移动块在第一个文字下居中,计算偏移量,然后我们在ViewPager上添加一个OnPageChangeListener事件来监听页面的滑动事件并进行相应的处理,具体的实现逻辑和代码可以参考FourActivity.java文件。
还没有评论,来说两句吧...