常用的菜单

一、系统菜单OptionsMenu

在这里插入图片描述

实现步骤:

首先在res创建menu文件夹存放菜单布局文件
在这里插入图片描述
在布局里边写每个菜单的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/delt" android:title="删除" app:showAsAction="never"></item>
    <item android:id="@+id/top" android:title="置顶"></item>
</menu>

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

public class MainActivity extends AppCompatActivity {
TextView textView;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        textView = findViewById(R.id.text);
    }
    //Activity重写onCreateOptionsMenu加载资源文件
    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.option_menu,menu);
        return super.onCreateOptionsMenu(menu);
    }
    //Activity重写onOptionsItemSelected加设置事件监听
    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        int id = item.getItemId();
        switch (id){
            case R.id.blue:
                textView.setTextColor(Color.BLUE);
                break;
            case R.id.red:
                textView.setTextColor(Color.RED);
                break;
            case R.id.green:
                textView.setTextColor(Color.GREEN);
                break;
        }
        return super.onOptionsItemSelected(item);
    }
}

二、上下文菜单ContextMenu

在这里插入图片描述

实现步骤:

1.首先在res创建menu文件夹存放菜单布局文件,我们继续使用上边的menu布局
2.Activity重写onCreateConextMenu加载资源文件
3.Activity重写onConextItemSelected设置事件监听
4.为控件添加长按属性并将菜单绑定到这个控件上:registerForContextMenu(控件)

protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    textView = findViewById(R.id.text);
    registerForContextMenu(textView);
}
@Override
public void onCreateContextMenu(ContextMenu menu, View v, ContextMenu.ContextMenuInfo menuInfo) {
    getMenuInflater().inflate(R.menu.option_menu,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.BLUE);
            break;
        case R.id.red:
            textView.setTextColor(Color.RED);
            break;
        case R.id.green:
            textView.setTextColor(Color.GREEN);
            break;
    }
    return super.onContextItemSelected(item);
}

二、弹出菜单

在这里插入图片描述

实现步骤:

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

protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    textView = findViewById(R.id.pupo_tv);
    textView.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            showPopupMenu();
        }
    });
}
private void showPopupMenu() {
    //1:创建对象
    PopupMenu popupMenu = new PopupMenu(this, textView);
    //2:记载布局
    popupMenu.inflate(R.menu.popu_menu);
    //3:事件监听
   popupMenu.setOnMenuItemClickListener(new PopupMenu.OnMenuItemClickListener() {
       @Override
       public boolean onMenuItemClick(MenuItem item) {
           int id = item.getItemId();
           switch (id){
               case R.id.blue:
                   textView.setTextColor(Color.BLUE);
                   break;
               case R.id.red:
                   textView.setTextColor(Color.RED);
                   break;
               case R.id.green:
                   textView.setTextColor(Color.GREEN);
                   break;
           }
           return false;
       }
   });
   //显示菜单
   popupMenu.show();
}

弹出菜单默认在view的下方

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

MX_XXS

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值