android Github-Client(ANDROID)开源之旅(三) ------ 巧用ViewPagerIndicator

本文主要是介绍android Github-Client(ANDROID)开源之旅(三) ------ 巧用ViewPagerIndicator,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Github-Client(ANDROID)开源之旅(三) ------ 巧用ViewPagerIndicator


接上篇博文:Github-Client(ANDROID)开源之旅(二) ------ 浅析ActionBarSherkLock

文中结合了网易新闻客户端讲解了开源库ActionBarSherklock的使用

今天蓝老师再给大家讲解一个开源库的使用,它就是ViewPagerIndicator(同样出自JakeWharton之手,ps:这胖子还是蛮厉害的)

官网地址:http://viewpagerindicator.com/

Github地址:https://github.com/JakeWharton/Android-ViewPagerIndicator

ViewPagerIndicator作为一款分页指标小部件兼容ViewPager,封装上做得还是不错的,目前为众多知名应用所使用

具体API使用大家下载官方demo示例瞅瞅就欧了(链接库都不懂得怎么引用的童鞋自个儿先去补补课)

以下是官网的效果图


本文就以优化大师的TAB滑动标签页为例来讲解该库的扩展使用

先上效果图,原版


山寨版



玩过优化大师的童鞋应该注意到,tab底部的下划线是会随着pager的滑动而实时变化,而网上很多demo则是标签页切换时下划线的动画效果,二者是有区别的,当然只要在onPageScrolled添加一些处理同样可以达到效果,不过代码就多了很多额外处理,另外这么做也不够通用,本着不重复发明轮子的原则,我们只需对现有控件做一些改造就可以实现我们想要的效果了


先看layout文件:

[java]  view plain copy
  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.         android:background="#dddddd">  
  7.           
  8.       
  9.         <RelativeLayout  
  10.         android:layout_width="fill_parent"  
  11.         android:layout_height="40dp"  
  12.         android:background="#074060">  
  13.           
  14.                 <TextView  
  15.                 android:id="@+id/title"  
  16.                 android:layout_width="wrap_content"  
  17.                 android:layout_height="wrap_content"  
  18.                 android:layout_centerInParent="true"  
  19.                 android:text="安卓优化大师"  
  20.                 android:textColor="#eeeeee"  
  21.                 android:textSize="20sp"/>                  
  22.               
  23.                 <ImageView  
  24.                  android:layout_width="wrap_content"  
  25.                  android:layout_height="wrap_content"  
  26.                  android:src="@drawable/titlebar_logo"  
  27.                  android:layout_centerVertical="true"  
  28.                  android:layout_toLeftOf="@id/title"  
  29.                  android:layout_marginRight="10dp"/>  
  30.           
  31.         </RelativeLayout>  
  32.           
  33.         <LinearLayout  
  34.         android:layout_width="fill_parent"  
  35.         android:layout_height="35dp"  
  36.         android:orientation="vertical"  
  37.         android:background="@drawable/main_header_background">  
  38.           
  39.                 <com.viewpagerindicator.TabPageIndicator  
  40.                 android:id="@+id/tab_indicator"  
  41.                 android:layout_height="wrap_content"  
  42.                 android:layout_width="fill_parent"/>  
  43.               
  44.                 <com.lance.tablinepagerindictor.widget.UnderlinePageIndicatorEx  
  45.                 android:id="@+id/underline_indicator"  
  46.                 android:layout_height="3dp"  
  47.                 android:layout_width="fill_parent"  
  48.                 android:layout_alignParentBottom="true"/>  
  49.           
  50.        </LinearLayout>       
  51.          
  52.        <android.support.v4.view.ViewPager  
  53.         android:id="@+id/pager"  
  54.         android:layout_width="fill_parent"  
  55.         android:layout_height="fill_parent"/>  
  56.           
  57.       
  58. </LinearLayout>  

再看UnderlinePageIndicatorEx的实现

