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

在上一篇文章中,我们只是大概的了解了一下关于ActionBar这个类的简单用法,今天我会继续以实例进行更加深入的讲解。

一、实现Tab选项标签

当你想要在一个Activity中提供Tab选项卡时,使用ActionBar的Tab选项标签是一个非常好的选择(而不是使用TabWidget类),因为系统会调整ActionBar的选项标签来适应不同尺寸的屏幕的需要,比如在屏幕足够宽的时候,Tab选项标签会被放到主操作栏中;当屏幕太窄的时候,Tab选项标签会被放到一个分离的横条中,如图1和图2所示:

图1

图2

要想使用Tab选项标签在Fragmengt之间切换,你必须在每次选择一个选项标签时执行一个Fragment事务。如果你不熟悉如何使用FragmentTransaction对象来改变Fragment,请阅读博主前面的文章Fragment的详细介绍和使用方法

首先,你的布局必须包含一个用于放置跟每个Fragment对象关联的选项标签的ViewGroup对象。并且要确保这个ViewGroup对象有一个资源ID,以便你能够在选项标签的切换代码中能够引用它。另外,如果选项标签的内容填充在Activity的布局中(不包括操作栏),那么Activity不需要任何布局(你甚至不需要调用setContentView()方法)。相反,你能够把每个Fragment对象放到默认的根ViewGroup对象中,你能够用android.R.id.content ID来引用这个ViewGroup对象(在Fragment执行事务期间,你能够在下面的示例代码中看到如何使用这个ID的。

决定了Fragment对象在布局中的显示位置后,添加Tab选项标签的基本过程如下:

<1> 实现ActionBar.TabListener接口。这个接口中回调方法会响应选项标签上的用户事件,以便你能够切换Fragment对象;

<2> 对于每个要添加的选项标签,都要实例化一个ActionBar.Tab对象,并且调用setTabListener()方法设置ActionBar.Tab对象的事件监听器。还可以用setText()或setIcon()方法来设置选项标签的标题或图标;

<3> 通过调用addTab()方法,把每个选项标签添加到操作栏。

二、实现Tab选项标签效果图

三、项目结构图

四、详细代码编写

1、在上面的效果图中,标题栏的最右边有一个时钟,这个效果纯属娱乐,实现的方法也很简单,在menu的布局文件中定义一个活动视图Action View,main.xml:

[html] view plaincopy
  1. <menu xmlns:android="http://schemas.android.com/apk/res/android" >
  2. <item
  3. android:id="@+id/action_clock"
  4. android:orderInCategory="100"
  5. android:showAsAction="always"
  6. android:title="@string/action_settings"
  7. android:actionLayout="@layout/clock"/>
  8. </menu>

2、在写一个时钟的布局文件,clock.xml:

[html] view plaincopy
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="match_parent"
  4. android:layout_height="match_parent"
  5. android:orientation="vertical" >
  6. <AnalogClock
  7. android:id="@+id/analogClock1"
  8. android:layout_width="wrap_content"
  9. android:layout_height="wrap_content" />
  10. </LinearLayout>

3、在定义一个布局文件用来存放Fragment的布局,列出其中一个,fragment_1.xml:

[html] view plaincopy
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="fill_parent"
  4. android:layout_height="fill_parent" >
  5. <ImageView
  6. android:id="@+id/imageview"
  7. android:layout_width="fill_parent"
  8. android:layout_height="fill_parent"
  9. android:scaleType="fitCenter"
  10. android:src="@drawable/xianjian01" >
  11. </ImageView>
  12. </LinearLayout>

4、定义一个类实现ActionBar.TabListener的接口,在这个实现中,每个Tab选项标签都使用了它自己的监听器,MyTabListener.java:

[java] view plaincopy
  1. package com.yangyu.myactionbar02;
  2. import android.app.ActionBar.Tab;
  3. import android.app.ActionBar.TabListener;
  4. import android.app.Activity;
  5. import android.app.Fragment;
  6. import android.app.FragmentTransaction;
  7. public class MyTabListener<T extends Fragment> implements TabListener {
  8. private Fragment fragment;
  9. private final Activity mActivity;
  10. private final Class<T> mClass;
  11. public MyTabListener(Activity activity, Class<T> clz){
  12. mActivity = activity;
  13. mClass = clz;
  14. }
  15. @Override
  16. public void onTabSelected(Tab tab, FragmentTransaction ft) {
  17. if(fragment == null){
  18. fragment = Fragment.instantiate(mActivity, mClass.getName());
  19. ft.add(android.R.id.content, fragment, null);
  20. }
  21. ft.attach(fragment);
  22. }
  23. @Override
  24. public void onTabUnselected(Tab tab, FragmentTransaction ft) {
  25. if (fragment != null) {
  26. ft.detach(fragment);
  27. }
  28. }
  29. @Override
  30. public void onTabReselected(Tab tab, FragmentTransaction ft) {
  31. }
  32. }

       警告:针对每个回调中的Fragment事务,你都不必调用commit()方法,因为系统会调用这个方法,并且如果你自己调用了这个方法,有可能会抛出一个异常。你也不能把这些Fragment事务添加到回退堆栈中。

在这段代码中,当对应的选项标签被选择时,监听器只是简单的把一个Fragment对象附加(attach()方法)到Activity布局上,或者如果没有实例化,就会创建这个Fragment对象,并且把它添加(add()方法)到布局中(android.R.id.content ViewGroup的一个子类),当这个选项标签解除选择时,对应的Fragment对象也会被解除与布局的依附关系。

5、ActionBar.TabListener的实现做了大量的工作,剩下的事情就是创建每个ActionBar.Tab对象并把它添加到ActionBar对象中,另外,你必须调用setNavigationMode(NAVIGATION_MODE_TABS)方法来让选项标签可见。如果选项标签的标题实际指示了当前的View对象,你也可以通过调用setDisplayShowTitleEnabled(false)方法来禁用Activity的标题,MainActivity.java:

[java] view plaincopy
  1. package com.yangyu.myactionbar02;
  2. import android.app.ActionBar;
  3. import android.app.Activity;
  4. import android.os.Bundle;
  5. import android.view.Menu;
  6. public class MainActivity extends Activity {
  7. @Override
  8. protected void onCreate(Bundle savedInstanceState) {
  9. super.onCreate(savedInstanceState);
  10. setContentView(R.layout.activity_main);
  11. initView();
  12. }
  13. /**
  14. * 初始化组件
  15. */
  16. private void initView(){
  17. // 提示getActionBar方法一定在setContentView后面
  18. final ActionBar actionBar = getActionBar();
  19. actionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_TABS);
  20. actionBar.setDisplayOptions(0, ActionBar.DISPLAY_SHOW_TITLE);
  21. actionBar.addTab(actionBar.newTab().setText("Tab选项卡一").setTabListener(new MyTabListener<FragmentPage1>(this,FragmentPage1.class)));
  22. actionBar.addTab(actionBar.newTab().setText("Tab选项卡二").setTabListener(new MyTabListener<FragmentPage2>(this,FragmentPage2.class)));
  23. }
  24. @Override
  25. public boolean onCreateOptionsMenu(Menu menu) {
  26. getMenuInflater().inflate(R.menu.main, menu);
  27. return true;
  28. }
  29. }

