如何创建浮动上下文菜单?

时间:2014-04-01 18:47:23

标签: java android

我想点击按钮时打开一个菜单。我试图创建一个浮动上下文菜单,但是当我按下按钮时没有任何反应。

MainActivity.java

public class MainActivity extends ListActivity {

    private Button button1;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        button1 = (Button)findViewById(R.id.button1);

        registerForContextMenu(button1);
    }

    public boolean onCreateOptionsMenu(Menu menu) {
        MenuInflater inflater = getMenuInflater();
        inflater.inflate(R.menu.main, menu);
        return true;
    }

    public boolean onOptionsItemSelected(MenuItem item)
    {
        switch (item.getItemId())
        {
            case R.id.item1:
                function();
                return true;
            default:
                return super.onOptionsItemSelected(item);
        }
    }
}

main.xml中

<menu xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    tools:context="com.prounitconverter.prounitconverter.MainActivity" >

    <item android:id="@+id/item1"
        android:title="@string/action_settings"
        android:orderInCategory="100"
        app:showAsAction="never" />
</menu>

另外,如何为两个不同的按钮创建两个菜单?

2 个答案:

答案 0 :(得分:1)

如果您正在寻找简单的下拉菜单 - 请使用PopupMenu

//anchorView - any view, where you want show menu
PopupMenu popupMenu = new PopupMenu(anchorView.getContext(), anchorView);
popupMenu.inflate(R.menu.my_menu_xml);
popupMenu.show();

答案 1 :(得分:0)

对于两个不同的菜单制作两个不同的xml文件,并将它们命名为不同,然后按名称对它们进行充气....要遵循的代码。

对于按钮,你没有onclick方法

在启动按钮

后,需要在onCreate中
this.button1.setOnClickListener(new OnClickListener() {
            @Override
            public void onClick(View v) {
            //open your menu here
            }
        });

this.button2.setOnClickListener(new OnClickListener(){             @覆盖             public void onClick(查看v){             //在这里打开你的菜单             }         });