[java]  view plain copy
  1. public class UnderlinePageIndicatorEx extends UnderlinePageIndicator{  
  2.   
  3.        public UnderlinePageIndicatorEx(Context context) {  
  4.            super(context, null);  
  5.              
  6.         }  
  7.   
  8.         public UnderlinePageIndicatorEx(Context context, AttributeSet attrs) {  
  9.             super(context, attrs, R.attr.vpiUnderlinePageIndicatorStyle);  
  10.               
  11.         }  
  12.   
  13.         public UnderlinePageIndicatorEx(Context context, AttributeSet attrs, int defStyle) {  
  14.             super(context, attrs, defStyle);  
  15.               
  16.         }  
  17.           
  18.           
  19.         @Override  
  20.         public void setViewPager(ViewPager viewPager) {  
  21.             if (mViewPager == viewPager) {  
  22.                 return;  
  23.             }  
  24. //          if (mViewPager != null) {  
  25. //              //Clear us from the old pager.  
  26. //              mViewPager.setOnPageChangeListener(null);  
  27. //          }  
  28.             if (viewPager.getAdapter() == null) {  
  29.                 throw new IllegalStateException("ViewPager does not have adapter instance.");  
  30.             }  
  31.             mViewPager = viewPager;  
  32. //          mViewPager.setOnPageChangeListener(this);  
  33.             invalidate();  
  34.             post(new Runnable() {  
  35.                 @Override public void run() {  
  36.                     if (mFades) {  
  37.                         post(mFadeRunnable);  
  38.                     }  
  39.                 }  
  40.             });  
  41.         }  
  42. }  

UnderlinePageIndicatorEx继承了UnderlinePageIndicator,前面提到链接库有所改动

事实上就是把成员变量的访问权限由private改为protected,然后重写了setViewPager方法(why?自个儿琢磨去)

最后看看activity中如何调用

[java]  view plain copy
  1. public class MainActivity extends FragmentActivity {  
  2.   
  3.     private ContentFrameAdapter mContentAdapter;  
  4.     private ViewPager mPager;  
  5.     private TabPageIndicator mTabPageIndicator;  
  6.     private UnderlinePageIndicatorEx mUnderlinePageIndicator;  
  7.       
  8.       
  9.     private  int COUNT = 0;  
  10.     private List<TitleStruct> mTitleList;  
  11.     private List<ContentStruct> mContentList;  
  12.       
  13.       
  14.       
  15.   
  16.     @Override  
  17.     protected void onCreate(Bundle arg0) {  
  18.   
  19.         super.onCreate(arg0);  
  20.         requestWindowFeature(Window.FEATURE_NO_TITLE);   
  21.         getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,     
  22.                     WindowManager.LayoutParams.FLAG_FULLSCREEN);    
  23.         setContentView(R.layout.activity_main);  
  24.           
  25.         initData();  
  26.         setupViews();  
  27.   
  28.     }  
  29.   
  30.   
  31.     private void setupViews(){        
  32.            
  33.          mPager = (ViewPager)findViewById(R.id.pager);  
  34.          mPager.setAdapter(mContentAdapter);   
  35.           
  36.          mTabPageIndicator = (TabPageIndicator) findViewById(R.id.tab_indicator);     
  37.          mTabPageIndicator.setViewPager(mPager);       
  38.            
  39.          mUnderlinePageIndicator = (UnderlinePageIndicatorEx)findViewById(R.id.underline_indicator);  
  40.          mUnderlinePageIndicator.setViewPager(mPager);  
  41.          mUnderlinePageIndicator.setFades(false);  
  42.            
  43.          mTabPageIndicator.setOnPageChangeListener(mUnderlinePageIndicator);  
  44.     }  
  45.       
  46.       
  47.     private void initData(){  
  48.          mContentList = new ArrayList<ContentStruct>();  
  49.          mTitleList = new ArrayList<TitleStruct>();  
  50.           
  51.          String[] arrStrings = getResources().getStringArray(R.array.sections);  
  52.          COUNT = arrStrings.length;  
  53.          for (int i = 0; i < COUNT; i++) {  
  54.              ContentStruct object = new ContentStruct();  
  55.              object.daString = arrStrings[i];  
  56.              object.index = i;        
  57.              mContentList.add(object);  
  58.                
  59.              TitleStruct object2 = new TitleStruct(arrStrings[i]);  
  60.              mTitleList.add(object2);  
  61.          }  
  62.            
  63.            
  64.          mContentAdapter = new ContentFrameAdapter(getSupportFragmentManager());  
  65.          mContentAdapter.setContentList(mContentList);  
  66.          mContentAdapter.setTitleList(mTitleList);  
  67.      
  68.     }  
  69.   
  70. }  

