转载请注明出处:http://blog.csdn.net/xiaanming/article/details/9971721

大家都知道Android的ActionBar是在3.0以上才有的,那么在3.0以下呢,google并没有给我提供在3.0以下支持ActionBar的包,但是外国的大牛JakeWharton实现了在3.0以下使用ActionBar, JakeWharton这位大牛是ActionBarSherlock,Android-ViewPagerIndicator ,NineOldAndroids的作者,非常厉害的一个人,Github的关注量超过2.6K,我左侧的友情链接里面有他的Github的主页链接,有兴趣的朋友可以去follow下他,今天我们使用的是他的开源框架ActionBarSherlock,ActionBarSherlock是让Action Bar功能支持2.X后的所有平台,而且他会自动的判断是调用原生Action Bar还是使用扩展ActionBar,很多知名的应用也使用这个库,我之前对ActionBar也不了解,所以就去下了ActionBarSherlock来好好的了解了解ActionBar的使用

把红色框框标记的文件导入Eclipse里面,我们可以先看下例子,来了解下ActionBar的一些使用情况

  • 我们新建一个Android工程,叫ViewPagerAndTab,然后指定ActionBarSherlock为ViewPagerAndTab的库工程,右键工程--->Properties

通过上面的几步我们就指定ActionBarSherlock为ViewPagerAndTab的库工程,接下来我们就能在3.0以下使用ActionBar,我这里使用的是ActionBar  Tab和ViewPager仿网易新闻,我们看看主要代码的编写

1.先看布局文件,里面一个ViewPager,非常简单

  1. <RelativeLayout 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:background="@android:color/white">
  6. <android.support.v4.view.ViewPager
  7. android:id="@+id/viewPager"
  8. android:layout_width="fill_parent"
  9. android:layout_height="wrap_content" />
  10. </RelativeLayout>

2.MainActivity代码,点击ActionBar的Tab,ViewPager切换不同的Fragment,滑动ViewPager,选中相对应的ActiionBar Tab

  1. package com.example.viewpagerandtabdemo;
  2. import java.util.ArrayList;
  3. import java.util.List;
  4. import android.os.Bundle;
  5. import android.support.v4.app.Fragment;
  6. import android.support.v4.app.FragmentTransaction;
  7. import android.support.v4.view.ViewPager;
  8. import android.support.v4.view.ViewPager.OnPageChangeListener;
  9. import com.actionbarsherlock.app.ActionBar;
  10. import com.actionbarsherlock.app.ActionBar.Tab;
  11. import com.actionbarsherlock.app.SherlockFragmentActivity;
  12. public class MainActivity extends SherlockFragmentActivity implements ActionBar.TabListener, OnPageChangeListener{
  13. /**
  14. * 顶部Tab的title
  15. */
  16. private String [] mTabTitles;
  17. /**
  18. * ViewPager对象的引用
  19. */
  20. private ViewPager mViewPager;
  21. /**
  22. * 装载Fragment的容器,我们的每一个界面都是一个Fragment
  23. */
  24. private List<Fragment> mFragmentList;
  25. /**
  26. * ActionBar对象的引用
  27. */
  28. private ActionBar mActionBar;
  29. @Override
  30. protected void onCreate(Bundle savedInstanceState) {
  31. super.onCreate(savedInstanceState);
  32. setContentView(R.layout.activity_main);
  33. //从资源文件在获取Tab的title
  34. mTabTitles = getResources().getStringArray(R.array.tab_title);
  35. mFragmentList =  new ArrayList<Fragment>();
  36. mViewPager = (ViewPager) findViewById(R.id.viewPager);
  37. //设置Adapter
  38. mViewPager.setAdapter(new TabPagerAdapter(getSupportFragmentManager(), mFragmentList));
  39. //设置监听
  40. mViewPager.setOnPageChangeListener(this);
  41. //获取Action实例我们使用getSupportActionBar()方法
  42. mActionBar = getSupportActionBar();
  43. //隐藏Title
  44. mActionBar.setDisplayShowTitleEnabled(false);
  45. //隐藏Home logo
  46. mActionBar.setDisplayShowHomeEnabled(false);
  47. //设置ActionBar的导航模式为Tab
  48. mActionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_TABS);
  49. //为ActionBar添加Tab并设置TabListener
  50. for(int i=0; i<mTabTitles.length; i++){
  51. ActionBar.Tab tab = mActionBar.newTab();
  52. tab.setText(mTabTitles[i]);
  53. tab.setTabListener(this);
  54. mActionBar.addTab(tab, i);
  55. }
  56. //将Fragment加入到List中,并将Tab的title传递给Fragment
  57. for(int i=0; i<mTabTitles.length; i++){
  58. Fragment fragment = new ItemFragment();
  59. Bundle args = new Bundle();
  60. args.putString("arg", mTabTitles[i]);
  61. fragment.setArguments(args);
  62. mFragmentList.add(fragment);
  63. }
  64. }
  65. @Override
  66. public void onTabSelected(Tab tab, FragmentTransaction ft) {
  67. //点击ActionBar Tab的时候切换不同的Fragment界面
  68. mViewPager.setCurrentItem(tab.getPosition());
  69. }
  70. @Override
  71. public void onTabUnselected(Tab tab, FragmentTransaction ft) {
  72. }
  73. @Override
  74. public void onTabReselected(Tab tab, FragmentTransaction ft) {
  75. }
  76. @Override
  77. public void onPageScrollStateChanged(int arg0) {
  78. }
  79. @Override
  80. public void onPageScrolled(int arg0, float arg1, int arg2) {
  81. }
  82. @Override
  83. public void onPageSelected(int arg0) {
  84. //滑动ViewPager的时候设置相对应的ActionBar Tab被选中
  85. mActionBar.setSelectedNavigationItem(arg0);
  86. }
  87. }

