原文:http://my.oschina.net/u/1403288/blog/208402

项目源码:https://github.com/wangjing0311/ViewPagerIndicator.git

一、源码分析

1.PageIndicator接口,它里面定义了最重要和基本的indicator表现出的一些方法:
    1.1 首先一个indicator必须要与一个ViewPager关联在一起,所以它提供了一个setViewPager方法。
    1.2 它扩展了ViewPager.OnPageChangeListener接口,表示接管了ViewPager的Pager改变时的监听处理,
          这也是为什么为ViewPager设置OnPageChangeListener监听器时不能设置在ViewPager上而必须设置在
          indicator上的原因。
    1.3 还有一个notifyDataSetChanged通知方法,表示为这个ViewPager提供View(一般是Fragment)的  Adapter 里面的数据集发生变化时,执行的动作,这里可增加相关的逻辑。

2.Viewpager Indicator的实现类(6个)

  2.1 小圆圈类型的
    2.2 带图标类型的                    
    2.3 小横线类型的,距离屏幕最下边端有一定的距离。
    2.4 标签类型的(Tab)
    2.5 标题类型的,与标签类型的有点像,但它当前的标题页的左/右边的标题会卷起,即往两端缩进去。
    2.6 屏幕底部小横线类型的,并且会占满整行。

二、Demo分析

1. Demo项目的设计
    项目由一个ListSamples的ListActivity入口,它主要用作组装所有的子indicator的列表。
    TestFragment.java,所有ViewPager上真正显示的视图。
    TestFragmentAdapter.java,所有ViewPager里的Adapter,为ViewPager生成TestFragment。
    Samplexxx.java,所有的indicator的显示,一个类显示一种使用方法或特性。

2.使用

1)layout.xml

<com.viewpagerindicator.TabPageIndicator
android:id="@+id/indicator"
android:layout_width="match_parent"
android:layout_height="wrap_content" />

2)Activity将viewpager与indicator联系在一起

ViewPager pager = (ViewPager)findViewById(R.id.viewpager);
pager.setAdapter(new TestAdapter(getSupportFragmentManager())); //Bind the title indicator to the adapter
TabPageInitlecator titleIndicator = (TabPageITitlePageIndicatoreById(R.id.titles);
titleIndicator.setViewPager(pager);

3)加入监听(不设置在ViewPager上,要设置在Indicator上)

titleIndicator.setOnPageChangeListener(mPageChangeListener);

3.修改indicator的样式(Theme)

1)AndroidManifest.xml

<activity
android:name=".SampleCirclesStyledTheme"
android:label="Circles/Styled (via theme)"
android:theme="@style/StyledIndicators">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="com.jakewharton.android.viewpagerindicator.sample.SAMPLE" />
</intent-filter>
</activity>

android:theme="@style/StyledIndicators" ==> values/styles.xml

<resources>
<style name="StyledIndicators" parent="@android:style/Theme.Light">
<item name="vpiCirclePageIndicatorStyle">@style/CustomCirclePageIndicator</item>
<item name="vpiLinePageIndicatorStyle">@style/CustomLinePageIndicator</item>
<item name="vpiTitlePageIndicatorStyle">@style/CustomTitlePageIndicator</item>
<item name="vpiTabPageIndicatorStyle">@style/CustomTabPageIndicator</item>
<item name="vpiUnderlinePageIndicatorStyle">@style/CustomUnderlinePageIndicator</item>
</style>

2)Layout.xml

<android.support.v4.view.ViewPager
android:id="@+id/pager"
android:layout_width="fill_parent"
android:layout_height="0dp"
android:layout_weight="1"
/>
<com.viewpagerindicator.CirclePageIndicator
android:id="@+id/indicator"
android:padding="10dip"
android:layout_height="wrap_content"
android:layout_width="fill_parent"
android:background="#FFCCCCCC"
app:radius="10dp"
app:fillColor="#FF888888"
app:pageColor="#88FF0000"
app:strokeColor="#FF000000"
app:strokeWidth="2dp"
/>

3)Activity的对象方法

CirclePageIndicator indicator = (CirclePageIndicator)findViewById(R.id.indicator);
mIndicator = indicator;
indicator.setViewPager(mPager); final float density = getResources().getDisplayMetrics().density;
indicator.setBackgroundColor(0xFFCCCCCC);
indicator.setRadius(10 * density);
indicator.setPageColor(0x880000FF);
indicator.setFillColor(0xFF888888);
indicator.setStrokeColor(0xFF000000);
indicator.setStrokeWidth(2 * density);

最新文章

  1. AngularJS 源码分析2
  2. easyUI 表格
  3. nginx安装及配置为简单的文件服务器
  4. js-图标控件
  5. Hash_1014: [JSOI2008]火星人prefix
  6. css中的字体及文本相关属性
  7. (转)CSS 为不同大小的浏览器视窗使用不同的样式表
  8. Azure开发者任务之二:Cloud Service项目添加到ASP.Net Web中
  9. 以Server模式启动Derby服务竟然抛套接字权限异常
  10. 查看java的.class文件的方法
  11. Sublime Text个性化设置
  12. cf C. Hamburgers
  13. Docker 基础技术之 Linux namespace 源码分析
  14. ActiveMq主从机制
  15. Chapter 5 Blood Type——25
  16. 安卓学习第一节--环境搭建及Android Studio 安装
  17. Day11 Python基础之装饰器(高级函数)(九)
  18. php读取不到指定的php.ini配置
  19. centos 配置ssh远程登录
  20. 【编程基础】编译器 cc、gcc、g++、CC 的区别

热门文章

  1. Mac系统下安装PIL
  2. 黑马程序员—C语言的函数、数组、字符串
  3. CSU 1337(费马大定理)
  4. MVC中的过滤器
  5. 新建PCH文件以及常用宏定义
  6. 蓝牙-b
  7. 利用Keil u4调试,精确实现软件延时
  8. MappedByteBuffer高速缓存文件、RandomAccessFile随机访问
  9. redis 基本使用
  10. http 400 错误的请求怎么解决