前几天学习了ViewPager作为引导页和Tab的使用方法。后来也有根据不同的使用情况改用Fragment作为Tab的情况,以及ViewPager结合FragmentPagerAdapter的使用。今天学习一种利用开源控件ViewPagerIndicator实现Tab的方式,也是各种新闻客户端等APP开发最常用的。

1.如何使用开源框架

第1步:improt library项目

第2步:导入library进我们自己新建的项目

从Github上Download下来这个zip包之后,里面会有一个library文件,是库工程,还有一个sample,是作者提供的例子(将sample这个项目import,可以看到作者提供的各种样式的Indicator,作为参考)。如果要在作者例子的基础上自己开发样式,需要将library项目import进Eclipse(library是库工程,我们需要将其作为我们自己项目的依赖库)。然后创建一个新项目,新建的项目libs目录下面有android-support-v4.jar,这个必须删除,因为ViewPageIndicator里面有这个库,我们项目中不允许两个android-support-v4.jar,不删除我们的项目是不能编译的。右键项目—Properties—Android选项卡—Add—选择library库工程—OK,导入完毕。


2.MainActivity布局

布局中仅一个ViewPager,一个ViewPagerIndicator.(本例使用的是其中一种ViewPagerIndicator:TabPagerIndicator)

注意它应该紧邻在ViewPager的上方或下方,总之要挨在一起。

  1. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  2. xmlns:tools="http://schemas.android.com/tools"
  3. android:layout_width="match_parent"
  4. android:layout_height="match_parent"
  5. android:orientation="vertical" >
  6. <com.viewpagerindicator.TabPageIndicator
  7. android:id="@+id/indicator"
  8. android:layout_width="match_parent"
  9. android:layout_height="wrap_content"
  10. android:background="@drawable/base_action_bar_bg" >
  11. </com.viewpagerindicator.TabPageIndicator>
  12. <android.support.v4.view.ViewPager
  13. android:id="@+id/pager"
  14. android:layout_width="match_parent"
  15. android:layout_height="0dp"
  16. android:layout_weight="1" >
  17. </android.support.v4.view.ViewPager>
  18. </LinearLayout>

3.MainActivity代码

第1步:实例化ViewPager,给ViewPager设置Adapter

第2步:实例化TabPageIndicator,TabPageIndicator与ViewPager绑在一起

第3步:在Indicator上设置OnPagerChangeListner监听器

第4步:定义Adapter(继承FragmentPagerAdapter)

先实例化ViewPager,然后实例化TabPageIndicator,然后设置TabPageIndicator和ViewPager关联,就是调用TabPageIndicator的setViewPager(ViewPager view)方法,这样子就实现了点击上面的Tab,下面的ViewPager切换;滑动ViewPager,上面的Tab跟着切换。

ViewPager的每一个Item我们使用的是Fragment,使用Fragment可以使布局更加灵活一点,建议多用Fragment。

设置监听的时候,需要用Indicator提供的OnPagerChangeListener方法

  1. public class MainActivity extends FragmentActivity {
  2. /**
  3. * Tab标题
  4. */
  5. private static final String[] TITLE = new String[] { "头条", "房产", "另一面", "女人",
  6. "财经", "数码", "情感", "科技" };
  7. @Override
  8. protected void onCreate(Bundle savedInstanceState) {
  9. super.onCreate(savedInstanceState);
  10. setContentView(R.layout.activity_main);
  11. //实例化ViewPager, 然后给ViewPager设置Adapter
  12. ViewPager pager = (ViewPager)findViewById(R.id.pager);
  13. FragmentPagerAdapter adapter = new TabPageIndicatorAdapter(getSupportFragmentManager());
  14. pager.setAdapter(adapter);
  15. //实例化TabPageIndicator,然后与ViewPager绑在一起(核心步骤)
  16. TabPageIndicator indicator = (TabPageIndicator)findViewById(R.id.indicator);
  17. indicator.setViewPager(pager);
  18. //如果要设置监听ViewPager中包含的Fragment的改变(滑动切换页面),使用OnPageChangeListener为它指定一个监听器,那么不能像之前那样直接设置在ViewPager上了,而要设置在Indicator上,
  19. indicator.setOnPageChangeListener(new OnPageChangeListener() {
  20. @Override
  21. public void onPageSelected(int arg0) {
  22. Toast.makeText(getApplicationContext(), TITLE[arg0], Toast.LENGTH_SHORT).show();
  23. }
  24. @Override
  25. public void onPageScrolled(int arg0, float arg1, int arg2) {
  26. }
  27. @Override
  28. public void onPageScrollStateChanged(int arg0) {
  29. }
  30. });
  31. }
  32. /**
  33. * 定义ViewPager的适配器
  34. */
  35. class TabPageIndicatorAdapter extends FragmentPagerAdapter {
  36. public TabPageIndicatorAdapter(FragmentManager fm) {
  37. super(fm);
  38. }
  39. @Override
  40. public Fragment getItem(int position) {
  41. //新建一个Fragment来展示ViewPager item的内容,并传递参数
  42. Fragment fragment = new ItemFragment();
  43. Bundle args = new Bundle();
  44. args.putString("arg", TITLE[position]);
  45. fragment.setArguments(args);
  46. return fragment;
  47. }
  48. @Override
  49. public CharSequence getPageTitle(int position) {
  50. return TITLE[position % TITLE.length];
  51. }
  52. @Override
  53. public int getCount() {
  54. return TITLE.length;
  55. }
  56. }
  57. }

