Menu菜单

Menu菜单

菜单类型显示菜单事件监听
系统菜单onCreateOptionsMenuonOptionItemSelectd
上下文菜单onCreateConextMenuonConextItemSelected
  • 系统菜单OptionsMenu (效果+具体实现)
    在这里插入图片描述
  1. 在res资源文件下创建一个menu文件夹,并创建一个xml文件作为OptionsMenu的布局文件,效果如下:
    在这里插入图片描述
  2. 在该文件下写入每个Item要显示的内容,代码如下:
<?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>
  1. 重写onCreateOptionsMenu加载资源文件和onOptionsItemSelectd设置事件监听两个方法,代码如下:
 @Override
 // 加载资源文件
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.layout,menu);
        return super.onCreateOptionsMenu(menu);
    }

    @Override
//  设置事件监听
    public boolean onOptionsItemSelected(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.onOptionsItemSelected(item);
    }

这样我们就完成的上面的效果图

  • 上下文菜单ContextMenu (效果+具体实现)
    在这里插入图片描述
  1. 在res资源文件下创建一个menu文件夹,并创建一个xml文件作为OptionsMenu的布局文件(与系统菜单一样)
  2. 重写onCreateConextMenu加载资源文件和onConextItemSelected设置事件监听两个方法,代码如下:
 @Override
//  加载资源文件
    public void onCreateContextMenu(ContextMenu menu, View v, ContextMenu.ContextMenuInfo menuInfo) {
        getMenuInflater().inflate(R.menu.layout,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);
    }
  1. 为控件添加长按属性并将菜单绑定到这个控件上:registerForContextMenu(控件)
public class Main2Activity extends AppCompatActivity {
    TextView textView;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main2);

        textView = findViewById(R.id.textview);
//      为控件添加长按属性并将菜单绑定到这个控件上
        registerForContextMenu(textView);
    }

这样我们就完成的上面的效果图

  • 弹出菜单 (效果+具体实现)
    在这里插入图片描述
  1. 在res资源文件下创建一个menu文件夹,并创建一个xml文件作为PopupMenu的布局文件(与系统菜单一样)
  2. 设置点击监听以及点击后的功能方法,代码如下:
public class Main3Activity extends AppCompatActivity {
    TextView textView;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main3);

        textView = findViewById(R.id.textview);
        textView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                showPopupMenu();
            }
        });
    }
  1. 功能代码的实现,代码如下:
public  void showPopupMenu(){
        PopupMenu popupMenu = new PopupMenu(Main3Activity.this,textView);
//      加载布局
        popupMenu.inflate(R.menu.layout);
//      事件监听
        popupMenu.setOnMenuItemClickListener(new PopupMenu.OnMenuItemClickListener() {
            @Override
            public boolean onMenuItemClick(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 false;
            }
        });
//      显示
        popupMenu.show();
    }

这样我们就完成的上面的效果图

以上就是我对菜单所掌握的知识与内容

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值