/*
 * 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); // 设置按钮显示的文本
    }
}