4.定义ViewPager每一个Item的代码(每一个Fragment)

此例只定义了一个Fragment,R.layout.fragment仅定义了一个TextView。在这个Fragment代码中,通过Bundle传递一个Key-value数据,内容仅一个字符串。实际开发的时候,针对每个ViewPager的item,要设计每个不同的Fragment的布局、代码内容等。此例代码只做示范。

  1. public class ItemFragment extends Fragment {
  2. @Override
  3. public View onCreateView(LayoutInflater inflater, ViewGroup container,
  4. Bundle savedInstanceState) {
  5. //动态找到布局文件,再从这个布局中find出TextView对象
  6. View contextView = inflater.inflate(R.layout.fragment_item, container, false);
  7. TextView mTextView = (TextView) contextView.findViewById(R.id.textview);
  8. //获取Activity传递过来的参数
  9. Bundle mBundle = getArguments();
  10. String title = mBundle.getString("arg");
  11. mTextView.setText(title);
  12. return contextView;
  13. }
  14. @Override
  15. public void onActivityCreated(Bundle savedInstanceState) {
  16. super.onActivityCreated(savedInstanceState);
  17. }
  18. }

5.Indicator的样式修改

第1步:在values/styles中添加<style>:

本例中,添加了3个<style>,其中"StyledIndicators"是我们需要的<style>,它其中的<item>使用了"CustomTabPageIndicator"这个<style>,这个<style>其中的一个<item>又使用了"CustomTabPageIndicator.Text"这个<style>。

实际上可以把"StyledIndicators"<style>的<item>属性全部写死在"StyledIndicators"下面。 但这样层级分离式的写法,增强了代码的复用性,以便后期维护和功能代码增删操作。

  1. <style name="StyledIndicators" parent="@android:style/Theme.Light">
  2. <item name="vpiTabPageIndicatorStyle">@style/CustomTabPageIndicator</item>
  3. </style>
  4. <style name="CustomTabPageIndicator" parent="Widget.TabPageIndicator">
  5. <item name="android:background">@drawable/tab_indicator</item>
  6. <item name="android:textAppearance">@style/CustomTabPageIndicator.Text</item>
  7. <item name="android:textSize">14sp</item>
  8. <item name="android:dividerPadding">8dp</item>
  9. <item name="android:showDividers">middle</item>
  10. <item name="android:paddingLeft">10dp</item>
  11. <item name="android:paddingRight">10dp</item>
  12. <item name="android:fadingEdge">horizontal</item>
  13. <item name="android:fadingEdgeLength">8dp</item>
  14. </style>
  15. <style name="CustomTabPageIndicator.Text" parent="android:TextAppearance.Medium">
  16. <item name="android:typeface">monospace</item>
  17. <item name="android:textColor">@drawable/selector_tabtext</item>
  18. </style>

第2步:创建<style>中使用到的drawable资源文件:

在drawable目录下添加tab_indicator.xml 和selector_tabtext.xml。

本例中使用到了自定义的drawable资源,自定义drawable一般配合上面的自定义style使用,提供图片、颜色等资源来支持自定义样式:

  1. <selector xmlns:android="http://schemas.android.com/apk/res/android">
  2. <item android:state_selected="false" android:state_pressed="false" android:drawable="@android:color/transparent" />
  3. <item android:state_selected="false" android:state_pressed="true" android:drawable="@android:color/transparent" />
  4. <item android:state_selected="true" android:state_pressed="false" android:drawable="@drawable/base_tabpager_indicator_selected" />
  5. <item android:state_selected="true" android:state_pressed="true" android:drawable="@drawable/base_tabpager_indicator_selected" />
  6. </selector>
  7. <selector xmlns:android="http://schemas.android.com/apk/res/android">
  8. <item android:state_selected="true" android:color="#EE2C2C" />
  9. <item android:state_pressed="true" android:color="#EE2C2C" />
  10. <item android:state_focused="true" android:color="#EE2C2C" />
  11. <item android:color="@android:color/black"/>
  12. </selector>

第3步:在Manifest中改用我们自定义的样式:

本例中直接在application上修改,也可以单独修改一个activity

  1. <application
  2. android:allowBackup="true"
  3. android:icon="@drawable/ic_launcher"
  4. android:label="@string/app_name"
  5. android:theme="@style/StyledIndicators" >

