menu菜单

第2天Menu菜单
#常用的菜单
#1.系统菜单OptionsMenu
#步骤流程:
#2.上下文菜单ContextMenu
#3.弹出菜单
常用的菜单
在这里插入图片描述
菜单 显示菜单 事件监听
系统菜单 onCreateOptionsMenu onOptionsItemSelected
上下文菜单 AlertDialog.Builder() setSingleChoiceItems()
1.系统菜单OptionsMenu
在这里插入图片描述
步骤流程:
1.在res下面创建一个menu文件夹,并新建一个xml文件作为OptionMenu的布局文件

<?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">
    <!--showAsAction属性:always总是  never 从不 ifroom 能显示就显示 默认是nerver-->
    <item android:id="@+id/blue" android:title="蓝色" app:showAsAction="never" ></item>
    <item android:id="@+id/red" android:title="红色" > </item>
    <item android:id="@+id/green" android:title="绿色" ></item>
</menu>

2.Activity重写onCreateOptionsMenu加载资源文件
3.Activity重写onOptionsItemSelected加设置事件监听

//步骤2:Activity重写onCreateOptionsMenu加载资源文件
//步骤3:Activity重写onOptionsItemSelected设置事件监听

 @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.optionmenu,menu);
        return super.onCreateOptionsMenu(menu);
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        int itemId = item.getItemId();
        switch (itemId){
            case R.id.blue:
                relative_layout.setBackgroundColor(Color.parseColor("#2239A2"));
                break;
            case R.id.green:
                relative_layout.setBackgroundColor(Color.parseColor("#1BA233"));
                break;
            case R.id.red:
                relative_layout.setBackgroundColor(Color.parseColor("#A21C31"));
                break;
        }
        return super.onOptionsItemSelected(item);
    }

注意:一个Activity只有一个系统菜单

2.上下文菜单ContextMenu
在这里插入图片描述
步骤流程:

1.在res下面创建一个menu文件夹,并新建一个xml文件作为ContextMenu的布局文件,我们复用上面的menu布局
2.Activity重写onCreateConextMenu加载资源文件
3.Activity重写onConextItemSelected设置事件监听
4.为控件添加长按属性并将菜单绑定到这个控件上:registerForContextMenu(控件)

 @Override
    public void onCreateContextMenu(ContextMenu menu, View v, ContextMenu.ContextMenuInfo menuInfo) {
        getMenuInflater().inflate(R.menu.optionmenu, menu);
        super.onCreateContextMenu(menu, v, menuInfo);
    }

    @Override
    public boolean onContextItemSelected(MenuItem item) {
        int id = item.getItemId();
        switch (id) {
            case R.id.blue:
                textview.setTextColor(Color.parseColor("#2239A2"));
                break;
            case R.id.green:
                textview.setTextColor(Color.parseColor("#1BA233"));
                break;
            case R.id.red:
                textview.setTextColor(Color.parseColor("#A21C31"));
                break;
        }
        return super.onContextItemSelected(item);
    }

注意:长按绑定的控件+可以为任意一个view设置上下文菜单

3.弹出菜单

在这里插入图片描述
1.实现流程:

步骤1:在res下面创建一个menu文件夹,并新建一个xml文件作为PoupMenu的布局文件。
步骤2:把PopupMenu相关逻辑封装到showPopupMenu()方法中,包含PopupMenu的实例化、布局设置、显示、添加MenuItem的点击监听及响应等
步骤3:为控件设置事件监听直接调用showPopupMenu()方法

2.代码
(1)xml布局文件:activity_main2.xml

(2)Java代码:Main2Activity.java

public class MainActivity extends AppCompatActivity {
    TextView textview;
    RelativeLayout relative_layout;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        relative_layout = findViewById(R.id.relative_layout);
        textview = findViewById(R.id.textview);
        //绑定上下文菜单
        registerForContextMenu(textview);

        textview.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                showPopupMenu();
            }
        });
    }
    public void showPopupMenu(){
        //TODO  1:创建对象
        //参数一 上下文  参数二  菜单显示在指定控件的下方
        PopupMenu popupMenu= new PopupMenu(this,textview);
        //TODO 2:记载布局
        popupMenu.inflate(R.menu.optionmenu);
        //TODO 3:事件监听
        popupMenu.setOnMenuItemClickListener(new PopupMenu.OnMenuItemClickListener() {
            @Override
            public boolean onMenuItemClick(MenuItem item) {
                int id=item.getItemId();
                switch (id){
                    case R.id.blue:
                        textview.setText("蓝色");
                        break;
                    case R.id.green:
                        textview.setText("绿色");
                        break;
                    case R.id.red:
                        textview.setText("红色");
                        break;
                }
                return false;
            }
        });
        //TODO 4:显示
        popupMenu.show();
    }

注意:弹出菜单,默认弹出的位置在控件view的下方

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值