先看下效果图:

这个需要用到1个开源的 库,这个后面也会说下的。

工程目录:

1. MainActivity.java

  1. public class MainActivity extends FragmentActivity {
  2. private ViewPagerFrameAdapter adapter;        //适配器(标题和内容)
  3. private ViewPager mPager;
  4. private TabPageIndicator         tabbPageIndicator;         //
  5. private UnderlinePageIndicatorEx underlinePageIndicator;
  6. private  int COUNT = 0;
  7. private List<String>   titles = new ArrayList<String>(); //标题
  8. @Override
  9. protected void onCreate(Bundle bundle) {
  10. super.onCreate(bundle);
  11. requestWindowFeature(Window.FEATURE_NO_TITLE);
  12. setContentView(R.layout.activity_main);
  13. //标题,这里自己造的假数据
  14. for (int j = 0; j < 3 ; j++){
  15. titles.add( "第"+ j +"标签卡");
  16. }
  17. mPager = (ViewPager)findViewById(R.id.pager);
  18. adapter = new ViewPagerFrameAdapter(getSupportFragmentManager(),titles);
  19. mPager.setAdapter(adapter);
  20. //得到指示器
  21. tabbPageIndicator = (TabPageIndicator) findViewById(R.id.tab_indicator);
  22. tabbPageIndicator.setViewPager(mPager);
  23. //下标
  24. underlinePageIndicator = (UnderlinePageIndicatorEx)findViewById(R.id.underline_indicator);
  25. underlinePageIndicator.setViewPager(mPager);
  26. underlinePageIndicator.setFades(false);
  27. //设置指示器
  28. tabbPageIndicator.setOnPageChangeListener(underlinePageIndicator);
  29. }
  30. //adapter 没啥好说的 跟前面的一样
  31. private class ViewPagerFrameAdapter extends FragmentStatePagerAdapter{
  32. private List<String> title; //页面标题头部数据
  33. public ViewPagerFrameAdapter(FragmentManager fm, List<String> title) {
  34. super(fm);
  35. this.title = title;
  36. }
  37. //根据position 返回 fragment
  38. @Override
  39. public Fragment getItem(int position) {
  40. return ArrayFragment.newInstance(position);
  41. }
  42. //size
  43. @Override
  44. public int getCount() {
  45. return title.size();
  46. }
  47. //顶部的title
  48. @Override
  49. public CharSequence getPageTitle(int position) {
  50. if (titles != null){
  51. return titles.get(position).toString();
  52. }
  53. return super.getPageTitle(position);
  54. }
  55. }
  56. }

UnderlinePageIndicatorEx.java

  1. //继承这个然后重写
  2. public class UnderlinePageIndicatorEx extends UnderlinePageIndicator{
  3. public UnderlinePageIndicatorEx(Context context) {
  4. super(context, null);
  5. }
  6. public UnderlinePageIndicatorEx(Context context, AttributeSet attrs) {
  7. super(context, attrs, R.attr.vpiUnderlinePageIndicatorStyle);
  8. }
  9. public UnderlinePageIndicatorEx(Context context, AttributeSet attrs, int defStyle) {
  10. super(context, attrs, defStyle);
  11. }
  12. //自身的 ViewPage传递过去
  13. @Override
  14. public void setViewPager(ViewPager viewPager) {
  15. if (mViewPager == viewPager){
  16. return;
  17. }
  18. //          if (mViewPager != null) {
  19. //              mViewPager.setOnPageChangeListener(null);
  20. //          }
  21. if (viewPager.getAdapter() == null) {
  22. throw new IllegalStateException(" pager 没有 加入 adapter");
  23. }
  24. mViewPager = viewPager;
  25. //          mViewPager.setOnPageChangeListener(this);
  26. invalidate();
  27. post(new Runnable(){
  28. @Override public void run() {
  29. if (mFades) {
  30. post(mFadeRunnable);
  31. }
  32. }
  33. });
  34. }
  35. }

ArrayFragment.java

  1. public class ArrayFragment extends Fragment{
  2. private int position;
  3. public ArrayFragment(int position){
  4. this.position = position;
  5. }
  6. // 返回   viwePager 下面滑动的页面
  7. public static ArrayFragment newInstance(int position){
  8. return new ArrayFragment(position);
  9. }
  10. @Override
  11. public void onCreate(Bundle savedInstanceState) {
  12. super.onCreate(savedInstanceState);
  13. }
  14. @Override
  15. public void onDestroy() {
  16. super.onDestroy();
  17. }
  18. // 根据position 返回不同的view
  19. @Override
  20. public View onCreateView(LayoutInflater inflater, ViewGroup container,
  21. Bundle savedInstanceState) {
  22. View view = inflater.inflate(R.layout.layoutaa, null);
  23. return view;
  24. }
  25. }