简洁明了,是不是比在activity添加一堆乱七八糟的东西要好看的多?

其它的就没啥好咋乎的了,最后附上工程链接:

http://download.csdn.net/detail/geniuseoe2012/5641165


欲知后事如何,且听下回分解

more brilliantPlease pay attention to my CSDN blog -->http://blog.csdn.net/geniuseoe2012 



开源之旅(四)   Github-Client(ANDROID)开源之旅(四) ------ 简介Roboguice

版权声明:本文为博主原创文章,未经博主允许不得转载。

这篇关于android Github-Client(ANDROID)开源之旅(三) ------ 巧用ViewPagerIndicator的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/994654

相关文章

Android中Dialog的使用详解

《Android中Dialog的使用详解》Dialog(对话框)是Android中常用的UI组件,用于临时显示重要信息或获取用户输入,本文给大家介绍Android中Dialog的使用,感兴趣的朋友一起... 目录android中Dialog的使用详解1. 基本Dialog类型1.1 AlertDialog(

Android Kotlin 高阶函数详解及其在协程中的应用小结

《AndroidKotlin高阶函数详解及其在协程中的应用小结》高阶函数是Kotlin中的一个重要特性,它能够将函数作为一等公民(First-ClassCitizen),使得代码更加简洁、灵活和可... 目录1. 引言2. 什么是高阶函数?3. 高阶函数的基础用法3.1 传递函数作为参数3.2 Lambda

Android自定义Scrollbar的两种实现方式

《Android自定义Scrollbar的两种实现方式》本文介绍两种实现自定义滚动条的方法,分别通过ItemDecoration方案和独立View方案实现滚动条定制化,文章通过代码示例讲解的非常详细,... 目录方案一:ItemDecoration实现(推荐用于RecyclerView)实现原理完整代码实现

Android App安装列表获取方法(实践方案)

《AndroidApp安装列表获取方法(实践方案)》文章介绍了Android11及以上版本获取应用列表的方案调整,包括权限配置、白名单配置和action配置三种方式,并提供了相应的Java和Kotl... 目录前言实现方案         方案概述一、 androidManifest 三种配置方式

Android WebView无法加载H5页面的常见问题和解决方法

《AndroidWebView无法加载H5页面的常见问题和解决方法》AndroidWebView是一种视图组件,使得Android应用能够显示网页内容,它基于Chromium,具备现代浏览器的许多功... 目录1. WebView 简介2. 常见问题3. 网络权限设置4. 启用 JavaScript5. D

Android如何获取当前CPU频率和占用率

《Android如何获取当前CPU频率和占用率》最近在优化App的性能,需要获取当前CPU视频频率和占用率,所以本文小编就来和大家总结一下如何在Android中获取当前CPU频率和占用率吧... 最近在优化 App 的性能,需要获取当前 CPU视频频率和占用率,通过查询资料,大致思路如下:目前没有标准的

无需邀请码!Manus复刻开源版OpenManus下载安装与体验

《无需邀请码!Manus复刻开源版OpenManus下载安装与体验》Manus的完美复刻开源版OpenManus安装与体验,无需邀请码,手把手教你如何在本地安装与配置Manus的开源版OpenManu... Manus是什么?Manus 是 Monica 团队推出的全球首款通用型 AI Agent。Man

golang获取prometheus数据(prometheus/client_golang包)

《golang获取prometheus数据(prometheus/client_golang包)》本文主要介绍了使用Go语言的prometheus/client_golang包来获取Prometheu... 目录1. 创建链接1.1 语法1.2 完整示例2. 简单查询2.1 语法2.2 完整示例3. 范围值

Android开发中gradle下载缓慢的问题级解决方法

《Android开发中gradle下载缓慢的问题级解决方法》本文介绍了解决Android开发中Gradle下载缓慢问题的几种方法,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、网络环境优化二、Gradle版本与配置优化三、其他优化措施针对android开发中Gradle下载缓慢的问

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后