按照 Android Studio 内置的例子作了个 actionbar 的 Demo,如今写下来作笔记,IDE 为 Android Studio 1.2。java
完成的截图以下:android
xml<?xml version="1.0" encoding="UTF-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="co.youngdze.startup" android:versionCode="1" android:versionName="1.0"> <application android:icon="@drawable/ic_launcher" android:label="@string/app_name" android:theme="@style/Theme.AppCompat" android:allowBackup="true"> <activity android:name=".MainActivity"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> </application> </manifest>
从截图可看出有一段很长的说明文字,且文字位于中间,长文字能够在用 CDATA
保存,因此写好须要的字符串。app
res/values/base-strings.xml:ide
xml<?xml version="1.0" encoding="UTF-8"?> <resources> <string name="app_name">ActionBar</string> <string name="intro_message"> <![CDATA[ This sample shows you how to use ActionBarCompat to create a basic Activity which displays action items. It covers inflating items from a menu resource, as well as adding an item in code. Items that are not shown as action items on the Action Bar are displayed in the action bar overflow. ]]> </string> </resources>
res/values/strings.xmlthis
xml<?xml version="1.0" encoding="utf-8"?> <resources> <string name="menu_refresh">Refresh</string> <string name="menu_location">Location</string> <string name="menu_settings">Settings</string> </resources>
由于只有一段说明文字,因此一个 <TextView>
足矣,经过 android:text
引用上面定义好的字符串。spa
文字位于屏幕中间,能够经过 android:gravity="center"
属性处理,而且设置 android:layout_width="match_parent"
和 android:layout_height="match_parent"
。code
为了看起来更舒服,因此加了个 android:padding="16dp"
属性。xml
res/layout/sample_main.xmlblog
xml<?xml version="1.0" encoding="utf-8"?> <TextView xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:padding="16dp" android:text="@string/intro_message" android:gravity="center" />
事实上 Location 项是打算经过 Activity 的 onCreateOptionsMenu()
来建立,因此如今只写两个 <item>
。utf-8
基本的属性都定义好,包括 android:id
、android:icon
、android:title
。
showAsAction
须要使用不一样的命名空间,这里用 support
表示,ifRoom
表示有空间就显示,never
表示永远不显示,也就是点击那个菜单汉堡包才显示。
res/menu/main.xml
xml<?xml version="1.0" encoding="utf-8" ?> <menu xmlns:android="http://schemas.android.com/apk/res/android" xmlns:support="http://schemas.android.com/apk/res-auto"> <item android:id="@+id/menu_refresh" android:icon="@drawable/ic_action_refresh" android:title="@string/menu_refresh" support:showAsAction="ifRoom" /> <item android:id="@+id/menu_settings" android:icon="@drawable/ic_action_settings" android:title="@string/menu_settings" support:showAsAction="never" /> </menu>
建立 Menu Item 会用到 MenuItem
类 和 Menu
类,先导入:
javaimport android.view.MenuItem; import android.view.Menu;
用到在 Menu
的方法是:
javapublic abstract MenuItem add (int groupId, int itemId, int order, CharSequence title);
groupId
表明组概念,若是想对 Item 进行分组管理这个会用得上,若是该 Item 不在组内则使用 None
。
itemId
表明 Item 的 ID,必须是独一无二的,若是不须要 itemID
则使用 None
。
orderId
表明 Item 所在的顺序,注意是在动态建立 Item 中的顺序,若是不须要,使用 None
。
title
表示 Item 的 android:title
属性。
不过得事先写一个独一无二的 ID 供 Item 建立调用:
res/values/ids.xml
xml<?xml version="1.0" encoding="utf-8"?> <resources> <!-- Generate an id which can be used when the location menu item is added in MainActivity --> <item name="menu_location" type="id"/> </resources>
动态建立代码以下:
java@Override public boolean onCreateOptionsMenu(Menu menu) { ... MenuItem locationItem = menu.add(0, R.id.menu_location, 0, R.string.menu_location); location.setIcon(R.drawable.ic_action_location); MenuItemCompat.setShowAsAction(locationItem, MenuItemCompat, SHOW_AS_ACTION_IF_ROOM); ... }
其实转为 XML 也就是:
xml<item android:id="@+id/menu_location" android:icon="@drawable/ic_action_location" android:title="@string/menu_location" support:showAsAction="ifRoom" />
这里重写的方法是 onOptionItemSeleted(MenuItem item)
,经过 item.getItemid()
识别所选的 Item。
能够用 Toast
类 makeText()
方法弹出提示如今点击的是哪一个 Item,使用方法是:
javaToast.makeText(context, text, duration).show();
如下是代码实现:
java
@Override public boolean onOptionsItemSelected(MenuItem item) { switch (item.getItemId()) { case R.id.menu_refresh: Toast.makeText(this, "Refresh!", Toast.LENGTH_SHORT).show(); return true; case R.id.menu_location: Toast.makeText(this, "Location!", Toast.LENGTH_SHORT).show(); return true; case R.id.menu_settings: Toast.makeText(this, "Setting!", Toast.LENGTH_SHORT).show(); return true; } return super.onOptionsItemSelected(item); }
所有 Activity 代码以下:
java/co/youngdze/startup/MainActivity.java
javapackage co.youngdze.startup; import android.support.v4.view.MenuItemCompat; import android.support.v7.app.ActionBarActivity; import android.os.Bundle; import android.view.Menu; import android.view.MenuItem; import android.widget.Toast; public class MainActivity extends ActionBarActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); MenuItem locationItem = menu.add(0, R.id.menu_location, 0, R.string.menu_location); locationItem.setIcon(R.drawable.ic_action_location); MenuItemCompat.setShowAsAction(locationItem, MenuItemCompat.SHOW_AS_ACTION_IF_ROOM); return true; } @Override public boolean onOptionsItemSelected(MenuItem item) { switch (item.getItemId()) { case R.id.menu_refresh: Toast.makeText(this, "Refresh!", Toast.LENGTH_SHORT).show(); return true; case R.id.menu_location: Toast.makeText(this, "Location!", Toast.LENGTH_SHORT).show(); return true; case R.id.menu_settings: Toast.makeText(this, "Setting!", Toast.LENGTH_SHORT).show(); return true; } return super.onOptionsItemSelected(item); } }