注意:以上有关ActionBar.TabListener的实现,只是几种可能的技术之一。在API Demos应用中你能够看到更多的这种样式。

如果Activity终止了,那么你应该保存当前选择的选项标签的状态,以便当用户再次返回时,你能够打开合适的选项标签。在保存状态的时刻,你能够用getSelectedNavigationIndex()方法查询当前的被选择的选项标签。这个方法返回被选择的选项标签的索引位置。

警告:保存每个Fragment所必须的状态是至关重要的,因为当用户用选项标签在Fragment对象间切换时,它会查看Fragment在离开时样子。

注意:在某些情况下,Android系统会把操作栏选项标签作为一个下拉列表来显示,以便确保操作栏的最优化显示。

6、最后再列出一个显示Fragment的类,FragmentPage1.java:

[java] view plaincopy
  1. package com.yangyu.myactionbar02;
  2. import android.app.Fragment;
  3. import android.os.Bundle;
  4. import android.view.LayoutInflater;
  5. import android.view.View;
  6. import android.view.ViewGroup;
  7. public class FragmentPage1 extends Fragment{
  8. @Override
  9. public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
  10. return inflater.inflate(R.layout.fragment_1, null);
  11. }
  12. }

五、实现下拉导航列表

     作为Activity内部的另一种导航(或过滤)模式,操作栏提供了内置的下拉列表。下拉列表能够提供Activity中内容

