Android ActionBar的基础使用
这个示例演示了ActionBar的基础使用,包括如何在menu.xml中定义menu items并将其填充到ActionBar的options menu中,以及如何在代码中将menu item添加到给定的options menu中。
介绍##
Android3.0引入了ActionBar,ActionBar可以标识用户所在应用的位置,提供用户在应用的各个Activity间进行切换、导航。示例在运行在Android4.0以上,不支持4.0以下版本。
屏幕截图
代码实现
layout/activity_main.xml
values/dimens.xml
4dp
8dp
16dp
32dp
64dp
16dp
16dp
values/ids.xml
values/strings.xml
BasicActionBar
Hello world!
设置
刷新
位置
menu/main.xml
MainActivity.java
package com.ddzj.basicactionbar;
import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
/*
* 初始化Activity的标准选择菜单中的内容,在这个方法中将menu items添加到menu中。 这个方法只在选择菜单(options
* menu)第一次被显示出来的时候调用一次。要在该菜单每次显示的时候更新它,请参见onPrepareOptionsMenu方法。
*
* 参数:
* menu:将menu items放入其中的options menu.
*
* 返回: 要让菜单显示,你必须返回true,否则不显示
*/
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// 将在menu.xml中定义好的menu items填充到menu中。inflate--填充
getMenuInflater().inflate(R.menu.main, menu);
/*
* 使用代码手动添加定位item
*
* add(int groupId, int itemId, int order, CharSequence title)
* 这个方法将一个menu item添加到给定menu中。
*
* 参数:
* groupId:该item所属的group的group标识符。如果没有所属,则写Menu.NONE
* itemId: 该item的Id.如果不需要一个唯一的ID,则写Menu.NONE,因为我们要处理该item的点击事件,
* 因此需要一个唯一的id来标示,我们在values/ids.xml中为该item定义一个id.
* order: 如果不关心顺序,则写Menu.NONE. 参见MenuItem.getOrder()
* title: 该item显示的文字
*/
MenuItem locationItem = menu.add(Menu.NONE, R.id.menu_location, Menu.NONE, R.string.menu_location);
locationItem.setShowAsAction(MenuItem.SHOW_AS_ACTION_IF_ROOM);
locationItem.setIcon(R.drawable.ic_action_location);
return true;
}
/*
* 当你的options menu中的menu item被点击时,调用此函数。hook:回调函数、钩子
* 参数:
* item:被点击的menu item
*/
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case R.id.action_refresh:
// 处理刷新的代码
return true;
case R.id.menu_location:
// 处理定位的代码
return true;
case R.id.action_settings:
// 处理设置的代码
return true;
}
// 总是调用该方法来做默认的处理
return super.onOptionsItemSelected(item);
}
}