安卓学习 Day28:菜单

一、案例演示 - 选项菜单

1、创建安卓应用

在这里插入图片描述

2、添加背景图片

在这里插入图片描述

3、字符串资源文件

<resources>
    <string name="app_name">选项菜单演示</string>
</resources>

4、主布局资源文件

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@drawable/background"
    android:gravity="center"
    tools:context=".MainActivity">

</LinearLayout>

5、主界面类

package net.zs.optons_menu_demo;

import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.Toast;
import android.widget.Toolbar;

public class MainActivity extends AppCompatActivity {

    private static final int NEW_MENU = 1;
    private static final int OPEN_MENU = 2;
    private static final int SAVE_MENU = 3;
    private static final int EXIT_MENU = 4;

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

    /**
     * 创建菜单选项
     */
    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // 添加四个菜单项(组标识、菜单项标识、菜单项序号、菜单项标题)
        menu.add(0, NEW_MENU, 1, "新建文件");
        menu.add(0, OPEN_MENU, 2, "打开文件");
        menu.add(0, SAVE_MENU, 3, "保存文件");
        menu.add(0, EXIT_MENU, 4, "退出程序");

        return true;
    }

    /**
     * 菜单项选择事件处理方法
     */
    @Override
    public boolean onOptionsItemSelected(@NonNull MenuItem item) {
        // 判断用户单击了哪个菜单项
        switch (item.getItemId()) {
            case NEW_MENU:
                Toast.makeText(this, "你单击了【新建文件】菜单项!", Toast.LENGTH_SHORT).show();
                break;
            case OPEN_MENU:
                Toast.makeText(this, "你单击了【打开文件】菜单项!", Toast.LENGTH_SHORT).show();
                break;
            case SAVE_MENU:
                Toast.makeText(this, "你单击了【保存文件】菜单项!", Toast.LENGTH_SHORT).show();
                break;
            case EXIT_MENU:
                finish(); // 关闭当前活动窗口
                break;
        }
        return true;
    }
}

6、运行程序,查看效果

在这里插入图片描述

二、案例演示 - 上下文菜单

1、创建安卓应用

在这里插入图片描述

2、添加图片资源

(1)下载图片资源

  • save_file.png
    ad韩国
  • copy.png
    请添加图片描述
  • cut.png
    在这里插入图片描述
  • edit.png
    在这里插入图片描述
  • exit.png
    在这里插入图片描述
  • file.png
    在这里插入图片描述
  • new_file.png
    在这里插入图片描述
  • open_file.png
    在这里插入图片描述
  • paste.png
    在这里插入图片描述
  • background.jpg
    在这里插入图片描述

(2)拷贝到src/main/res/mipmap-xxxhdpi目录下

在这里插入图片描述

3、字符串资源文件

<resources>
    <string name="app_name">上下文菜单演示</string>
    <string name="file">文件</string>
    <string name="edit">编辑</string>
</resources>

4、主布局资源文件

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@drawable/background"
    android:padding="15dp"
    tools:context=".MainActivity">

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        android:padding="10dp"        
        android:background="#eeeeee">
        
        <TextView
            android:id="@+id/tvFile"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginRight="15dp"
            android:text="@string/file"
            android:textColor="#0000ff"
            android:textSize="20sp" />

        <TextView
            android:id="@+id/tvEdit"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="@string/edit"
            android:textColor="#0000ff"
            android:textSize="20sp" />
    </LinearLayout>
</LinearLayout>

5、主界面类

package net.zs.context_menu_demo;

import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.view.ContextMenu;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.TextView;
import android.widget.Toast;

import java.lang.reflect.Method;

public class MainActivity extends AppCompatActivity {

    private TextView tvFile;
    private TextView tvEdit;

    private static final int NEW_MENU_ITEM = 1;
    private static final int OPEN_MENU_ITEM = 2;
    private static final int SAVE_MENU_ITEM = 3;
    private static final int EXIT_MENU_ITEM = 4;

    private static final int CUT_MENU_ITEM = 5;
    private static final int COPY_MENU_ITEM = 6;
    private static final int PASTE_MENU_ITEM = 7;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        // 利用布局资源文件设置用户界面
        setContentView(R.layout.activity_main);

