menu :android3.0以前常用的菜單
menu的三種實現方式:OptionsMenu,ContextMenu,PopupMenu
showAsAction屬性共有五個值:ifRoom、never、always、withText、collapseActionView,可以混合使用。
ifRoom 會顯示在Item中,但是如果已經有4個或者4個以上的Item時會隱藏在溢出列表中。當然個數並不僅僅侷限於4個,依據屏幕的寬窄而定
never 永遠不會顯示。只會在溢出列表中顯示,而且只顯示標題,所以在定義item的時候,最好把標題都帶上。
always 無論是否溢出,總會顯示。
withText withText值示意Action bar要顯示文本標題。Action bar會儘可能的顯示這個標題,但是,如果圖標有效並且受到Action bar空間的限制,文本標題有可能顯示不全。
collapseActionView 聲明瞭這個操作視窗應該被摺疊到一個按鈕中,當用戶選擇這個按鈕時,這個操作視窗展開。否則,這個操作視窗在默認的情況下是可見的,並且即便在用於不適用的時候,也要佔據操作欄的有效空間。
一般要配合ifRoom一起使用纔會有效果。
ifRoom 會顯示在Item中,但是如果已經有4個或者4個以上的Item時會隱藏在溢出列表中。當然個數並不僅僅侷限於4個,依據屏幕的寬窄而定
never 永遠不會顯示。只會在溢出列表中顯示,而且只顯示標題,所以在定義item的時候,最好把標題都帶上。
always 無論是否溢出,總會顯示。
withText withText值示意Action bar要顯示文本標題。Action bar會儘可能的顯示這個標題,但是,如果圖標有效並且受到Action bar空間的限制,文本標題有可能顯示不全。
collapseActionView 聲明瞭這個操作視窗應該被摺疊到一個按鈕中,當用戶選擇這個按鈕時,這個操作視窗展開。否則,這個操作視窗在默認的情況下是可見的,並且即便在用於不適用的時候,也要佔據操作欄的有效空間。
一般要配合ifRoom一起使用纔會有效果。
在res資源文件夾下創建menu文件夾接着創建xml文件
<?xml version="1.0" encoding="utf-8"?> <menu xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto"> <item android:id="@+id/item1" android:orderInCategory="100" android:title="選項1" app:showAsAction="never" /> <item android:id="@+id/item2" android:orderInCategory="100" android:title="選項2" app:showAsAction="never" /> <item android:id="@+id/item3" android:orderInCategory="100" android:title="選項3" app:showAsAction="never" /> </menu>
package cgg.com.sss; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.view.ContextMenu; import android.view.Menu; import android.view.MenuItem; import android.view.View; import android.widget.Toast; public class MainActivity extends AppCompatActivity { /** * Menu 菜單:三種實現方式之一: * 重寫onCreateOptionsMenu方法 * * onOptionsItemSelected方法做事件處理 */ @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); } @Override public boolean onCreateOptionsMenu(Menu menu) { // 利用菜單填充器將xml轉成menu對象 getMenuInflater().inflate(R.menu.menu_item,menu); // 也可以動態添加item // menu.add(groundId,itemId,orderInCategory,title); menu.add(Menu.NONE,0x0011,101,"動態添加"); return true;// true表示讓菜單顯示出來 } /** * 菜單選項的點擊事件處理的方法 */ @Override public boolean onOptionsItemSelected(MenuItem item) { switch (item.getItemId()){ case R.id.item1: Toast.makeText(this, "item1", Toast.LENGTH_SHORT).show(); break; case R.id.item2: Toast.makeText(this, "item2", Toast.LENGTH_SHORT).show(); break; case R.id.item3: Toast.makeText(this, "item3", Toast.LENGTH_SHORT).show(); break; case 0x0011: Toast.makeText(this, "動態添加", Toast.LENGTH_SHORT).show(); break; } return super.onOptionsItemSelected(item); } }
運行效果
第二種方式
package cgg.com.sss; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.view.ContextMenu; import android.view.Menu; import android.view.MenuItem; import android.view.View; import android.widget.Button; import android.widget.Toast; public class MainActivity extends AppCompatActivity { /** * Menu 菜單:三種實現方式之一: * 重寫onCreateContextMenu方法 * * onContextItemSelected方法做事件處理 */ @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); Button but = findViewById(R.id.test); // 註冊上下文菜單綁定到某控件上(長按時觸發) registerForContextMenu(but); } @Override public void onCreateContextMenu(ContextMenu menu, View v, ContextMenu.ContextMenuInfo menuInfo) { super.onCreateContextMenu(menu, v, menuInfo); // 利用菜單填充器將xml轉成menu對象 getMenuInflater().inflate(R.menu.menu_item,menu); // 也可以動態添加item // menu.add(groundId,itemId,orderInCategory,title); menu.add(Menu.NONE,0x0011,101,"動態添加"); } /** * 菜單選項的點擊事件處理的方法 */ @Override public boolean onContextItemSelected(MenuItem item) { switch (item.getItemId()){ case R.id.item1: Toast.makeText(this, "item1", Toast.LENGTH_SHORT).show(); break; case R.id.item2: Toast.makeText(this, "item2", Toast.LENGTH_SHORT).show(); break; case R.id.item3: Toast.makeText(this, "item3", Toast.LENGTH_SHORT).show(); break; case 0x0011: Toast.makeText(this, "動態添加", Toast.LENGTH_SHORT).show(); break; } return super.onContextItemSelected(item); } }效果示例
最後一種 PopupMenu
package cgg.com.sss; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.view.ContextMenu; import android.view.Menu; import android.view.MenuItem; import android.view.View; import android.widget.Button; import android.widget.PopupMenu; import android.widget.Toast; public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); } // button的點擊事件 public void showPopupMenu(View view) { PopupMenu popupMenu = new PopupMenu(this, view); getMenuInflater().inflate(R.menu.menu_item, popupMenu.getMenu()); popupMenu.show(); // PopupMenu的items事件處理 popupMenu.setOnMenuItemClickListener(new PopupMenu.OnMenuItemClickListener() { @Override public boolean onMenuItemClick(MenuItem item) { switch (item.getItemId()) { case R.id.item1: Toast.makeText(MainActivity.this, "item1", Toast.LENGTH_SHORT).show(); break; case R.id.item2: Toast.makeText(MainActivity.this, "item2", Toast.LENGTH_SHORT).show(); break; case R.id.item3: Toast.makeText(MainActivity.this, "item3", Toast.LENGTH_SHORT).show(); break; } return false; } }); } }
運行效果