Menu菜单

常用的菜单

菜单显示菜单事件监听
系统菜单onCreateOptionsMenuonOptionsltemSelected
上下文菜单AlertDialog.Builder()setSingleChoiceltems()

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">
    <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加设置事件监听

//Activity重写onCreateOptionMenu加载资源文件
@Override
public boolean onCreateOptionsMenu(Menu menu) {
    getMenuInflater().inflate(R.menu.opmenu,menu);
    return super.onCreateOptionsMenu(menu);
}
//Activity重写onOptionsItemSelected设置时间监听

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

    }
    return super.onOptionsItemSelected(item);
}

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

2.上下文菜单ContextMenu

在这里插入图片描述

步骤流程

1.在res下面创建一个menu文件夹,并新建一个xml文件作为ContexMenu的布局文件

<?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/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重写onCreateConexMenu加载资源文件
3.Activity重写onConextltemSelected设置事件监听
4.为控件添加长按属性并将菜单绑定到这个控件上:registerForContextMenu(控件)

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

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

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

3.弹出菜单

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

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    Tv = findViewById(R.id.Tv1);
    Tv2 = findViewById(R.id.Tv2);
    //TODO 为控件添加长按属性并将菜单绑定到这个控件上
    registerForContextMenu(Tv2);
    Tv3 = findViewById(R.id.Tv3);
    Tv3.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            showPopupMenu();
        }
    });
}
//TODO 弹出菜单
public void showPopupMenu(){
    //TODO 1:创建对象
    //参数一  上下文 参数二  菜单显示在指定控件的下方
    PopupMenu popupMenu = new PopupMenu(this, Tv3);
    //TODO 2.记载布局
    popupMenu.inflate(R.menu.opmenu);
    //TODO 3.事件监听
    popupMenu.setOnMenuItemClickListener(new PopupMenu.OnMenuItemClickListener() {
        @Override
        public boolean onMenuItemClick(MenuItem item) {
            int id = item.getItemId();
            switch (id){
                case R.id.blue:
                    Tv3.setTextColor(Color.parseColor("#2239A2"));
                    break;
                case R.id.green:
                    Tv3.setTextColor(Color.parseColor("#1BA233"));
                    break;
                case R.id.red:
                    Tv3.setTextColor(Color.parseColor("#A21C31"));
                    break;

            }
            return false;
        }
    });
    //TODO 4.显示
    popupMenu.show();
}

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值