创业投资公司网站建设安徽省交通运输厅网站
2026/3/29 18:43:16 网站建设 项目流程
创业投资公司网站建设,安徽省交通运输厅网站,页面设计结构的特色,上海装饰公司网站建设2.6.3 ViewPager的简单使用 分类 Android 基础入门教程 本节引言#xff1a; 本节带来的是Android 3.0后引入的一个UI控件——ViewPager(视图滑动切换工具)#xff0c;实在想不到 如何来称呼这个控件#xff0c;他的大概功能#xff1a;通过手势滑动可以完成View的切换本节带来的是Android 3.0后引入的一个UI控件——ViewPager(视图滑动切换工具)实在想不到 如何来称呼这个控件他的大概功能通过手势滑动可以完成View的切换一般是用来做APP 的引导页或者实现图片轮播因为是3.0后引入的如果想在低版本下使用就需要引入v4 兼容包哦~我们也可以看到ViewPager在android.support.v4.view.ViewPager目录下~ 下面我们就来学习一下这个控件的基本用法~ 官方API文档ViewPager1.ViewPager的简单介绍ViewPager就是一个简单的页面切换组件我们可以往里面填充多个View然后我们可以左 右滑动从而切换不同的View我们可以通过setPageTransformer()方法为我们的ViewPager 设置切换时的动画效果当然动画我们还没学到所以我们把为ViewPager设置动画 放到下一章绘图与动画来讲解和前面学的ListViewGridView一样我们也需要一个Adapter (适配器)将我们的View和ViewPager进行绑定而ViewPager则有一个特定的Adapter——PagerAdapter另外Google官方是建议我们使用Fragment来填充ViewPager的这样 可以更加方便的生成每个Page以及管理每个Page的生命周期给我们提供了两个Fragment 专用的AdapterFragmentPageAdapter和FragmentStatePagerAdapter我们简要的来分析下这两个Adapter的区别FragmentPageAdapter和PagerAdapter一样只会缓存当前的Fragment以及左边一个右边 一个即总共会缓存3个Fragment而已假如有1234四个页面处于1页面缓存12处于2页面缓存123处于3页面销毁1页面缓存234处于4页面销毁2页面缓存34更多页面的情况依次类推~FragmentStatePagerAdapter当Fragment对用户不 见得时整个Fragment会被销毁 只会保存Fragment的状态而在页面需要重新显示的时候会生成新的页面综上FragmentPageAdapter适合固定的页面较少的场合而FragmentStatePagerAdapter则适合 于页面较多或者页面内容非常复杂(需占用大量内存)的情况2.PagerAdapter的使用我们先来介绍最普通的PagerAdapter如果想使用这个PagerAdapter需要重写下面的四个方法 当然这只是官方建议实际上我们只需重写getCount()和isViewFromObject()就可以了~getCount():获得viewpager中有多少个viewdestroyItem():移除一个给定位置的页面。适配器有责任从容器中删除这个视图。 这是为了确保在finishUpdate(viewGroup)返回时视图能够被移除。而另外两个方法则是涉及到一个key的东东instantiateItem(): ①将给定位置的view添加到ViewGroup(容器)中,创建并显示出来 ②返回一个代表新增页面的Object(key),通常都是直接返回view本身就可以了,当然你也可以 自定义自己的key,但是key和每个view要一一对应的关系isViewFromObject(): 判断instantiateItem(ViewGroup, int)函数所返回来的Key与一个页面视图是否是 代表的同一个视图(即它俩是否是对应的对应的表示同一个View),通常我们直接写 return view object!使用示例1最简单用法运行效果图关键部分代码好的代码写起来也是非常简单的首先是每个View的布局一式三份另外两个View一样view_one.xml?xml version1.0 encodingutf-8? LinearLayout xmlns:androidhttp://schemas.android.com/apk/res/android android:layout_widthmatch_parent android:layout_heightmatch_parent android:background#FFBA55 android:gravitycenter android:orientationvertical TextView android:layout_widthwrap_content android:layout_heightwrap_content android:text第一个Page android:textColor#000000 android:textSize18sp android:textStylebold / /LinearLayout然后编写一个自定义个的PagerAdapterMyPagerAdapter.javapublic class MyPagerAdapter extends PagerAdapter { private ArrayListView viewLists; public MyPagerAdapter() { } public MyPagerAdapter(ArrayListView viewLists) { super(); this.viewLists viewLists; } Override public int getCount() { return viewLists.size(); } Override public boolean isViewFromObject(View view, Object object) { return view object; } Override public Object instantiateItem(ViewGroup container, int position) { container.addView(viewLists.get(position)); return viewLists.get(position); } Override public void destroyItem(ViewGroup container, int position, Object object) { container.removeView(viewLists.get(position)); } }接着到Activity了和以前学的ListView非常类似OneActivity.javapublic class OneActivity extends AppCompatActivity{ private ViewPager vpager_one; private ArrayListView aList; private MyPagerAdapter mAdapter; Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_one); vpager_one (ViewPager) findViewById(R.id.vpager_one); aList new ArrayListView(); LayoutInflater li getLayoutInflater(); aList.add(li.inflate(R.layout.view_one,null,false)); aList.add(li.inflate(R.layout.view_two,null,false)); aList.add(li.inflate(R.layout.view_three,null,false)); mAdapter new MyPagerAdapter(aList); vpager_one.setAdapter(mAdapter); } }好的关键代码就上述部分非常容易理解~使用示例2标题栏——PagerTitleStrip与PagerTabStrip就是跟随着ViewPager滑动而滑动的标题咯这两个是官方提供的一个是普通文字 一个是带有下划线以及可以点击文字可切换页面下面我们来写个简单的例子~运行效果图关键代码实现这里两者的区别仅仅是布局不一样而已其他的都一样PagerTitleStrip所在Activtiy的布局activity_two.xmlLinearLayout xmlns:androidhttp://schemas.android.com/apk/res/android android:layout_widthmatch_parent android:layout_heightmatch_parent android:orientationvertical TextView android:layout_widthmatch_parent android:layout_height48dp android:background#CCFF99 android:gravitycenter android:textPagerTitleStrip效果演示 android:textColor#000000 android:textSize18sp / android.support.v4.view.ViewPager android:idid/vpager_two android:layout_widthwrap_content android:layout_heightwrap_content android:layout_gravitycenter android.support.v4.view.PagerTitleStrip android:idid/pagertitle android:layout_widthwrap_content android:layout_height40dp android:layout_gravitytop android:textColor#FFFFFF / /android.support.v4.view.ViewPager /LinearLayout而PagerTabStrip所在的布局activity_three.xmlLinearLayout xmlns:androidhttp://schemas.android.com/apk/res/android android:layout_widthmatch_parent android:layout_heightmatch_parent android:orientationvertical TextView android:layout_widthmatch_parent android:layout_height35dp android:background#C0C080 android:gravitycenter android:textPagerTabStrip效果演示 android:textSize18sp / android.support.v4.view.ViewPager android:idid/vpager_three android:layout_widthwrap_content android:layout_heightwrap_content android:layout_gravitycenter android.support.v4.view.PagerTabStrip android:idid/pagertitle android:layout_widthwrap_content android:layout_heightwrap_content android:layout_gravitytop / /android.support.v4.view.ViewPager /LinearLayout接下来的两者都一样了我们先来编写一个自定义的PagerAdapter除了前面重写的 四个方法外我们需要另外重写一个方法getPageTitle()这个设置标题的~ 代码如下MyPagerAdapter2.java/** * Created by Jay on 2015/10/8 0008. */ public class MyPagerAdapter2 extends PagerAdapter { private ArrayListView viewLists; private ArrayListString titleLists; public MyPagerAdapter2() {} public MyPagerAdapter2(ArrayListView viewLists,ArrayListString titleLists) { this.viewLists viewLists; this.titleLists titleLists; } Override public int getCount() { return viewLists.size(); } Override public boolean isViewFromObject(View view, Object object) { return view object; } Override public Object instantiateItem(ViewGroup container, int position) { container.addView(viewLists.get(position)); return viewLists.get(position); } Override public void destroyItem(ViewGroup container, int position, Object object) { container.removeView(viewLists.get(position)); } Override public CharSequence getPageTitle(int position) { return titleLists.get(position); } }最后是Activity部分两个都是一样的TwoActivity.java/** * Created by Jay on 2015/10/8 0008. */ public class TwoActivity extends AppCompatActivity { private ViewPager vpager_two; private ArrayListView aList; private ArrayListString sList; private MyPagerAdapter2 mAdapter; Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_two); vpager_two (ViewPager) findViewById(R.id.vpager_two); aList new ArrayListView(); LayoutInflater li getLayoutInflater(); aList.add(li.inflate(R.layout.view_one,null,false)); aList.add(li.inflate(R.layout.view_two,null,false)); aList.add(li.inflate(R.layout.view_three, null, false)); sList new ArrayListString(); sList.add(橘黄); sList.add(淡黄); sList.add(浅棕); mAdapter new MyPagerAdapter2(aList,sList); vpager_two.setAdapter(mAdapter); } }好了非常简单有疑问的话自己下demo看看就懂了~使用示例3ViewPager实现TabHost的效果当然示例2很多时候只是中看不中用实际开发中我们可能需要自行定制这个标题栏 下面我们就来写个简单的例子来实现TabHost的效果如果你不知道TabHost是什么鬼的 话那么请看效果图运行效果图实现逻辑解析下面我们来讲解下实现上述效果的逻辑然后贴代码首先是布局顶部一个LinearLayout包着三个TextViewweight属性都为1然后下面跟着 一个滑块的ImageView我们设置宽度为match_parent最底下是我们的ViewPager这里可能 有两个属性你并不认识一个是flipInterval这个是指定View动画间的时间间隔的而persistentDrawingCache则是设置控件的绘制缓存策略可选值有四个none不在内存中保存绘图缓存animation:只保存动画绘图缓存scrolling只保存滚动效果绘图缓存all所有的绘图缓存都应该保存在内存中可以同时用2个animation|scrolling这样~布局代码activity_four.xmlLinearLayout xmlns:androidhttp://schemas.android.com/apk/res/android xmlns:toolshttp://schemas.android.com/tools android:idid/LinearLayout1 android:layout_widthmatch_parent android:layout_heightmatch_parent android:orientationvertical tools:context.MainActivity LinearLayout android:layout_widthfill_parent android:layout_height48dp android:background#FFFFFF TextView android:idid/tv_one android:layout_widthfill_parent android:layout_heightfill_parent android:layout_weight1.0 android:gravitycenter android:text橘黄 android:textColor#000000 / TextView android:idid/tv_two android:layout_widthfill_parent android:layout_heightfill_parent android:layout_weight1.0 android:gravitycenter android:text淡黄 android:textColor#000000 / TextView android:idid/tv_three android:layout_widthfill_parent android:layout_heightfill_parent android:layout_weight1.0 android:gravitycenter android:text浅棕 android:textColor#000000 / /LinearLayout ImageView android:idid/img_cursor android:layout_widthfill_parent android:layout_heightwrap_content android:scaleTypematrix android:srcmipmap/line / android.support.v4.view.ViewPager android:idid/vpager_four android:layout_widthwrap_content android:layout_height0dp android:layout_gravitycenter android:layout_weight1.0 android:flipInterval30 android:persistentDrawingCacheanimation / /LinearLayout接着到我们的Activity了我们来捋下思路Step 1我们需要让我们的移动块在第一个文字下居中那这里就要算一下偏移量 先获得图片宽度pw然后获取屏幕宽度sw计算方法很简单offset(偏移量) ((sw / 3)-pw) / 2//屏幕宽/3 - 图片宽度然后再除以2左右嘛然后我么你调用setImageMatrix设置滑块当前的位置同时我们也把切换一页和两页滑块的移动距离也算出来很简单one offset * 2 pw;two one * 2;Step 2当我们滑动页面时我们的滑块要进行移动我们要为ViewPager添加一个 OnPageChangeListener事件我们需要对滑动后的页面来做一个判断同时记录滑动前处于 哪个页面下面自己画了个图可能更容易理解吧PS:太久没写字字很丑能看清就好字丑人美哈哈~嗯如果还是不能理解的话自己动手画画图就知道了下面上代码FourActvitiy.java/** * Created by Jay on 2015/10/8 0008. */ public class FourActivity extends AppCompatActivity implements View.OnClickListener, ViewPager.OnPageChangeListener { private ViewPager vpager_four; private ImageView img_cursor; private TextView tv_one; private TextView tv_two; private TextView tv_three; private ArrayListView listViews; private int offset 0;//移动条图片的偏移量 private int currIndex 0;//当前页面的编号 private int bmpWidth;// 移动条图片的长度 private int one 0; //移动条滑动一页的距离 private int two 0; //滑动条移动两页的距离 Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_four); initViews(); } private void initViews() { vpager_four (ViewPager) findViewById(R.id.vpager_four); tv_one (TextView) findViewById(R.id.tv_one); tv_two (TextView) findViewById(R.id.tv_two); tv_three (TextView) findViewById(R.id.tv_three); img_cursor (ImageView) findViewById(R.id.img_cursor); //下划线动画的相关设置 bmpWidth BitmapFactory.decodeResource(getResources(), R.mipmap.line).getWidth();// 获取图片宽度 DisplayMetrics dm new DisplayMetrics(); getWindowManager().getDefaultDisplay().getMetrics(dm); int screenW dm.widthPixels;// 获取分辨率宽度 offset (screenW / 3 - bmpWidth) / 2;// 计算偏移量 Matrix matrix new Matrix(); matrix.postTranslate(offset, 0); img_cursor.setImageMatrix(matrix);// 设置动画初始位置 //移动的距离 one offset * 2 bmpWidth;// 移动一页的偏移量,比如1-2,或者2-3 two one * 2;// 移动两页的偏移量,比如1直接跳3 //往ViewPager填充View同时设置点击事件与页面切换事件 listViews new ArrayListView(); LayoutInflater mInflater getLayoutInflater(); listViews.add(mInflater.inflate(R.layout.view_one, null, false)); listViews.add(mInflater.inflate(R.layout.view_two, null, false)); listViews.add(mInflater.inflate(R.layout.view_three, null, false)); vpager_four.setAdapter(new MyPagerAdapter(listViews)); vpager_four.setCurrentItem(0); //设置ViewPager当前页从0开始算 tv_one.setOnClickListener(this); tv_two.setOnClickListener(this); tv_three.setOnClickListener(this); vpager_four.addOnPageChangeListener(this); } Override public void onClick(View v) { switch (v.getId()) { case R.id.tv_one: vpager_four.setCurrentItem(0); break; case R.id.tv_two: vpager_four.setCurrentItem(1); break; case R.id.tv_three: vpager_four.setCurrentItem(2); break; } } Override public void onPageSelected(int index) { Animation animation null; switch (index) { case 0: if (currIndex 1) { animation new TranslateAnimation(one, 0, 0, 0); } else if (currIndex 2) { animation new TranslateAnimation(two, 0, 0, 0); } break; case 1: if (currIndex 0) { animation new TranslateAnimation(offset, one, 0, 0); } else if (currIndex 2) { animation new TranslateAnimation(two, one, 0, 0); } break; case 2: if (currIndex 0) { animation new TranslateAnimation(offset, two, 0, 0); } else if (currIndex 1) { animation new TranslateAnimation(one, two, 0, 0); } break; } currIndex index; animation.setFillAfter(true);// true表示图片停在动画结束位置 animation.setDuration(300); //设置动画时间为300毫秒 img_cursor.startAnimation(animation);//开始动画 } Override public void onPageScrollStateChanged(int i) { } Override public void onPageScrolled(int i, float v, int i1) { } }嗯关于动画可能你并不熟悉没事下一章我们带大家一起扣~3.ViewPager结合Fragment示例嗯在前面讲解Fragment的时候我们就讲解了一个使用示例 Android基础入门教程——5.2.4 Fragment实例精讲——底部导航栏ViewPager滑动切换页面 这里就不再详述了有兴趣的点下链接看看即可~4.代码示例下载ViewPagerDemo.zip本节小结关于ViewPager限于篇幅有些地方并没有讲到其他的大家需要自己查阅文档了~另外上面也说了ViewPager的动画我们会在下一章讲解好的就说这么多~嗯国庆前曾说会在国庆假期里完成整个系列结果一篇都没写实在抱歉... 因为妹子过来玩了So你懂的~会加快进度~争取早日进阶

需要专业的网站建设服务?

联系我们获取免费的网站建设咨询和方案报价,让我们帮助您实现业务目标

立即咨询