        // 通过资源标识符获取控件实例
        tvFile = findViewById(R.id.tvFile);
        tvEdit = findViewById(R.id.tvEdit);

        // 给控件注册上下文菜单
        registerForContextMenu(tvFile);
        registerForContextMenu(tvEdit);
    }

    /**
     * 设置图标可用的方法
     */
    private void setIconEnabled(Menu menu, boolean enabled) {
        try {
            Class<?> Clazz = Class.forName("com.android.internal.view.menu.MenuBuilder");
            Method m = Clazz.getDeclaredMethod("setOptionalIconsVisible", boolean.class);
            m.setAccessible(true);
            // MenuBuilder实现Menu接口,创建菜单时,传进来的menu其实就是MenuBuilder对象(Java的多态特征)
            m.invoke(menu, enabled);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    /**
     * 创建上下文菜单
     */
    @Override
    public void onCreateContextMenu(ContextMenu menu, View v, ContextMenu.ContextMenuInfo menuInfo) {
        super.onCreateContextMenu(menu, v, menuInfo);
        // 设置菜单图标可用
        setIconEnabled(menu, true);
        // 针对不同控件创建不同的上下文菜单
        switch (v.getId()) {
            case R.id.tvFile:
                // 创建文件菜单
                menu.setHeaderIcon(R.mipmap.file);
                menu.setHeaderTitle("文件");
                // 添加菜单项(组标识、菜单项标识、菜单项序号、菜单项文本)

                menu.add(1, NEW_MENU_ITEM, 1, "新建").setIcon(R.mipmap.new_file);
                menu.add(1, OPEN_MENU_ITEM, 2, "打开").setIcon(R.mipmap.open_file);
                menu.add(1, SAVE_MENU_ITEM, 3, "保存").setIcon(R.mipmap.save_file);
                menu.add(1, EXIT_MENU_ITEM, 4, "退出").setIcon(R.mipmap.exit);
                break;
            case R.id.tvEdit:
                // 创建编辑菜案
                menu.setHeaderIcon(R.mipmap.edit);
                menu.setHeaderTitle("编辑");
                // 添加菜单项(组标识、菜单项标识、菜单项序号、菜单项文本)
                menu.add(2, CUT_MENU_ITEM, 1, "剪切").setIcon(R.mipmap.cut);
                menu.add(2, COPY_MENU_ITEM, 2, "复制").setIcon(R.mipmap.copy);
                menu.add(2, PASTE_MENU_ITEM, 3, "粘贴").setIcon(R.mipmap.paste);
                break;
        }
    }

    /**
     * 上下文菜单项选择事件处理方法
     */
    @Override
    public boolean onContextItemSelected(@NonNull MenuItem item) {
        // 判断用户选择了哪个菜单项
        switch (item.getItemId()) {
            case NEW_MENU_ITEM:
                Toast.makeText(this, "你单击了【新建】菜单项!", Toast.LENGTH_SHORT).show();
                break;
            case OPEN_MENU_ITEM:
                Toast.makeText(this, "你单击了【打开】菜单项!", Toast.LENGTH_SHORT).show();
                break;
            case SAVE_MENU_ITEM:
                Toast.makeText(this, "你单击了【保存】菜单项!", Toast.LENGTH_SHORT).show();
                break;
            case EXIT_MENU_ITEM:
                finish();
                break;
            case CUT_MENU_ITEM:
                Toast.makeText(this, "你单击了【剪切】菜单项!", Toast.LENGTH_SHORT).show();
                break;
            case COPY_MENU_ITEM:
                Toast.makeText(this, "你单击了【复制】菜单项!", Toast.LENGTH_SHORT).show();
                break;
            case PASTE_MENU_ITEM:
                Toast.makeText(this, "你单击了【粘贴】菜单项!", Toast.LENGTH_SHORT).show();
                break;
        }
        return true;
    }
}

6、运行程序,查看效果

在这里插入图片描述

三、案例演示 - 子菜单

1、创建安卓应用

在这里插入图片描述

2、添加背景图片

在这里插入图片描述

3、主布局资源文件

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/root"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@drawable/background"
    android:gravity="center"
    android:orientation="vertical"
    tools:context=".MainActivity">

</LinearLayout>

4、主界面类

package net.zs.submenu_demo;

import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;

import android.graphics.Color;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.SubMenu;
import android.widget.LinearLayout;

public class MainActivity extends AppCompatActivity {

    private LinearLayout root;
    private static final int SET_COLOR_MENU = 0;
    private static final int RED_MENU_ITEM = 1;
    private static final int GREEN_MENU_ITEM = 2;
    private static final int BLUE_MENU_ITEM = 3;
    private static final int RESET_MENU_ITEM = 4;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        // 利用布局资源文件设置用户界面
        setContentView(R.layout.activity_main);

        // 通过资源标识符获取控件实例
        root = findViewById(R.id.root);

    }

    /**
     * 创建选项菜单及其子菜单
     */
    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // 创建设置颜色子菜单
        SubMenu setColorSubMenu = menu.addSubMenu(0, SET_COLOR_MENU, 1, "设置颜色");
        // 给子菜单添加菜单选项
        setColorSubMenu.add(0, RED_MENU_ITEM, 1, "红色");
        setColorSubMenu.add(0, GREEN_MENU_ITEM, 2, "绿色");
        setColorSubMenu.add(0, BLUE_MENU_ITEM, 3, "蓝色");
        setColorSubMenu.add(0, RESET_MENU_ITEM, 4, "重置");
        // 事件传播到此结束
        return true;
    }

    /**
     * 菜单项事件处理方法
     */
    @Override
    public boolean onOptionsItemSelected(@NonNull MenuItem item) {
        // 根据不同菜单项执行不同操作
        switch (item.getItemId()) {
            case RED_MENU_ITEM:
                // 将窗口背景设置为红色
                root.setBackgroundColor(Color.RED);
                break;
            case GREEN_MENU_ITEM:
                // 将窗口背景设置为绿色
                root.setBackgroundColor(Color.GREEN);
                break;
            case BLUE_MENU_ITEM:
                // 将窗口背景设置为蓝色
                root.setBackgroundColor(Color.BLUE);
                break;
            case RESET_MENU_ITEM:
                // 将窗口背景重置为原始图片
                root.setBackgroundResource(R.drawable.background);
                break;
        }
        // 事件传播到此结束
        return true;
    }
}