的不同排序模式。

启用下拉式导航的基本过程如下:

<1> 创建一个给下拉提供可选项目的列表,以及描画列表项目时所使用的布局;

<2> 实现ActionBar.OnNavigationListener回调,在这个回调中定义当用户选择列表中一个项目时所发生的行为;

<3> 用setNavigationMode()方法该操作栏启用导航模式;

<4> 用setListNavigationCallbacks()方法给下拉列表设置回调方法。

 六、下拉导航实现效果图

七、项目结构图

八、详细代码编写

1、这段代码比较简单,主要是调用了SpinnerAdapter和ActionBar.OnNavigationListener对象

[java] view plaincopy
  1. package com.yangyu.myactionbar03;
  2. import android.app.ActionBar;
  3. import android.app.Activity;
  4. import android.os.Bundle;
  5. import android.view.Menu;
  6. import android.widget.ArrayAdapter;
  7. import android.widget.SpinnerAdapter;
  8. public class MainActivity extends Activity {
  9. @Override
  10. protected void onCreate(Bundle savedInstanceState) {
  11. super.onCreate(savedInstanceState);
  12. setContentView(R.layout.activity_main);
  13. initView();
  14. }
  15. /**
  16. * 初始化组件
  17. */
  18. private void initView(){
  19. ActionBar actionBar = getActionBar();
  20. actionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_LIST);
  21. //定义一个下拉列表数据适配器
  22. SpinnerAdapter mSpinnerAdapter = ArrayAdapter.createFromResource(this,
  23. R.array.action_list,
  24. android.R.layout.simple_spinner_dropdown_item);
  25. actionBar.setListNavigationCallbacks(mSpinnerAdapter, new ActionBar.OnNavigationListener() {
  26. @Override
  27. public boolean onNavigationItemSelected(int itemPosition, long itemId) {
  28. return true;
  29. }
  30. });
  31. }
  32. @Override
  33. public boolean onCreateOptionsMenu(Menu menu) {
  34. getMenuInflater().inflate(R.menu.main, menu);
  35. return true;
  36. }
  37. }
  38. 源码下载(Tab选项标签)
  39. 源码下载(下拉列表)

