| 一、ActionBar概述 |
ActionBar是android3.0以后新增的組件,主要用於標示應用程序以及用戶所處的位置並提供相關操作以及全局的導航功能。下面我們就看看如何使用ActionBar,真正使用之前,我們應該首先了解一下ActionBar的結構。
根據官方文檔,我們看到整個ActionBar可以分為4個部分,具體如下圖:

1、 App icon:主要用於展示App的Logo,如果當前界面不是一級界面,還可以展示返回導航。
2、 View Control:用於切換不同的視圖或者展示非交互信息如app標題等。
3、 Action Buttons:用於展示app中最重要的操作按鈕,如果過多actionbar中放不下則會轉移到Action overflow中,長按會展示操作名稱。根據文檔說明,Action Buttons的總寬度不會超過ActionBar的50%。
4、 Action overflow:用於存放展示相對較少使用的操作按鈕。
了解了ActionBar的基本結構后,下面我們一起看看如何使用ActionBar。
| 二、ActionBar的使用 |
因為actionbar是android3.0之后新增的所以如果在API Level 11以下的版本使用actionBar的話需要導入v7支持包,在這里我們為了兼容低版本需要加入支持包,然后通過以下兩個步驟就可以使用ActionBar了。
1、 創建Activity是繼承ActionBarActivity
之后運行程序可以看到如下效果圖:

如果不想展示ActionBar,我們可以通過如下代碼:
//取得ActionBar對象 ActionBar actionBar =getSupportActionBar(); //調用hide方法,隱藏actionbar actionBar.hide(); //調用show方法,展示actionbar //actionBar.show();
根據actionBar的結構,我們先了解App icon區域的相關操作,此部分主要有兩個部分,一部分用於展示Logo,一部分用於展示返回鍵導航,返回鍵導航主要操作如下:
1、 返回鍵導航的顯示與隱藏:setDisplayHomeAsUpEnabled(Boolean flag)
2、 返回鍵導航的圖標設置:setHomeAsUpIndicator
3、 返回鍵的事件處理:重寫onOptionsItemSelected方法,做如下判斷
if(id==android.R.id.home){ Toast.makeText(this,"點擊了返回!!",Toast.LENGTH_SHORT).show(); return true; }
效果圖如下:

Logo區主要操作:
1、 Logo的顯示與隱藏:
setDisplayShowHomeEnabled(Boolean flag)
setDisplayUseLogoEnabled(Boolean flag)
2、 Logo的設置:setLogo
設置后效果圖如下:

第二部分是View Control區,此區域可放置內容比較多,除了用於視圖導航的Spinner、tabs、ShareActionProvider,還可以顯示標題等信息、自定義View等。本次內容我們先來看看標題部分,其余的下次再做仔細詳細介紹。
主要操作:
1、 顯示與隱藏標題:setDisplayShowTitleEnabled(Boolean flag)
2、 設置主標題:setTitle
3、 設置副標題:setSubtitle
4、 設定自定義View:setCustomView
顯示效果如下圖:

Action Buttons和Action flow 的操作類似,都是用於存放展示操作按鈕,那么如何將操作按鈕顯示在actionbar中呢?
在這里,我們可以分為兩步:
1、 重寫onCreateOptionsMenu,此方法用於生成菜單按鈕,有兩種方式,一種方式編寫xml文件,另外一種是java代碼生成,這里我們選擇編寫xml。
2、 重寫onOptionsItemSelected,此方法用於響應菜單操作。
Xml內容如下:
<menu xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" tools:context=".MainActivity"> <item android:id="@+id/action_search" android:title="搜索" android:orderInCategory="100" app:showAsAction="always" android:icon="@drawable/ic_launcher"/> <item android:id="@+id/action_share" android:title="分享" android:orderInCategory="100" app:showAsAction="never" /> <item android:id="@+id/action_collection" android:title="收藏" android:orderInCategory="100" app:showAsAction="never" /> <item android:id="@+id/action_font" android:title="字體大小" android:orderInCategory="100" app:showAsAction="never" /> </menu>
ShowAsAction是非常重要的屬性,它的值決定了菜單顯示區域,分別有never、always、ifroom等
效果如下:


想要了解更多內容的小伙伴,可以點擊查看源碼,親自運行測試。
出處: http://www.cnblogs.com/jerehedu/
本文版權歸煙台傑瑞教育科技有限公司和博客園共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,否則保留追究法律責任的權利。