好了接下来是 布局xml了。

  1. <LinearLayout
  2. xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="fill_parent"
  4. android:layout_height="fill_parent"
  5. android:orientation="vertical"
  6. >
  7. <!--  标题      和      标题下面的  指示器  -->
  8. <LinearLayout
  9. android:layout_width="fill_parent"
  10. android:layout_height="35dp"
  11. android:orientation="vertical"
  12. android:background="@drawable/main_header_background">
  13. <com.viewpagerindicator.TabPageIndicator
  14. android:id="@+id/tab_indicator"
  15. android:layout_height="wrap_content"
  16. android:layout_width="fill_parent"/>
  17. <com.test.linepagerindictor.widget.UnderlinePageIndicatorEx
  18. android:id="@+id/underline_indicator"
  19. android:layout_height="3dip"
  20. android:layout_width="fill_parent"
  21. android:layout_alignParentBottom="true"/>
  22. </LinearLayout>
  23. <android.support.v4.view.ViewPager
  24. android:id="@+id/pager"
  25. android:layout_width="fill_parent"
  26. android:layout_height="fill_parent"/>
  27. </LinearLayout>

接下来设置 滑动指示器的style

  1. <!-- 总 style  直接引用  这个   由  tab style  和    Indicator style 组成 -->
  2. <style name="StyledAllIndicators" parent="@android:style/Theme.Light">
  3. <item name="vpiTabPageIndicatorStyle">@style/CustomTabPageIndicator</item>
  4. <item name="vpiUnderlinePageIndicatorStyle">@style/CustomUnderlinePageIndicator</item>
  5. </style>
  6. <!-- tab的 style -->
  7. <style name="CustomTabPageIndicator" parent="Widget.TabPageIndicator">
  8. <item name="android:background">#00000000</item>
  9. <item name="android:textAppearance">@style/CustomTabPageIndicator_text</item>
  10. <item name="android:textColor">@color/selector_tab</item>
  11. <item name="android:textSize">20sp</item>
  12. <!-- 分割线,可有可无的 -->
  13. <item name="android:divider">@drawable/custom_tab_indicator_divider</item>
  14. <item name="android:dividerPadding">10dip</item>
  15. <item name="android:showDividers">middle</item>
  16. <item name="android:paddingTop">4dp</item>
  17. <item name="android:paddingLeft">8dp</item>
  18. <item name="android:paddingBottom">4dp</item>
  19. <item name="android:paddingRight">8dp</item>
  20. <item name="android:fadingEdge">horizontal</item>
  21. <item name="android:fadingEdgeLength">8dp</item>
  22. </style>
  23. <style name="CustomTabPageIndicator_text" parent="android:TextAppearance.Medium">
  24. <item name="android:typeface">monospace</item>
  25. </style>
  26. <!--  下标的指示器的颜色 -->
  27. <style name="CustomUnderlinePageIndicator">
  28. <item name="selectedColor">#EB5548</item>
  29. <item name="android:background">#00000000</item>
  30. <item name="fadeLength">1000</item>
  31. <item name="fadeDelay">1000</item>
  32. </style>

selector_tab.xml     这个是 选择器 在style中引用的,是用来切换 被选中的背景色的

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <selector xmlns:android="http://schemas.android.com/apk/res/android">
  3. <item android:state_selected="true" android:color="#91D228" />
  4. <item android:state_focused="true" android:color="#91D228" />
  5. <item android:color="#dddddd" />
  6. </selector>

好了 ,基本就这些了   fragment的的那个xml  自己随意画吧, 那个开源库随后上传。

