❶ 如何設置全部的activity使用一個actionbar
<item
android:id="@+id/action_clock"
android:orderInCategory="100"
android:showAsAction="always"
android:title="@string/action_settings"
android:actionLayout="@layout/clock"/>
</menu>
2、在寫一個時鍾的布局文件,clock.xml:
[html] view plain
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<AnalogClock
android:id="@+id/analogClock1"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
</LinearLayout>
3、在定義一個布局文件用來存放Fragment的布局,列出其中一個,fragment_1.xml:
[html] view plain
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
<ImageView
android:id="@+id/imageview"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:scaleType="fitCenter"
android:src="@drawable/xianjian01" >
</ImageView>
</LinearLayout>
4、定義一個類實現ActionBar.TabListener的介面,在這個實現中,每個Tab選項標簽都使用了它自己的監聽器,MyTabListener.java:
[java] view plain
package com.yangyu.myactionbar02;
import android.app.ActionBar.Tab;
import android.app.ActionBar.TabListener;
import android.app.Activity;
import android.app.Fragment;
import android.app.FragmentTransaction;
public class MyTabListener<T extends Fragment> implements TabListener {
private Fragment fragment;
private final Activity mActivity;
private final Class<T> mClass;
public MyTabListener(Activity activity, Class<T> clz){
mActivity = activity;
mClass = clz;
}
@Override
public void onTabSelected(Tab tab, FragmentTransaction ft) {
if(fragment == null){
fragment = Fragment.instantiate(mActivity, mClass.getName());
ft.add(android.R.id.content, fragment, null);
}
ft.attach(fragment);
}
@Override
public void onTabUnselected(Tab tab, FragmentTransaction ft) {
if (fragment != null) {
ft.detach(fragment);
}
}
@Override
public void onTabReselected(Tab tab, FragmentTransaction ft) {
}
}
❷ android item布局,弄成新版微信的UI那樣。
menu/items.xml
<item
android:id="@+id/search"
android:title="Search"
android:showAsAction="ifRoom|collapseActionView"
android:actionLayout="@layout/menu_layout"
/>
你可以在menu_layout裡面做一個類似威信那樣的。
(Menumenu){
/**Createanoptionmenufromres/menu/items.xml*/
getMenuInflater().inflate(R.menu.items,menu);
/***/
Viewv=(View)menu.findItem(R.id.search).getActionView();
/***/
EditTexttxtSearch=(EditText)v.findViewById(R.id.txt_search);
returnsuper.onCreateOptionsMenu(menu);
}
❸ 如何設置全部的Activity使用一個actionbar
<menu xmlns:android="http://schemas.android.com/apk/res/android" >
<item
android:id="@+id/action_clock"
android:orderInCategory="100"
android:showAsAction="always"
android:title="@string/action_settings"
android:actionLayout="@layout/clock"/>
</menu>
2、在寫一個時鍾的布局文件,clock.xml:
[html] view plain
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<AnalogClock
android:id="@+id/analogClock1"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
</LinearLayout>
3、在定義一個布局文件用來存放Fragment的布局,列出其中一個,fragment_1.xml:
[html] view plain
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
<ImageView
android:id="@+id/imageview"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:scaleType="fitCenter"
android:src="@drawable/xianjian01" >
</ImageView>
</LinearLayout>
4、定義一個類實現ActionBar.TabListener的介面,在這個實現中,每個Tab選項標簽都使用了它自己的監聽器,MyTabListener.Java:
[java] view plain
package com.yangyu.myactionbar02;
import android.app.ActionBar.Tab;
import android.app.ActionBar.TabListener;
import android.app.Activity;
import android.app.Fragment;
import android.app.FragmentTransaction;
public class MyTabListener<T extends Fragment> implements TabListener {
private Fragment fragment;
private final Activity mActivity;
private final Class<T> mClass;
public MyTabListener(Activity activity, Class<T> clz){
mActivity = activity;
mClass = clz;
}
@Override
public void onTabSelected(Tab tab, FragmentTransaction ft) {
if(fragment == null){
fragment = Fragment.instantiate(mActivity, mClass.getName());
ft.add(android.R.id.content, fragment, null);
}
ft.attach(fragment);
}
@Override
public void onTabUnselected(Tab tab, FragmentTransaction ft) {
if (fragment != null) {
ft.detach(fragment);
}
}
@Override
public void onTabReselected(Tab tab, FragmentTransaction ft) {
}
}
❹ 如何在android開發使用ACTION
需要注意幾點,SDK和最終運行的固件必須是Android 3.0即honeycomb,在androidmanifest.xml文件中的uses-sdk元素中加入android:minSdkVersion 或android:targetSdkVersion,類似<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.android123.cwj"
android:versionCode="1"
android:versionName="1.0">
<uses-sdk android:minSdkVersion="honeycomb" />
<application ... >
...
</application>
</manifest>
如果需要隱藏Action Bar可以在的Activity的屬性中設置主題風格為NoTitleBar在你的manifest文件中,下面的代碼在3.0以前是隱藏標題,而在3.0以後就是隱藏ActionBar了,代碼為
<activity android:theme="<a href="http://my.oschina.net/asia" class="referer" target="_blank">@android</a> :style/Theme.NoTitleBar"
一、添加活動條目 Action Items
對於活動條目大家可以在下圖看到Android 3.0的標題右部分可以變成工具欄,下面的Save和Delete就是兩個Action Items活動條目
下面是一個menu的layout布局文件代碼
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<item android:id="@+id/menu_add"
; android:icon="@drawable/ic_menu_save"
; android:title="@string/menu_save"
; android:showAsAction="ifRoom|withText" />
</menu>
而其他代碼類似Activity中的Menu,比如
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case android.R.id.home:
// 當Action Bar的圖標被單擊時執行下面的Intent
Intent intent = new Intent(this, Android123.class);
startActivity(intent);
break;
}
return super.onOptionsItemSelected(item);
}
對於ActionBar的創建,可以在你的Activity中重寫onStart方法
@Override
protected void onStart() {
super.onStart();
ActionBar actionBar = this.getActionBar();
actionBar.setDisplayOptions(ActionBar.DISPLAY_HOME_AS_UP, ActionBar.DISPLAY_HOME_AS_UP);
}
調用getActionBar方式在你的Activity的onCreate中時需要注意必須在調用了setContentView之後。
二、添加活動視圖 Action View
對於Action View你可以自己定義視圖,比如搜索視圖,android.widget.SearchView控制項,
對於ActionView,我們可以在menu的布局文件使用中來自定義searchview布局,如代碼
<item android:id="@+id/menu_search"
; android:title="Search"
android:icon="@drawable/ic_menu_search"
; android:showAsAction="ifRoom"
android:actionLayout="@layout/searchview" ;/>
也可以直接指定Android系統中的SearchView控制項,那麼這時menu」_search的代碼要這樣寫
<item android:id="@+id/menu_search"
; android:title="Search"
android:icon="@drawable/ic_menu_search"
; android:showAsAction="ifRoom"
android:actionViewClass="android.widget.SearchView" />
兩種方法中一個屬性是actionLayout制定一個layout xml布局文件,一個是actionViewClass指定一個類,最終調用可以在Activity中響應onCreateOptionsMenu方法映射這個menu布局即可。
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.options, menu);
SearchView searchView = (SearchView) menu.findItem(R.id.menu_search).getActionView();
return super.onCreateOptionsMenu(menu);
}
❺ 如何在android開發使用ACTION
需要注意幾點,SDK和最終運行的固件必須是Android 3.0即honeycomb,在androidmanifest.xml文件中的uses-sdk元素中加入android:minSdkVersion 或android:targetSdkVersion,類似<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.android123.cwj"
android:versionCode="1"
android:versionName="1.0">
<uses-sdk android:minSdkVersion="honeycomb" />
<application ... >
...
</application>
</manifest>
如果需要隱藏Action Bar可以在的Activity的屬性中設置主題風格為NoTitleBar在你的manifest文件中,下面的代碼在3.0以前是隱藏標題,而在3.0以後就是隱藏ActionBar了,代碼為
<activity android:theme="<a href="http://my.oschina.net/asia" class="referer" target="_blank">@android</a> :style/Theme.NoTitleBar"
一、添加活動條目 Action Items
對於活動條目大家可以在下圖看到Android 3.0的標題右部分可以變成工具欄,下面的Save和Delete就是兩個Action Items活動條目
下面是一個menu的layout布局文件代碼
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<item android:id="@+id/menu_add"
; android:icon="@drawable/ic_menu_save"
; android:title="@string/menu_save"
; android:showAsAction="ifRoom|withText" />
</menu>
而其他代碼類似Activity中的Menu,比如
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case android.R.id.home:
// 當Action Bar的圖標被單擊時執行下面的Intent
Intent intent = new Intent(this, Android123.class);
startActivity(intent);
break;
}
return super.onOptionsItemSelected(item);
}
對於ActionBar的創建,可以在你的Activity中重寫onStart方法
@Override
protected void onStart() {
super.onStart();
ActionBar actionBar = this.getActionBar();
actionBar.setDisplayOptions(ActionBar.DISPLAY_HOME_AS_UP, ActionBar.DISPLAY_HOME_AS_UP);
}
調用getActionBar方式在你的Activity的onCreate中時需要注意必須在調用了setContentView之後。
二、添加活動視圖 Action View
對於Action View你可以自己定義視圖,比如搜索視圖,android.widget.SearchView控制項,
對於ActionView,我們可以在menu的布局文件使用中來自定義searchview布局,如代碼
<item android:id="@+id/menu_search"
; android:title="Search"
android:icon="@drawable/ic_menu_search"
; android:showAsAction="ifRoom"
android:actionLayout="@layout/searchview" ;/>
也可以直接指定Android系統中的SearchView控制項,那麼這時menu」_search的代碼要這樣寫
<item android:id="@+id/menu_search"
; android:title="Search"
android:icon="@drawable/ic_menu_search"
; android:showAsAction="ifRoom"
android:actionViewClass="android.widget.SearchView" />
兩種方法中一個屬性是actionLayout制定一個layout xml布局文件,一個是actionViewClass指定一個類,最終調用可以在Activity中響應onCreateOptionsMenu方法映射這個menu布局即可。
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.options, menu);
SearchView searchView = (SearchView) menu.findItem(R.id.menu_search).getActionView();
return super.onCreateOptionsMenu(menu);
}
❻ 如何自定義 ShareActionProvider 中Android
下面我們從下拉導航、視窗操作、標簽導航三個方面逐一討論ActionBar
第一,下拉導航
下拉導航最典型的應用場景就是在Google+中的使用,效果如下圖:
圖1;Google+ 圖2:本文示例
實現此效果分如下幾個步驟:
1.初始化一個SpinnerAdapter
[java] view plain
SpinnerAdapter mSpinnerAdapter = ArrayAdapter.createFromResource(this,
R.array.action_list,
android.R.layout.simple_spinner_dropdown_item);
2.生成一個OnNavigationListener來響應ActionBar的菜單項點擊操作
[java] view plain
/**
* 在這里配合Fragment,實現不同的頁面導航
*/
OnNavigationListener mOnNavigationListener = new OnNavigationListener() {
@Override
public boolean onNavigationItemSelected(int position, long itemId) {
Fragment newFragment = null;
switch (position) {
case 0:
newFragment = new Fragment1();
break;
case 1:
newFragment = new Fragment2();
break;
case 2:
newFragment = new Fragment3();
break;
default:
break;
}
getSupportFragmentManager().beginTransaction()
.replace(R.id.container, newFragment, strings[position])
.commit();
return true;
}
};
3,將生成好的適配去和監聽器塞給ActionBar
[java] view plain
actionBar = getActionBar();
actionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_LIST);//導航模式必須設為NAVIGATION_MODE_LIST
actionBar.setListNavigationCallbacks(mSpinnerAdapter,
mOnNavigationListener);
第二,操作視窗
先上效果圖
圖3 圖4 圖5
在上面的操作視窗里,增加了一個用於搜索的可選菜單項以及分享和設置的兩個自定義ActionProVider。那麼如何在一個活動中,在已有的ActionBar上添加這些操作視窗。同創建可選菜單一樣,定義options.xml的menu文件如下:
[html] view plain
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android" >
<item
android:id="@+id/menu_search"
android:actionViewClass="android.widget.SearchView"
android:icon="@drawable/ic_menu_search"
android:showAsAction="ifroom"
android:title="搜索"/>
<item
android:id="@+id/menu_share"
android:actionProviderClass="android.widget.ShareActionProvider"
android:showAsAction="never"
android:title="分享"/>
<item
android:id="@+id/menu_setting"
android:actionProviderClass="com.example.tabdemo.MyActionProvider"
android:showAsAction="never"
android:title="設置">
<menu>
<item
android:id="@+id/menu_theme"
android:actionProviderClass="com.example.tabdemo.MyActionProvider"
android:showAsAction="always|withText"
android:title="更換主題"/>
<item
android:id="@+id/menu_system"
android:actionProviderClass="com.example.tabdemo.MyActionProvider"
android:showAsAction="always|withText"
android:title="系統設置"/>
</menu>
</item>
</menu>
仔細觀察可以發現每個Item里都包含如下這兩個屬性:
[html] view plain
android:actionProviderClass="com.example.tabdemo...."
[html] view plain
android:showAsAction=""
對於actionProviderClass屬性用來指定一個構建視窗所使用的布局資源,除了使用actionProviderClass指定外,還可以使用actionLayout或者actionViewClass都可以。SearchView和ShareActionProvider都是系統自帶的ActionProvider,MyActionProvider是我們要重寫的,後面將會看到如何去自定義一個ActionProvider。
showAsAction屬性共有五個值:ifRoom、never、always、withText、collapseActionView,可以混合使用。
ifRoom 會顯示在Item中,但是如果已經有4個或者4個以上的Item時會隱藏在溢出列表中。當然個
數並不僅僅局限於4個,依據屏幕的寬窄而定
never 永遠不會顯示。只會在溢出列表中顯示,而且只顯示標題,所以在定義item的時候,最好
把標題都帶上。
always 無論是否溢出,總會顯示。
withText withText值示意Action bar要顯示文本標題。Action bar會盡可能的顯示這個
標題,但是,如果圖標有效並且受到Action bar空間的限制,文本標題有可
能顯示不全。
collapseActionView 聲明了這個操作視窗應該被折疊到一個按鈕中,當用戶選擇這個按鈕時,這個操作視窗展開。否則,
這個操作視窗在默認的情況下是可見的,並且即便在用於不適用的時候,也要佔據操作欄的有效空間。
一般要配合ifRoom一起使用才會有效果。
註: 當你的應用程序正在Android4.0(API 級別 14)或以上的版本上運行,那麼還有一種叫做「分隔操作欄」的額外模式對action bar有效。當你啟用分隔操作欄模式時,在屏幕的底部會顯示一個獨立的橫條,用於顯示Activity在窄屏設備(如豎屏手機)上運行時的所有操作項。這里我們不過過多描述,有興趣自己去研究。
就像載入menu一樣,在activity的onCreateOptionsMenu方法里調用上述的xml文件:
[java] view plain
getMenuInflater().inflate(R.menu.options, menu);
//搜索視窗,因為showAsAction="ifRoom",所以圖三中出現了搜索按鈕
SearchView searchView = (SearchView) menu.findItem(R.id.menu_search)
.getActionView();
//分享視窗,因為showAsAction="never",所以只能在溢出菜單中才看見到
ShareActionProvider mShareActionProvider = (ShareActionProvider) menu
.findItem(R.id.menu_share).getActionProvider();
Intent shareIntent = new Intent(Intent.ACTION_SEND);
shareIntent.setType("image/*");
mShareActionProvider.setShareIntent(shareIntent);
//設置視窗,MyActionProvider就是我們自定義的ActionProvider
MyActionProvider myactionprovider = (MyActionProvider) menu.findItem(
R.id.menu_setting).getActionProvider();
return super.onCreateOptionsMenu(menu);
顯然,當成功運行的時候,結果如圖三,當點擊搜索按鈕時,搜索按鈕立刻變成了如圖四的樣子,變成可折疊的操作視窗。
如何自定義操作視窗,定義一個類MyActionProvider繼承自ActionProvider,並實現它的兩口回調函數即可。如下:
[java] view plain
/**
* @ClassName: MyActionProvider
* @Description: 自定義一個視窗操作器,實現構造函數和onCreateActionView即可
* @author yuxianglong
* @date 2013-7-11 下午3:13:44
*
*/
public class MyActionProvider extends ActionProvider{
private Context context;
private LayoutInflater inflater;
private View view;
private ImageView button;
public MyActionProvider(Context context) {
super(context);
// TODO Auto-generated constructor stub
this.context = context;
inflater = LayoutInflater.from(context);
view = inflater.inflate(R.layout.myactionprovider, null);
}
如此一來,只要在options.xml里直接引用。運行成功效果如圖五,點擊溢出菜單,設置按鈕出來了,如果繼續點下去,回調出它的子菜單,因為我們在options.xml里給自定義的ActionProvider分配了子菜單。
當然了,最顯眼的就是處理Action Bar上的應用程序圖標,平時玩手機多的同學應該可以發現,好多應用的圖標都是可以點擊的,而且大多數都是回到了上一個Activity,或者說是主Activity。那麼,如何觸發應用程序圖標呢,說白了應用程序圖標也是一個菜單,並且其id是規定死的,所以只要我們在onOptionsItemSelected方法里去捕捉它的點擊事件,做出響應:
[java] view plain
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId())
{
case android.R.id.home:
Intent intent = new Intent(this, HomeActivity.class);
intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
startActivity(intent);
return true;
default:
return super.onOptionsItemSelected(item);
}
}
我們給Intent添加了FLAG_ACTIVITY_CLEAR_TOP標識,該標識的作用是在回到HomeActivity時,把在堆棧中處於HomeActivity上面的活動全部清除。如果這是候運行程序的話,如果系統版本小於4.0的話,是可以正常跑起來的,達到想要的效果,但如果系統大於或者等於4.0的話,那麼點擊應用圖標是無效的。必須加上setHomeButtonEnabled=true,4.0一下 默認為true。如果還想要一個回退箭頭的話,再加上一句setDisplayHomeAsUpEnabled(true);效果如下:
這里我在擴展一下:使用過Navigation Drawer的同學應該了解,這里點擊應用程序圖標通常會作為拉出導航抽屜。通常在那種情況下是把活動的onOptionsItemSelected,傳送給ActionBarDrawerToggle的onOptionsItemSelected。不多說了,感興趣的同學自己去研究,後面會把Navigation Bar寫出來。
第三,導航選項標簽
當你想要在一個Activity中提供導航選擇標簽時,使用操作欄的選項標簽是一個非常好的選擇(而不是使用TabWidget類),因為系統會調整操作欄選項標簽來適應不同尺寸的屏幕的需要,在屏幕足夠寬的時候,導航選項標簽會被放到主操作欄中;當屏幕太窄的時候,選項標簽會被放到一個分離的橫條中。如圖下:
要使用選項標簽在Fragmengt之間切換,選擇一個選項標簽時執行一個Fragment事務,布局裡包含一個用於放置跟每個Fragment對象關聯的選項標簽的ViewGroup對象。該對象有一個資源ID,以便能夠在選項標簽的切換代碼中能夠引用它。Activity的布局文件activity_main.xml定義如下:
[html] view plain
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/container"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity"
tools:ignore="MergeRootFrame" />
這里的ViewGroup為FragmentLayout。Activity代碼如下:
[java] view plain
/*
* @ClassName: MainActivity
* @Description: 繼承自FragmentActivity,作為Fragment的holder-Activity使用,
* 實現TabListener介面,當切Tab的時候達到切換Fragment的效果
* @author yuxianglong
* @date 2013-7-11 下午7:40:35
*
*/
public class MainActivity extends FragmentActivity implements
ActionBar.TabListener {
private ActionBar actionBar;
}
@Override
public void onTabSelected(ActionBar.Tab tab,
FragmentTransaction fragmentTransaction) {
// When the given tab isselected, show the tabcontents in the
// //container view.
Fragment fragment3 = null;
Fragment fragment1 = null;
Fragment fragment2 = null;
switch (tab.getPosition()) {
case 0:
if (fragment1 == null) {
fragment1 = new Fragment1();
}
getSupportFragmentManager().beginTransaction()
.replace(R.id.container, fragment1).commit();
break;
case 1:
if (fragment2 == null) {
fragment2 = new Fragment2();
}
getSupportFragmentManager().beginTransaction()
.replace(R.id.container, fragment2).commit();
break;
case 2:
if (fragment3 == null) {
fragment3 = new Fragment3();
}
getSupportFragmentManager().beginTransaction()
.replace(R.id.container, fragment3).commit();
break;
default:
break;
}
}
@Override
public void onTabUnselected(ActionBar.Tab tab,
FragmentTransaction fragmentTransaction) {
}
@Override
public void onTabReselected(ActionBar.Tab tab,
FragmentTransaction fragmentTransaction) {
}
❼ 如何對actionbar.tab對象進行實例
一、實現Tab選項標簽
當你想要在一個Activity中提供Tab選項卡時,使用ActionBar的Tab選項標簽是一個非常好的選擇(而不是使用TabWidget類),因為系統會調整ActionBar的選項標簽來適應不同尺寸的屏幕的需要,比如在屏幕足夠寬的時候,Tab選項標簽會被放到主操作欄中;當屏幕太窄的時候,Tab選項標簽會被放到一個分離的橫條中
要想使用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
plain
<menu xmlns:android="http://schemas.android.com/apk/res/android" >
<item
android:id="@+id/action_clock"
android:orderInCategory="100"
android:showAsAction="always"
android:title="@string/action_settings"
android:actionLayout="@layout/clock"/>
</menu>
2、在寫一個時鍾的布局文件,clock.xml:
[html] view
plain
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<AnalogClock
android:id="@+id/analogClock1"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
</LinearLayout>
3、在定義一個布局文件用來存放Fragment的布局,列出其中一個,fragment_1.xml:
[html] view
plain
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
<ImageView
android:id="@+id/imageview"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:scaleType="fitCenter"
android:src="@drawable/xianjian01" >
</ImageView>
</LinearLayout>
4、定義一個類實現ActionBar.TabListener的介面,在這個實現中,每個Tab選項標簽都使用了它自己的監聽器,MyTabListener.java:
[java] view
plain
package com.yangyu.myactionbar02;
import android.app.ActionBar.Tab;
import android.app.ActionBar.TabListener;
import android.app.Activity;
import android.app.Fragment;
import android.app.FragmentTransaction;
public class MyTabListener<T extends Fragment> implements TabListener {
private Fragment fragment;
private final Activity mActivity;
private final Class<T> mClass;
public MyTabListener(Activity activity, Class<T> clz){
mActivity = activity;
mClass = clz;
}
@Override
public void onTabSelected(Tab tab, FragmentTransaction ft) {
if(fragment == null){
fragment = Fragment.instantiate(mActivity, mClass.getName());
ft.add(android.R.id.content, fragment, null);
}
ft.attach(fragment);
}
@Override