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);
}
}