ActionBar學習筆記
(1)XML文件和手動添加Menu Item
XML文件中添加,然後在activity的onCreateOptionsMenu方法中引用getMenuInflater().inflate(R.menu.main, menu);
<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="com.example.actionbar.MainActivity" >
<item
android:id="@+id/action_settings1"
android:orderInCategory="100"
android:title="item1"
android:icon="@drawable/btn_login_delete"
app:showAsAction="withText|always"/>
<item
android:id="@+id/action_settings2"
android:orderInCategory="100"
android:title="item2"
android:icon="@drawable/btn_login_delete"
app:showAsAction="never"/>
</menu>
手動添加,也是在activity的onCreateOptionsMenu方法中
MenuItem actionItem = menu.add("Action Button");
MenuItemCompat.setShowAsAction(actionItem, MenuItemCompat.SHOW_AS_ACTION_IF_ROOM | MenuItemCompat.SHOW_AS_ACTION_WITH_TEXT);
actionItem.setIcon(android.R.drawable.ic_menu_share);
(2)//android:orderInCategory="100" :放到overflow的優先級,值越大優先級越低
(3)XML文件中的app:showAsAction屬性always:這個值會使菜單項一直顯示在Action Bar上。
ifRoom:如果有足夠的空間,這個值會使菜單項顯示在Action Bar上。
never:這個值使菜單項永遠都不出現在Action Bar上。
withText:這個值使菜單項和它的圖標,菜單文本一起顯示。
其中withText沒有效果,不能文本和icon一起顯示
(4)使用一些屬性,實現效果,如返回
ActionBar.DISPLAY_USE_LOGO:顯示導航logo
ActionBar.DISPLAY_HOME_AS_UP顯示返回圖標
使用方法actionBar.setDisplayOptions(flags | ActionBar.DISPLAY_USE_LOGO | ActionBar.DISPLAY_HOME_AS_UP);
實現返回
// 按導航區域返回,導航區域包括
@Override
public boolean onSupportNavigateUp() {
Log.e(TAG, "onSupportNavigateUp");
finish();
return true;
// return super.onSupportNavigateUp();
}
(5)調用getActionBar方式在你的Activity的onCreate中時需要注意必須在調用了setContentView之後,在onOptionsItemSelected方法中實現點擊事件
(6)待解決的問題:
icon和文本一起顯示
自定義View(CustomerView),如文本顯示在中間
TabView顯示
樣式自定義
package com.example.actionbar;
import android.support.v4.view.MenuItemCompat;
import android.support.v7.app.ActionBar;
import android.support.v7.app.ActionBarActivity;
import android.annotation.SuppressLint;
import android.os.Build;
import android.os.Bundle;
import android.util.Log;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.ImageView;
public class MainActivity extends ActionBarActivity {
private static final String TAG = "ActionBar MainActivity";
//
// 1、always:這個值會使菜單項一直顯示在Action Bar上。
// 2、ifRoom:如果有足夠的空間,這個值會使菜單項顯示在Action Bar上。
// 3、never:這個值使菜單項永遠都不出現在Action Bar上。
// 4、withText:這個值使菜單項和它的圖標,菜單文本一起顯示。
//android:orderInCategory="100" :放到overflow的優先級,值越大優先級越低
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
// 調用getActionBar方式在你的Activity的onCreate中時需要注意必須在調用了setContentView之後
// 顯示返回圖標
ActionBar actionBar = getSupportActionBar();
actionBar.setDisplayHomeAsUpEnabled(true);
actionBar.setDisplayShowHomeEnabled(true);
actionBar.setLogo(R.drawable.btn_login_delete);
// actionBar.setIcon(R.drawable.btn_login_search);
int flags = actionBar.getDisplayOptions();
//ActionBar.DISPLAY_USE_LOGO:顯示導航logo
//ActionBar.DISPLAY_HOME_AS_UP顯示返回圖標
actionBar.setDisplayOptions(flags | ActionBar.DISPLAY_USE_LOGO | ActionBar.DISPLAY_HOME_AS_UP);
actionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_STANDARD);
}
// 按導航區域返回,導航區域包括
@Override
public boolean onSupportNavigateUp() {
Log.e(TAG, "onSupportNavigateUp");
finish();
return true;
// return super.onSupportNavigateUp();
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
//佈局文件添加 menu item
getMenuInflater().inflate(R.menu.main, menu);
//手動添加menu item
MenuItem actionItem = menu.add("Action Button");
MenuItemCompat.setShowAsAction(actionItem, MenuItemCompat.SHOW_AS_ACTION_IF_ROOM | MenuItemCompat.SHOW_AS_ACTION_WITH_TEXT);
actionItem.setIcon(android.R.drawable.ic_menu_share);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
// Handle action bar item clicks here. The action bar will
// automatically handle clicks on the Home/Up button, so long
// as you specify a parent activity in AndroidManifest.xml.
int id = item.getItemId();
// if (id == R.id.action_settings) {
// return true;
// }
return super.onOptionsItemSelected(item);
}
}