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