ActionBar的基础使用(Google Sample API22)

Android ActionBar的基础使用

这个示例演示了ActionBar的基础使用,包括如何在menu.xml中定义menu items并将其填充到ActionBar的options menu中,以及如何在代码中将menu item添加到给定的options menu中。

介绍##

Android3.0引入了ActionBar,ActionBar可以标识用户所在应用的位置,提供用户在应用的各个Activity间进行切换、导航。示例在运行在Android4.0以上,不支持4.0以下版本。

屏幕截图

ActionBar的基础使用(Google Sample API22)_第1张图片
basic_actionBar

ActionBar的基础使用(Google Sample API22)_第2张图片
basic_actionBar2

代码实现

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

图片资源##

ic_action_location.png

ic_action_refresh.png

ic_action_settings.png

ic_launcher.png

你可能感兴趣的:(ActionBar的基础使用(Google Sample API22))