我们使用ActionBarSherlock的时候不再是继承Activity,而是继承SherlockActivity,SherlockDialogFragment,SherlockFragmentActivity等等,我这里用到Fragment,所以继承SherlockFragmentActivity,我们不能随便设置Activity的theme,以后我们要全屏显示的时候直接设置android:theme="@android:style/Theme.Black.NoTitleBar"

,我们使用ActionBar就不能这样设置了,并且不能随便设置他的Theme,必须是Theme.Sherlock, Theme.Sherlock.Light, Theme.Sherlock.Light.DarkActionBar,或者是他们的子样式,不然就会出java.lang.IllegalStateException异常,所以为了自定义ActionBar的Tab,我们必须修改其style

注意:我们还必须删除ViewPagerAndTab工程libs下面的android-support-v4.jar包,因为在ActionBarSherlock已经包含android-support-v4.jar

3.ViewPager的适配器TabPagerAdapter,因为我们用到Fragment,所以我们继承FragmentStatePagerAdapter而不是PagerAdapter

  1. package com.example.viewpagerandtabdemo;
  2. import java.util.List;
  3. import android.support.v4.app.Fragment;
  4. import android.support.v4.app.FragmentManager;
  5. import android.support.v4.app.FragmentStatePagerAdapter;
  6. public class TabPagerAdapter extends FragmentStatePagerAdapter {
  7. private List<Fragment> list;
  8. //构造函数
  9. public TabPagerAdapter(FragmentManager fm, List<Fragment> list) {
  10. super(fm);
  11. this.list = list;
  12. }
  13. @Override
  14. public Fragment getItem(int arg0) {
  15. return list.get(arg0);
  16. }
  17. @Override
  18. public int getCount() {
  19. return list.size();
  20. }
  21. }

4.ItemFragment 继承SherlockFragment,也可以直接继承Fragment,里面的的布局比较简单,一个TextView用来显示从Activity传递过来的ActionBar Tab的title

  1. package com.example.viewpagerandtabdemo;
  2. import android.os.Bundle;
  3. import android.view.LayoutInflater;
  4. import android.view.View;
  5. import android.view.ViewGroup;
  6. import android.widget.TextView;
  7. import com.actionbarsherlock.app.SherlockFragment;
  8. public class ItemFragment extends SherlockFragment {
  9. @Override
  10. public View onCreateView(LayoutInflater inflater, ViewGroup container,
  11. Bundle savedInstanceState) {
  12. View contextView = inflater.inflate(R.layout.fragment_item, container, false);
  13. TextView mTextView = (TextView) contextView.findViewById(R.id.textview);
  14. //获取Activity传递过来的参数
  15. Bundle mBundle = getArguments();
  16. String title = mBundle.getString("arg");
  17. mTextView.setText(title);
  18. return contextView;
  19. }
  20. @Override
  21. public void onActivityCreated(Bundle savedInstanceState) {
  22. super.onActivityCreated(savedInstanceState);
  23. }
  24. }

然后我们将上面的Activity的theme设置成android:theme="@style/Theme.Sherlock.Light.DarkActionBar" 运行项目看看效果,下图一是项目的效果,图二是网易的效果

