简单实现Android弹出菜单效果

 更新时间:2016年06月14日 11:48:12   转载 作者:rainmj  
这篇文章主要为大家详细介绍了简单实现Android弹出菜单效果的相关代码,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了Android弹出菜单效果的具体代码,供大家参考,具体内容如下

功能描述:用户单击按钮弹出菜单。当用户选择一个菜单项,会触发MenuItemClick事件并让弹出的菜单消失;如果用户在菜单外单击,则直接消失弹出的菜单。当菜单消失时,会引发DismissEvent事件(利用此事件可在菜单消失时做一些后续处理)。

1、运行效果

 

2、添加菜单项
在Resources文件夹下添加一个menu子文件夹,然后在此子文件夹下添加一个名为demo07_popup_menu.xml的文件:

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
  <item android:id="@+id/item1"
     android:title="item 1" />  
  <item android:id="@+id/item1"
     android:title="item 2" /> 
  <item android:id="@+id/item1"
     android:title="item 3" />
</menu> 

3、添加demo07_PopupMenu.axml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:orientation="vertical"
  android:layout_width="fill_parent"
  android:layout_height="fill_parent">
  <Button
    android:id="@+id/popupButton"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:text="@string/showPopup" />
</LinearLayout> 

保存所有文件。

4、添加Demo07PopupMenu.cs

using Android.App;
using Android.OS;
using Android.Widget;

namespace ch05demos.SrcActivity
{
  [Activity(Label = "Demo07PopupMenu")]
  public class Demo07PopupMenu : Activity
  {
    protected override void OnCreate(Bundle savedInstanceState)
    {
      base.OnCreate(savedInstanceState);
      SetContentView(Resource.Layout.demo07_Popup);

      Button btn = FindViewById<Button>(Resource.Id.popupButton);
      btn.Click += (s, arg) =>
      {
        PopupMenu menu = new PopupMenu(this, btn);
        menu.Inflate(Resource.Menu.demo07_popup_menu);
        menu.MenuItemClick += (sender, args) =>
        {
          string str = string.Format("你选择了:{0}", args.Item);
          Toast.MakeText(this,str, ToastLength.Short).Show();
        };
        menu.DismissEvent += (sender, args) =>
        {
          //菜单消失后可在此事件中做一些后续处理
        };
        menu.Show();
      };
    }
  }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

最新评论