|
|
|
|
/*
|
|
|
|
|
* 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;
|
|
|
|
|
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;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* DropdownMenu 类用于实现一个带有下拉菜单的按钮组件。
|
|
|
|
|
* 按钮点击时会显示一个弹出菜单,菜单项点击时可以设置回调事件。
|
|
|
|
|
*/
|
|
|
|
|
public class DropdownMenu {
|
|
|
|
|
|
|
|
|
|
private Button mButton; // 存储与菜单关联的按钮
|
|
|
|
|
private PopupMenu mPopupMenu; // 存储弹出菜单对象
|
|
|
|
|
private Menu mMenu; // 存储菜单对象
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 构造函数,初始化 DropdownMenu。
|
|
|
|
|
* @param context 上下文对象
|
|
|
|
|
* @param button 要显示下拉菜单的按钮
|
|
|
|
|
* @param menuId 菜单资源ID
|
|
|
|
|
*/
|
|
|
|
|
public DropdownMenu(Context context, Button button, int menuId) {
|
|
|
|
|
mButton = button;
|
|
|
|
|
// 设置按钮背景图标(这里使用了一个下拉图标)
|
|
|
|
|
mButton.setBackgroundResource(R.drawable.dropdown_icon);
|
|
|
|
|
|
|
|
|
|
// 创建一个 PopupMenu 对象,显示在按钮下方
|
|
|
|
|
mPopupMenu = new PopupMenu(context, mButton);
|
|
|
|
|
|
|
|
|
|
// 获取菜单对象,之后可以对菜单进行操作
|
|
|
|
|
mMenu = mPopupMenu.getMenu();
|
|
|
|
|
|
|
|
|
|
// 根据给定的菜单ID,加载对应的菜单资源
|
|
|
|
|
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 找到的菜单项
|
|
|
|
|
*/
|
|
|
|
|
public MenuItem findItem(int id) {
|
|
|
|
|
return mMenu.findItem(id); // 查找菜单项
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 设置按钮的标题文本。
|
|
|
|
|
* @param title 新的按钮文本
|
|
|
|
|
*/
|
|
|
|
|
public void setTitle(CharSequence title) {
|
|
|
|
|
mButton.setText(title); // 设置按钮显示的文本
|
|
|
|
|
}
|
|
|
|
|
}
|