5、运行程序,查看效果

在这里插入图片描述

四、案例演示 - 利用菜单配置文件生成菜单

1、创建安卓应用

在这里插入图片描述

2、添加图片资源

  • 案例二中已经发布了需要用的图片资源,请自行下载。
    在这里插入图片描述

3、主布局资源文件

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@drawable/background"
    tools:context=".MainActivity">
    
</LinearLayout>

4、字符串资源文件

<resources>
    <string name="app_name">利用XML配置生成菜单</string>
    <string name="file_menu">文件</string>
    <string name="new_file">新建文件</string>
    <string name="open_file">打开文件</string>
    <string name="save_file">保存文件</string>
    <string name="exit">退出程序</string>
    <string name="edit_menu">编辑</string>
    <string name="cut">剪切</string>
    <string name="copy">复制</string>
    <string name="paste">粘贴</string>
</resources>

5、自定义菜单配置文件

  • 在res目录里创建menu目录,然后在里面创建菜单配置文件main.xml
    在这里插入图片描述
  • 源代码
<?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"
    xmlns:tools="http://schemas.android.com/tools"
    tools:context="net.zs.xml_menu.MainActivity">

    <item
        android:id="@+id/file_menu"
        android:title="@string/file_menu"
        app:showAsAction="always">
        <menu>
            <item
                android:id="@+id/new_file_menu_item"
                android:icon="@mipmap/new_file"
                android:title="@string/new_file"
                app:showAsAction="ifRoom|withText" />
            <item
                android:id="@+id/open_file_menu_item"
                android:icon="@mipmap/open_file"
                android:title="@string/open_file"
                app:showAsAction="ifRoom|withText" />
            <item
                android:id="@+id/save_file_menu_item"
                android:icon="@mipmap/save_file"
                android:title="@string/save_file"
                app:showAsAction="ifRoom|withText" />
            <item
                android:id="@+id/exit_menu_item"
                android:icon="@mipmap/exit"
                android:title="@string/exit"
                app:showAsAction="ifRoom|withText" />
        </menu>
    </item>
    <item
        android:id="@+id/edit_menu"
        android:title="@string/edit_menu"
        app:showAsAction="always">
        <menu>
            <item
                android:id="@+id/cut_menu_item"
                android:icon="@mipmap/cut"
                android:title="@string/cut"
                app:showAsAction="ifRoom|withText" />
            <item
                android:id="@+id/copy_menu_item"
                android:icon="@mipmap/copy"
                android:title="@string/copy"
                app:showAsAction="ifRoom|withText" />
            <item
                android:id="@+id/paste_menu_item"
                android:icon="@mipmap/paste"
                android:title="@string/paste"
                app:showAsAction="ifRoom|withText" />
        </menu>
    </item>