是不是相差很大呢?人家下面的指示条是红色的,我们做出来的是蓝色的,人家选中Tab的字体颜色是红色,我们的不变色等等,那么我们要怎么才能做出网易新闻的那样子的效果,我们需要改变其style,改变如下

  1. <style name="Themes.ActionBarTab" parent="@style/Theme.Sherlock">
  2. <!-- 去除ActionBar的Divider -->
  3. <item name="actionBarDivider">@null</item>
  4. <!-- 设置ActionBar Tab的高度 -->
  5. <item name="actionBarSize">45dip</item>
  6. <!-- 设置ActionBar Tab字体的样式 -->
  7. <item name="actionBarTabTextStyle">@style/Widget.Sherlock.ActionBar.TabText</item>
  8. <!-- 设置ActionBar Tab的样式,例如下面的红色指引,Tab之间的间隙等等 -->
  9. <item name="actionBarTabStyle">@style/Widget.Sherlock.ActionBar.TabView</item>
  10. <!-- 设置ActionBar的样式,这里简单的设置了ActionBar的背景 -->
  11. <item name="actionBarStyle">@style/Widget.Slider.ActionBar</item>
  12. </style>
  13. <style name="Widget.Slider.ActionBar" parent="@style/Widget.Sherlock.ActionBar">
  14. <item name="backgroundStacked">@drawable/base_action_bar_bg</item>
  15. </style>
  16. <style name="Widget.Sherlock.ActionBar.TabText" parent="android:Widget.Holo.ActionBar.TabText">
  17. <item name="android:textColor">@drawable/selector_tabtext</item>
  18. <item name="android:textSize">15sp</item>
  19. </style>
  20. <style name="Widget.Sherlock.ActionBar.TabView" parent="Widget">
  21. <item name="android:background">@drawable/tab_indicator</item>
  22. <item name="android:paddingLeft">8dip</item>
  23. <item name="android:paddingRight">8dip</item>
  24. </style>

还有一些图片,selector我没有贴出来,可以去下载代码看看效果,改变style运行效果

好了,今天的讲解到此结束,有疑问的朋友请在下面留言,有兴趣的可以看看 开源框架ViewPageIndicator 和 ViewPager 仿网易新闻客户端Tab标签

源码下载,请点击

很多朋友说自己在4.1上面怎么设置style没效果,首先这个库是在2.X的机器上面使用ActionBar,3.0以后就是使用Andriod自带的ActionBar,所以在3.0以上的系统使用的style为android自带的style,所以我们要将style文件做下修改,如下

  1. <style name="Themes.ActionBarTab" parent="@style/Theme.Sherlock">
  2. <!-- 去除ActionBar的Divider -->
  3. <item name="actionBarDivider">@null</item>
  4. <item name="android:actionBarDivider">@null</item>
  5. <!-- 设置ActionBar Tab的高度 -->
  6. <item name="actionBarSize">45dip</item>
  7. <item name="android:actionBarSize">45dip</item>
  8. <!-- 设置ActionBar Tab字体的样式 -->
  9. <item name="actionBarTabTextStyle">@style/Widget.Sherlock.ActionBar.TabText</item>
  10. <item name="android:actionBarTabTextStyle">@style/Widget.Sherlock.ActionBar.TabText</item>
  11. <!-- 设置ActionBar Tab的样式,例如下面的红色指引,Tab之间的间隙等等 -->
  12. <item name="actionBarTabStyle">@style/Widget.Sherlock.ActionBar.TabView</item>
  13. <item name="android:actionBarTabStyle">@style/Widget.Sherlock.ActionBar.TabView</item>
  14. <!-- 设置ActionBar的样式,这里简单的设置了ActionBar的背景 -->
  15. <item name="actionBarStyle">@style/Widget.Slider.ActionBar</item>
  16. <item name="android:actionBarStyle">@style/Widget.Slider.ActionBar</item>
  17. </style>
  18. <style name="Widget.Slider.ActionBar" parent="@style/Widget.Sherlock.ActionBar">
  19. <item name="backgroundStacked">@drawable/base_action_bar_bg</item>
  20. <item name="android:backgroundStacked">@drawable/base_action_bar_bg</item>
  21. </style>
  22. <style name="Widget.Sherlock.ActionBar.TabText" parent="android:Widget.Holo.ActionBar.TabText">
  23. <item name="android:textColor">@drawable/selector_tabtext</item>
  24. <item name="android:textSize">15sp</item>
  25. </style>
  26. <style name="Widget.Sherlock.ActionBar.TabView" parent="Widget">
  27. <item name="android:background">@drawable/tab_indicator</item>
  28. <item name="android:paddingLeft">8dip</item>
  29. <item name="android:paddingRight">8dip</item>
  30. </style>

