|
|
/*
|
|
|
* 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.
|
|
|
*/
|
|
|
|
|
|
// DropdownMenu.java - 下拉菜单包装类
|
|
|
// 主要功能:将Button和PopupMenu组合封装,提供简洁的下拉菜单实现
|
|
|
package net.micode.notes.ui;
|
|
|
|
|
|
// ======================= 导入区域 =======================
|
|
|
// Android上下文
|
|
|
import android.content.Context; // 上下文
|
|
|
// Android菜单相关
|
|
|
import android.view.Menu; // 菜单接口
|
|
|
import android.view.MenuItem; // 菜单项
|
|
|
// Android视图相关
|
|
|
import android.view.View; // 视图基类
|
|
|
import android.view.View.OnClickListener; // 点击监听器
|
|
|
// Android控件
|
|
|
import android.widget.Button; // 按钮控件
|
|
|
import android.widget.PopupMenu; // 弹出菜单控件
|
|
|
import android.widget.PopupMenu.OnMenuItemClickListener; // 弹出菜单项点击监听器
|
|
|
|
|
|
// 应用内部资源
|
|
|
import net.micode.notes.R; // 资源文件R类
|
|
|
|
|
|
// ======================= 下拉菜单包装类 =======================
|
|
|
/**
|
|
|
* DropdownMenu - 下拉菜单包装类
|
|
|
* 功能:将Button控件与PopupMenu组合,创建下拉菜单效果
|
|
|
* 使用方式:将Button转换为下拉菜单按钮,点击显示菜单
|
|
|
* 设计模式:外观模式(Facade),简化PopupMenu的使用
|
|
|
*/
|
|
|
public class DropdownMenu {
|
|
|
|
|
|
// ======================= 成员变量 =======================
|
|
|
|
|
|
/** 按钮控件 - 显示为下拉菜单的触发器按钮 */
|
|
|
private Button mButton;
|
|
|
|
|
|
/** 弹出菜单 - 实际的PopupMenu控件,包含菜单项 */
|
|
|
private PopupMenu mPopupMenu;
|
|
|
|
|
|
/** 菜单对象 - 对应PopupMenu中的菜单,用于查找菜单项 */
|
|
|
private Menu mMenu;
|
|
|
|
|
|
// ======================= 构造函数 =======================
|
|
|
|
|
|
/**
|
|
|
* 构造函数
|
|
|
* 初始化下拉菜单,将普通Button转换为下拉菜单按钮
|
|
|
*
|
|
|
* 工作流程:
|
|
|
* 1. 保存Button引用
|
|
|
* 2. 设置Button背景为下拉箭头图标
|
|
|
* 3. 创建PopupMenu并关联到Button
|
|
|
* 4. 获取Menu对象
|
|
|
* 5. 加载菜单布局
|
|
|
* 6. 设置Button点击事件显示菜单
|
|
|
*
|
|
|
* @param context 上下文,用于创建PopupMenu
|
|
|
* @param button 按钮控件,将转换为下拉菜单触发器
|
|
|
* @param menuId 菜单资源ID,对应res/menu目录下的XML文件
|
|
|
*
|
|
|
* 示例:
|
|
|
* new DropdownMenu(context, button, R.menu.note_operation_menu);
|
|
|
*/
|
|
|
public DropdownMenu(Context context, Button button, int menuId) {
|
|
|
// 1. 保存Button引用
|
|
|
mButton = button;
|
|
|
|
|
|
// 2. 设置Button背景为下拉箭头图标
|
|
|
// R.drawable.dropdown_icon: 下拉箭头图标
|
|
|
// 使Button看起来像下拉菜单按钮
|
|
|
mButton.setBackgroundResource(R.drawable.dropdown_icon);
|
|
|
|
|
|
// 3. 创建PopupMenu并关联到Button
|
|
|
// 第二个参数是锚点视图,菜单会显示在Button下方
|
|
|
mPopupMenu = new PopupMenu(context, mButton);
|
|
|
|
|
|
// 4. 获取PopupMenu的Menu对象
|
|
|
mMenu = mPopupMenu.getMenu();
|
|
|
|
|
|
// 5. 加载菜单布局文件
|
|
|
// 从XML资源文件加载菜单项到Menu对象
|
|
|
mPopupMenu.getMenuInflater().inflate(menuId, mMenu);
|
|
|
|
|
|
// 6. 设置Button点击事件
|
|
|
mButton.setOnClickListener(new OnClickListener() {
|
|
|
/**
|
|
|
* Button点击事件处理
|
|
|
* 点击Button时显示弹出菜单
|
|
|
* @param v 被点击的Button视图
|
|
|
*/
|
|
|
public void onClick(View v) {
|
|
|
mPopupMenu.show(); // 显示弹出菜单
|
|
|
}
|
|
|
});
|
|
|
}
|
|
|
|
|
|
// ======================= 菜单项点击监听器设置 =======================
|
|
|
|
|
|
/**
|
|
|
* 设置下拉菜单项点击监听器
|
|
|
* 当用户点击菜单项时触发
|
|
|
*
|
|
|
* @param listener 菜单项点击监听器
|
|
|
* 实现OnMenuItemClickListener接口
|
|
|
*
|
|
|
* 使用示例:
|
|
|
* dropdownMenu.setOnDropdownMenuItemClickListener(new OnMenuItemClickListener() {
|
|
|
* @Override
|
|
|
* public boolean onMenuItemClick(MenuItem item) {
|
|
|
* // 处理菜单项点击
|
|
|
* return true;
|
|
|
* }
|
|
|
* });
|
|
|
*/
|
|
|
public void setOnDropdownMenuItemClickListener(OnMenuItemClickListener listener) {
|
|
|
// 安全检查:确保PopupMenu已创建
|
|
|
if (mPopupMenu != null) {
|
|
|
mPopupMenu.setOnMenuItemClickListener(listener);
|
|
|
}
|
|
|
}
|
|
|
|
|
|
// ======================= 菜单项查找 =======================
|
|
|
|
|
|
/**
|
|
|
* 根据ID查找菜单项
|
|
|
* 用于动态修改菜单项属性(如启用状态、标题、图标等)
|
|
|
*
|
|
|
* @param id 菜单项资源ID
|
|
|
* @return 找到的MenuItem对象,未找到返回null
|
|
|
*
|
|
|
* 使用示例:
|
|
|
* MenuItem item = dropdownMenu.findItem(R.id.menu_delete);
|
|
|
* if (item != null) {
|
|
|
* item.setEnabled(false); // 禁用删除菜单项
|
|
|
* }
|
|
|
*/
|
|
|
public MenuItem findItem(int id) {
|
|
|
return mMenu.findItem(id);
|
|
|
}
|
|
|
|
|
|
// ======================= 按钮标题设置 =======================
|
|
|
|
|
|
/**
|
|
|
* 设置按钮标题文本
|
|
|
* 用于动态更新下拉按钮显示的文字
|
|
|
*
|
|
|
* @param title 按钮标题文本
|
|
|
*
|
|
|
* 使用示例:
|
|
|
* dropdownMenu.setTitle("操作菜单");
|
|
|
* 或
|
|
|
* dropdownMenu.setTitle(getString(R.string.menu_title));
|
|
|
*/
|
|
|
public void setTitle(CharSequence title) {
|
|
|
mButton.setText(title);
|
|
|
}
|
|
|
} |