ViewPagerIndicator+viewpager指示器详解的更多相关文章

  1. Android ViewPager使用详解(转)

    这是谷歌官方给我们提供的一个兼容低版本安卓设备的软件包,里面包囊了只有在安卓3.0以上可以使用的api.而viewpager就是其中之一利用它,我们可以做很多事情,从最简单的导航,到页面菜单等等.那如 ...

  2. Android ViewPager使用详解

    这是谷歌官方给我们提供的一个兼容低版本安卓设备的软件包,里面包囊了只有在安卓3.0以上可以使用的api.而viewpager就是其中之一利用它,我们可以做很多事情,从最简单的导航,到页面菜单等等.那如 ...

  3. 【Android 界面效果21】Android ViewPager使用详解

    这是谷歌官方给我们提供的一个兼容低版本安卓设备的软件包,里面包囊了只有在安卓3.0以上可以使用的api.而viewpager就是其中之一利用它,我们可以做很多事情,从最简单的导航,到页面菜单等等.那如 ...

  4. 基于 CADisplayLink 的 FPS 指示器详解

    前言 之前在开发中有使用到计时器NSTimer,后来了解到iOS中不同的计时方法,其中就包括了CADisplayLink.基于CADisplayLink以屏幕刷新频率同步绘图的特性,尝试根据这点去实现 ...

  5. ViewPager 详解(四)----自主实现滑动指示条

    前言:前面我们用了三篇的时间讲述了有关ViewPager的基础知识,到这篇就要进入点实际的了.在第三篇<ViewPager 详解(三)---PagerTabStrip与PagerTitleStr ...

  6. Android流行界面结构——Fragment通过ViewPager(带指示器)嵌套Fragment结构的创建方法详解

    原创文章,转载请注明出处http://www.cnblogs.com/baipengzhan/p/6287213.html 当前Android流行界面结构的一种——Fragment通过ViewPage ...

  7. ViewPager 详解(三)---PagerTabStrip与PagerTitleStrip添加标题栏的异同

    前言:在前两篇文章中,我们讲解了滑动页面的的实现方法与四大函数的意义,但有时,仅仅实现页面滑动是不够的,还要有标题栏才会显得更友好.所以在这篇文章中,我将会向大家展示在Android.support. ...

  8. [转]ViewPager 详解(三)---PagerTabStrip与PagerTitleStrip添加标题栏的异同

      目录(?)[-] 一PagerTitleStrip Class Overview XML布局文件 重写适配器的getPageTitle函数 变量 初始化 重写CharSequence getPag ...

  9. ViewPager 详解(五)-----使用Fragment实现ViewPager滑动

    前言:前几篇文章讲解了ViewPager的普通实现方法,但Android官方最推荐的一种实现方法却是使用fragment,下面我们使用fragment来重新实现一下第一篇<ViewPager 详 ...

随机推荐

  1. zookeeper分布式部署方案

    版本:http://apache.fayea.com/zookeeper/zookeeper-3.4.8/环境:debian 7/8说明:最低配置3台步骤:1.下载zookeeper-3.4.8并解压 ...

  2. javascript之事件处理

    一般事件 onclick                       鼠标点击时触发此事件 ondblclick                  鼠标双击时触发此事件 onmousedown    ...

  3. 安卓中不同APP之间的消息通信

    昨天在腾讯实习生招聘初试面试时面试官问道我关于两个APP之间相互通信的方式,当时自己回道到了contentProvider与BroadcastReceiver.但他接着问还有没有其它的方式,我跟他说可 ...

  4. Android 面向协议编程 体会优雅编程之旅

    Android中面向协议编程的深入浅出 http://blog.csdn.net/sk719887916/article/details skay编写 说起协议,现实生活中大家第一感觉会想到规则或者约 ...

  5. iOS中 喷枪打字动画的实现

    实现原理比较简单,这里不做过多介绍. #import "ViewController.h" @interface ViewController () @property (weak ...

  6. iOS体会篇 大学编程到公司的过程

    原文作者:朱众 授权本技术博文转载. 刚进公司时,在你正式动手写代码前,很可能要理解code base.这一过程至少持续1个月,取决于你所在项目的规模.你会发现你不得不使用你浑身所学之能事,理解上古程 ...

  7. awk 详解+实例

    1. awk简介 awk是一种编程语言,用于在linux/unix下对文本和数据进行处理.数据可以来自标准输入.一个或多个文件,或其它命令的输出.它支持用户自定义函数和动态正则表达式等先进功能,是li ...

  8. [Django高级]理解django中的中间件机制和执行顺序

    原文来自 Understanding Django Middlewares, 这篇文章从整体上介绍了django中中间件定义,作用,和怎么样自己写中间件 –orangleliu. 注:middlewa ...

  9. 敏捷测试(6)--基于story的敏捷基础知识

    基于story的敏捷基础知识----需求管理(三) (3)每日站会 站会的目的有三个: (1)周知进度 仅从用户故事和任务的层面周知进度,任务进度只有两种状态:完成或未完成(完成百分比). (2)周知 ...

  10. sed命令 linux

    sed 实用工具是一个"编辑器",但它与其它大多数编辑器不同.除了不面向屏幕之外,它还是非交互式的.这意味着您必须将要对数据执行的命令插入到命令行或要处 理的脚本中.当显示它时,请 ...