【Android UI设计与开发】第11期:顶部标题栏(二)ActionBar实现Tab选项卡和下拉导航列表相关推荐

  1. 【Android UI设计与开发】5.底部菜单栏(二)使用Fragment实现底部菜单栏

    既然 Fragment 取代了TabActivity,当然 TabActivity 的能实现的菜单栏,Fragment 当然也能实现.主要其实就是通过菜单栏的点击事件切换 Fragment 的显示和隐 ...

  2. 【Android UI设计与开发】第13期:顶部标题栏(四)自定义ActionBar风格和样式

    转载请注明出处:http://blog.csdn.net/yangyu20121224/article/details/9087941   这篇文章将对ActionBar专题前面几篇学习过的内容做一个 ...

  3. 【Android UI设计与开发】9:滑动菜单栏(一)开源项目SlidingMenu的使用和示例-转...

    一.SlidingMenu简介 相信大家对SlidingMenu都不陌生了,它是一种比较新的设置界面或配置界面的效果,在主界面左滑或者右滑出现设置界面效果,能方便的进行各种操作.很多优秀的应用都采用了 ...

  4. 【Android UI设计与开发】第02期:引导界面(二)使用ViewPager实现欢迎引导页面

    转载请注明出处:http://blog.csdn.net/yangyu20121224/article/details/8980917 本系列文章都会以一个程序的实例开发为主线来进行讲解,以求达到一个 ...

  5. android ui设计与开发工具,Android用户体验与UI设计

    Android用户体验与UI设计 编辑 锁定 讨论 上传视频 本词条缺少概述图,补充相关内容使词条更完整,还能快速升级,赶紧来编辑吧! 本书是一部介绍Android用户体验.UI设计理念和方法论的作品 ...

  6. 【Android UI设计与开发】第10期:顶部标题栏(一)ActionBar详细概述和简单示例

    转载请注明出处:http://blog.csdn.net/yangyu20121224/article/details/9042387   由于是刚开始写博客,所以一开始在格式上也没有太在意,今天偶然 ...

  7. 【Android UI设计与开发】第09期:底部菜单栏(四)Fragment+PopupWindow仿QQ空间最新版底部菜单栏

    转载请注明出处:http://blog.csdn.net/yangyu20121224/article/details/9023451          在今天的这篇文章当中,我依然会以实战加理论结合 ...

  8. 【Android UI设计与开发】第06期:底部菜单栏(一)使用TabActivity实现底部菜单栏

    转载请注明出处:http://blog.csdn.net/yangyu20121224/article/details/8989063       从这一篇文章开始,我们将进入到一个应用程序主界面UI ...

  9. 【Android UI设计与开发】第05期:引导界面(五)实现应用程序只启动一次引导界面

    转载请注明出处:http://blog.csdn.net/yangyu20121224/article/details/8987342  这篇文章算是对整个引导界面开发专题的一个终结了吧,个人觉得大部 ...

最新文章

  1. MySQL xtrabackup之--databases 勿手贱
  2. 软件工程第八次作业-2017282110249
  3. java null 转空_java 对象属性为 null 值转为 空串
  4. linux内核中的循环缓冲区
  5. linux软件读取不到空间,Linux下Oracle软件、数据文件等所在的磁盘分区空间不足的解决思路...
  6. 基于JAVA+SpringMVC+Mybatis+MYSQL的酒店食品仓库管理系统
  7. esp8266驱动_ESP8266配置windows版
  8. Android开发笔记(三十九)Activity的生命周期
  9. Hbuilder启动夜神游模拟器失败,解决方案
  10. 新的一年,谈谈我对技术架构的理解
  11. 手机号 ,邮箱,固定电话js验证,身份证号(正则表达式)
  12. P3194 [HNOI2008]水平可见直线
  13. Java Serializable 序列化 与 对象克隆
  14. PAIP.img ROM文件提取APK
  15. 软件单元测试数据分析模板,单元测试报告模板
  16. Pr 入门教程如何修改过渡效果设置?
  17. win10c语言乱码修复方法,大神详解win10系统记事本中文变乱码的处理方案
  18. 【这是程序设计基础的50道题目】
  19. Python笔记 No.1 - Python函数及装饰器
  20. 物联网开发常用的开发板_物联网开发人员简介:物联网开发人员调查的结果

热门文章

  1. python中rename函数_python os.rename(…)不起作用!
  2. asp.net core学习笔记
  3. 10个顶级的CSS UI开源框架
  4. fatal error LNK1123: 转换到 COFF 期间失败
  5. php引用计数的基本知识
  6. 支持html5浏览器速查
  7. CentOS7 搭建GIT环境
  8. c# 之Web.config
  9. 【转】HTTP Header 详解
  10. PAT 1041. 考试座位号(15)