Android 开源框架ActionBarSherlock 和 ViewPager 仿网易新闻客户端的更多相关文章

  1. 类似掌盟的Tab页 Android 开源框架ViewPageIndicator 和 ViewPager 仿网易新闻客户端Tab标签 (转)

    原博客地址  :http://blog.csdn.net/xiaanming/article/details/10766053 本文转载,记录学习用,如有需要,请到原作者网站查看(上面这个网址) 之前 ...

  2. Android 开源框架ViewPageIndicator 和 ViewPager 仿网易新闻客户端Tab标签

    转载请注明出处:http://blog.csdn.net/xiaanming/article/details/10766053 之前用JakeWharton的开源框架ActionBarSherlock ...

  3. Android 开源框架ViewPageIndicator 和 ViewPager 仿网易新闻clientTab标签

    之前用JakeWharton的开源框架ActionBarSherlock和ViewPager实现了对网易新闻clientTab标签的功能,ActionBarSherlock是在3.0下面的机器支持Ac ...

  4. Android Studio精彩案例(一)《ActionBar和 ViewPager版仿网易新闻客户端》

    转载本专栏文章,请注明出处,尊重原创 .文章博客地址:道龙的博客 为了能更好的分享高质量的文章,所以开设了此专栏.文章代码都以Android Studio亲测运行,读者朋友可在后面直接下载源码.该专栏 ...

  5. Android开源框架ViewPageIndicator和ViewPager实现Tab导航

    前言: 关于使用ViewPageIndicator和ViewPager实现Tab导航,在开发社区里已经有一堆的博客对其进行了介绍,假设我还在这里写怎样去实现.那简直就是老生常谈,毫无新奇感,并且.我也 ...

  6. Android SlidingMenu 仿网易新闻客户端布局

    前面两篇文章中的SlidingMenu都出现在左侧,今天来模仿一下网易新闻客户端左右两边都有SlidingMenu的效果,以下是网易新闻客户端效果: 不扯闲话了,直接进入正题吧 frame_conte ...

  7. Android Studio精彩案例(四)《DrawerLayout使用详解仿网易新闻客户端侧边栏 》

    转载本专栏文章,请注明出处,尊重原创 .文章博客地址:道龙的博客 为了提高兴趣,咱们开头先看看最终要实现什么样的效果: 侧拉菜单在Android应用中非常常见,它的实现方式太多了,今天我们就说说使用G ...

  8. 分享一个仿网易新闻客户端iPhone版的标签式导航ViewController

    该Controller是一个容器,用于容纳其他的controller.效果与网易新闻客户端的标签式导航基本一样: (1)点击上面的标签,可以切换到对应的controller,标签下面的红色提示条的长度 ...

  9. Android 开源框架ActionBarSherlock初探

    1:我的开发环境是Ubuntu12.04下:adt-bundle-linux-x86-20130729. ActionBarSherlock下载地址:http://actionbarsherlock. ...

随机推荐

  1. POJ2241——The Tower of Babylon

    The Tower of Babylon Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 2207   Accepted: 1 ...

  2. Maven 工程下 Spring MVC 站点配置 (一)

    最近,查找一些具体资料时,虽然会有很多,但是系统的却很少,尤其是对maven 下 spring mvc 站点搭建的配置,总是说的很多但让新手一目了然的步骤却少之又少. 对此闲暇时整理了一下,做了一套较 ...

  3. SQL查询多行合并成一行

    问题描述:无论是在sql 2000,还是在 sql 2005 中,都没有提供字符串的聚合函数,  所以,当我们在处理下列要求时,会比较麻烦:有表tb, 如下:id    value----- ---- ...

  4. VS2003,安装程序检测到另一个程序…

    昨天在安装Visual Studio .Net 2003时,出现一个对话框   "安装程序检测到另一个程序要求计算机重新启动.必须重新启动计算机后才能安装visual studio.net系 ...

  5. OCMOCM

    14年,OCM考试费12000 15年,考试费19800 对于我来说,1,2年之后是否换工作还是个未知数 在本单位考这个貌似没什么用处,工资也不会突然就涨很多 跳槽的话,专门做数据库感觉压力还挺大 年 ...

  6. IOS中设置状态栏的状态

    IOS上 关于状态栏的相关设置(UIStatusBar) 知识普及 ios上状态栏 就是指的最上面的20像素高的部分 状态栏分前后两部分,要分清这两个概念,后面会用到: 前景部分:就是指的显示电池.时 ...

  7. JSP EL表达式详细介绍(转)

    转自:http://www.jb51.net/article/20042.htm 为了使JSP写起来更加简单. 表达式语言的灵感来自于 ECMAScript 和 XPath 表达式语言,它提供了在 J ...

  8. 在Vim中查看文件编码

    :set fileencoding 即可显示文件编码格式. 如果你只是想查看其它编码格式的文件或者想解决 用Vim查看文件乱码的问题,那么在 ~/.vimrc 文件中添加以下内容: set encod ...

  9. 解决在IE浏览器下 boder边框出现断裂或虚线的问题

    ie6.0下面经常会出现border边框断断续续的问题,等深一步了解了div之后自然会经常碰到这种问题了,不过初学div+css 的一般不会用遇到这个问题,因为初学者不会偷懒,等我们觉得用的很熟了,各 ...

  10. 发现一个不错的学习git的地方

    Git入门:http://rogerdudler.github.io/git-guide/index.zh.html 简洁.实用.高效的学习git基本操作的方式