diff --git a/DropdownMenu.java b/DropdownMenu.java new file mode 100644 index 0000000..c969c70 --- /dev/null +++ b/DropdownMenu.java @@ -0,0 +1,90 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package net.micode.notes.ui; + +import android.content.Context; + // 引入 Context 类,提供访问应用环境的功能,如启动活动、获取系统服务、访问资源等。 +import android.view.Menu; +// 引入 Menu 类,定义菜单的结构,通常用于上下文菜单、选项菜单等。 +import android.view.MenuItem; + // 引入 MenuItem 类,代表菜单中的一项,可以设置标题、图标等属性并绑定点击事件。 +import android.view.View; +// 引入 View 类,所有 UI 控件的基类,处理控件的显示和用户交互(如点击、拖动等)。 +import android.view.View.OnClickListener; +// 引入 OnClickListener 接口,用于处理视图(如按钮)的点击事件。 +import android.widget.Button; +// 引入 Button 类,用于在界面中创建按钮控件,用户点击按钮时可以触发某个操作。 +import android.widget.PopupMenu; +// 引入 PopupMenu 类,表示一个弹出式菜单,通常用于显示上下文菜单或按钮点击后的菜单。 +import android.widget.PopupMenu.OnMenuItemClickListener; +// 引入 OnMenuItemClickListener 接口,用于处理 PopupMenu 中菜单项的点击事件。 +import net.micode.notes.R; +// 引入 R 类,自动生成的资源类,用于访问应用的资源文件(如布局、字符串、ID 等)。 + + +// DropdownMenu 类用于显示一个下拉菜单 +public class DropdownMenu { + + // 成员变量 + private Button mButton; // 按钮,用于触发下拉菜单显示 + private PopupMenu mPopupMenu; // 弹出菜单 + private Menu mMenu; // 菜单对象,用于管理菜单项 + + // 构造函数,初始化按钮和菜单 + public DropdownMenu(Context context, Button button, int menuId) { + // 将传入的按钮实例赋值给 mButton + mButton = button; + + // 设置按钮的背景资源(这里使用的是一个下拉图标) + mButton.setBackgroundResource(R.drawable.dropdown_icon); + + // 初始化 PopupMenu 对象,关联按钮 + mPopupMenu = new PopupMenu(context, mButton); + + // 获取菜单对象 + mMenu = mPopupMenu.getMenu(); + + // 使用菜单 ID(通过菜单资源 XML 文件)填充菜单项 + mPopupMenu.getMenuInflater().inflate(menuId, mMenu); + + // 设置按钮的点击事件监听器,当按钮被点击时显示弹出菜单 + mButton.setOnClickListener(new OnClickListener() { + public void onClick(View v) { + // 显示弹出菜单 + mPopupMenu.show(); + } + }); + } + + // 设置菜单项点击事件监听器 + public void setOnDropdownMenuItemClickListener(OnMenuItemClickListener listener) { + // 如果 mPopupMenu 已经初始化,则设置菜单项点击事件监听器 + if (mPopupMenu != null) { + mPopupMenu.setOnMenuItemClickListener(listener); + } + } + + // 根据 ID 查找菜单项 + public MenuItem findItem(int id) { + return mMenu.findItem(id); + } + + // 设置按钮的文本(通常用于显示当前菜单的标题或提示) + public void setTitle(CharSequence title) { + mButton.setText(title); + } +}