|
|
/*
|
|
|
* 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
|
|
|
* 描述: 下拉菜单组件
|
|
|
* 作用: 提供一个基于按钮和弹出菜单的下拉菜单组件
|
|
|
* 功能:
|
|
|
* 1. 将按钮与弹出菜单关联,点击按钮显示菜单
|
|
|
* 2. 支持设置菜单项点击监听器
|
|
|
* 3. 支持查找特定菜单项
|
|
|
* 4. 支持设置按钮标题
|
|
|
*/
|
|
|
package net.micode.notes.ui;
|
|
|
|
|
|
import android.content.Context;
|
|
|
import android.view.Menu;
|
|
|
import android.view.MenuItem;
|
|
|
import android.view.View;
|
|
|
import android.view.View.OnClickListener;
|
|
|
import android.widget.Button;
|
|
|
import android.widget.PopupMenu;
|
|
|
import android.widget.PopupMenu.OnMenuItemClickListener;
|
|
|
|
|
|
import net.micode.notes.R;
|
|
|
|
|
|
/**
|
|
|
* 下拉菜单组件类
|
|
|
*
|
|
|
* 这个类封装了一个基于按钮和PopupMenu的下拉菜单组件。
|
|
|
* 用户点击按钮时,会显示一个下拉菜单,用户可以从中选择选项。
|
|
|
* 组件支持设置菜单项点击监听器,以及查找特定菜单项和设置按钮标题。
|
|
|
*/
|
|
|
public class DropdownMenu {
|
|
|
/** 触发菜单显示的按钮 */
|
|
|
private Button mButton;
|
|
|
|
|
|
/** 弹出菜单对象 */
|
|
|
private PopupMenu mPopupMenu;
|
|
|
|
|
|
/** 菜单对象,用于管理菜单项 */
|
|
|
private Menu mMenu;
|
|
|
|
|
|
/**
|
|
|
* 构造函数
|
|
|
*
|
|
|
* @param context 上下文环境
|
|
|
* @param button 用于触发菜单显示的按钮
|
|
|
* @param menuId 菜单资源ID
|
|
|
*/
|
|
|
public DropdownMenu(Context context, Button button, int menuId) {
|
|
|
mButton = button;
|
|
|
// 设置按钮的背景为下拉图标
|
|
|
mButton.setBackgroundResource(R.drawable.dropdown_icon);
|
|
|
|
|
|
// 创建弹出菜单,并与按钮关联
|
|
|
mPopupMenu = new PopupMenu(context, mButton);
|
|
|
// 获取菜单对象
|
|
|
mMenu = mPopupMenu.getMenu();
|
|
|
// 从资源文件中加载菜单项
|
|
|
mPopupMenu.getMenuInflater().inflate(menuId, mMenu);
|
|
|
|
|
|
// 设置按钮点击监听器,点击时显示菜单
|
|
|
mButton.setOnClickListener(new OnClickListener() {
|
|
|
public void onClick(View v) {
|
|
|
// 显示弹出菜单
|
|
|
mPopupMenu.show();
|
|
|
}
|
|
|
});
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* 设置下拉菜单项点击监听器
|
|
|
*
|
|
|
* @param listener 菜单项点击监听器
|
|
|
*/
|
|
|
public void setOnDropdownMenuItemClickListener(OnMenuItemClickListener listener) {
|
|
|
if (mPopupMenu != null) {
|
|
|
mPopupMenu.setOnMenuItemClickListener(listener);
|
|
|
}
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* 查找指定ID的菜单项
|
|
|
*
|
|
|
* @param id 要查找的菜单项ID
|
|
|
* @return 找到的菜单项,如果不存在则返回null
|
|
|
*/
|
|
|
public MenuItem findItem(int id) {
|
|
|
return mMenu.findItem(id);
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* 设置按钮标题文本
|
|
|
*
|
|
|
* @param title 要设置的标题文本
|
|
|
*/
|
|
|
public void setTitle(CharSequence title) {
|
|
|
mButton.setText(title);
|
|
|
}
|
|
|
}
|