android 中 viewpager 滑动的指示器的更多相关文章

  1. Android中ViewPager实现滑动条及与Fragment结合的实例教程

    ViewPager类主要被用来实现可滑动的视图功能,这里我们就来共同学习Android中ViewPager实现滑动条及与Fragment结合的实例教程,需要的朋友可以参考下 自主实现滑动指示条先上一个 ...

  2. Android中viewPager的一两点使用

    Android中viewPager的一两点使用 viewPager是谷歌官方提供的一种方便实现页面滑动效果的控件,可以直接使用也可以和fragment联合使用.这里只简单说下直接使用. 使用viewP ...

  3. Android中ViewPager+Fragment取消(禁止)预加载延迟加载(懒加载)问题解决方案

    转载请注明出处:http://blog.csdn.net/linglongxin24/article/details/53205878本文出自[DylanAndroid的博客] Android中Vie ...

  4. Android中实现滑动翻页—使用ViewFlipper(dp和px之间进行转换)

    Android中实现滑动翻页—使用ViewFlipper(dp和px之间进行转换) Android中dp和px之间进行转换 在xml布局文件中,我们既可以设置px,也可以设置dp(或者dip).一般情 ...

  5. android 禁止ViewPager滑动

    最近项目中,有个需求就是要禁止ViewPager滑动事件,我们看下360手机助手的界面,风格就类似这样的 大家如果使用过360手机助手就会发现中间内容是不可以滑动的,现在写一个demo,讲下怎么禁止V ...

  6. Android中ViewPager的使用

    我们在一个apk中第一次開始的时候,会有一个guide界面.一般使用ViewPager来完毕. 布局文件例如以下: <? xml version="1.0" encoding ...

  7. Android中ViewPager如何设置不能通过屏幕左右滑动来切换页面

    //很多时候,我想禁止用户通过屏幕的左右滑动来切换界面!如何实现! //创建一个类继承viewpager,实现 onTouchEvent   和   onInterceptTouchEvent方法,都 ...

  8. Android中分页滑动实现总结

    手机的屏幕相对较小,因此会出现当有多项内容需要展示而不得不进行分页的情况.例如手机桌面的应用图标的展示.一般一屏可以显示4*4=16个小方块形的应用程序,可以通过左右滑动进行屏幕的选择.而Androi ...

  9. android 中 ViewPager 的平常用法 ViewPager+ Views

    延续前面几个的经常用到的ViewPager, 直接加载各种不同的 View 工程目录: 代码: public class ViewActivity extends Activity { // 每个Vi ...

随机推荐

  1. ZH奶酪:PHP的cURL库

    原文链接:http://coolshell.cn/articles/664.html 参考链接:http://www.runoob.com/php/php-ref-curl.html 使用PHP的cU ...

  2. TQ2440触摸屏

    s3c2440集成了4线制电阻式的触摸屏接口,触点坐标的检测是通过A/D转换来实现的. s3c2440一共有4种触摸屏接口模式: (1)等待中断模式 设置ADCTSC寄存器为0xD3即可令触摸屏控制器 ...

  3. infobright系列三:数据导入乱码

    1:目前在用的是社区版的infobright,不支持DML功能,只能用LOAD DATA方式导入数据. 如果元数据中有特殊控制字符,导入过程中经常会报错 2: 设置Reject File导入之前,设定 ...

  4. Got fatal error 1236 from master when reading data from binary log: 'Could not find first log file name in binary log index file'系列二:reset slave

    reset slave会清除从库的所有复制信息.一般应用场景:如切换为不同的Master, 主从重做等: 1. 命令在slave上执行,执行前一定要stop slave. 2. 执行reset sla ...

  5. ES6学习笔记九:修饰器

    一:修饰器(Decorator)是一个函数,用来修改类的行为. 1)定义与使用 function 修饰器名(target) { //target是被修饰对象,可用target.xxx进行调用修改 } ...

  6. ES5学习笔记

    转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/7234053.html 一:基础 1:语法 ECMAScript 中的变量无特定的类型,定义变量时只用 var ...

  7. JavaWeb项目配置化之Properties类的使用

    转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/6397370.html  在项目中的应用见: https://github.com/ygj0930/Couple ...

  8. 〖Linux〗tmux 配置文件

    tmux中默认的shell是zsh,zsh在日常中使用可以协助我们高效地使用shell命令. 配置文件默认位置 ~/.tmux.conf,此外,把常用快捷键也附录在这里,方便记忆. # 设置Shell ...

  9. VS编译 x64版本zlib库

    编译的过程倒也不是很难.我把编译的源码和脚本及说明都放在gitee上了. 详细的可以见这里 https://gitee.com/solym/zlib-1.2.11.git 可以参考这些文章 win10 ...

  10. Eclipse和MyEclipse使用技巧--如何解决新建一个包的时候,工具帮生成了多个包的问题?

    一.问题再现 二.如何解决