</menu>

6、主界面类

package net.zs.xml_menu;

import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.Toast;

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        // 利用布局资源文件设置用户界面
        setContentView(R.layout.activity_main);
    }

    /**
     * 利用菜单配置文件生成选项菜单
     */
    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // 利用菜单填充器将菜单配置文件填充成菜单
        getMenuInflater().inflate(R.menu.main, menu);
        // 事件传播到此为止
        return true;
    }

    /**
     * 菜单项事件处理方法
     */
    @Override
    public boolean onOptionsItemSelected(@NonNull MenuItem item) {
        // 根据不同菜单项执行不同操作
        switch (item.getItemId()) {
            case R.id.new_file_menu_item:
                toast("新建文件");
                break;
            case R.id.open_file_menu_item:
                toast("打开文件");
                break;
            case R.id.save_file_menu_item:
                toast("保存文件");
                break;
            case R.id.exit_menu_item:
                finish();
                break;
            case R.id.cut_menu_item:
                toast("剪切");
                break;
            case R.id.copy_menu_item:
                toast("复制");
                break;
            case R.id.paste_menu_item:
                toast("粘贴");
                break;
        }
        // 事件传播到此为止
        return true;
    }

    /**
     * 吐司
     */
    public void toast(String text) {
        Toast.makeText(this, "你单击了【" + text + "】菜单项!", Toast.LENGTH_SHORT).show();
    }
}

7、运行程序,查看效果

在这里插入图片描述

8、修改菜单配置文件

  • 删除两个app:showAsAction="always"
    在这里插入图片描述
    在这里插入图片描述
  • 源代码
<?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"
    xmlns:tools="http://schemas.android.com/tools"
    tools:context="net.zs.xml_menu.MainActivity">

    <item
        android:id="@+id/file_menu"
        android:title="@string/file_menu">
        <menu>
            <item
                android:id="@+id/new_file_menu_item"
                android:icon="@mipmap/new_file"
                android:title="@string/new_file"
                app:showAsAction="ifRoom|withText" />
            <item
                android:id="@+id/open_file_menu_item"
                android:icon="@mipmap/open_file"
                android:title="@string/open_file"
                app:showAsAction="ifRoom|withText" />
            <item
                android:id="@+id/save_file_menu_item"
                android:icon="@mipmap/save_file"
                android:title="@string/save_file"
                app:showAsAction="ifRoom|withText" />
            <item
                android:id="@+id/exit_menu_item"
                android:icon="@mipmap/exit"
                android:title="@string/exit"
                app:showAsAction="ifRoom|withText" />
        </menu>
    </item>
    <item
        android:id="@+id/edit_menu"
        android:title="@string/edit_menu">
        <menu>
            <item
                android:id="@+id/cut_menu_item"
                android:icon="@mipmap/cut"
                android:title="@string/cut"
                app:showAsAction="ifRoom|withText" />
            <item
                android:id="@+id/copy_menu_item"
                android:icon="@mipmap/copy"
                android:title="@string/copy"
                app:showAsAction="ifRoom|withText" />
            <item
                android:id="@+id/paste_menu_item"
                android:icon="@mipmap/paste"
                android:title="@string/paste"
                app:showAsAction="ifRoom|withText" />
        </menu>
    </item>
</menu>

9、再次运行,查看效果

在这里插入图片描述

  • 可以看见【文件】和【编辑】被隐藏起来了
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值