伴隨android的遠古menu

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一起使用纔會有效果。


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


}

運行效果

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章