context menu

Android的菜单有三种:

Options Menu

当用户按下menu button按钮时显示的菜单
Context Menu 当用户长久按住屏幕,即被注册显示上下文菜单的视图时显示的菜单 Submenu
当用户按下一个菜单的某个选项时弹出的子菜单
现在演示一个上下文菜单。
main.xml布局文件:此布局文件定义了listview,用来显示一组列表,稍后上下文菜单将被注册到该listview,并且响应该listview。
Xml代码 复制代码 收藏代码
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:id="@+id/layout"
  4. android:layout_width="fill_parent" android:layout_height="fill_parent">
  5. <ListView android:id="@+id/lv_list" android:layout_width="wrap_content"
  6. android:layout_height="fill_parent">
  7. </ListView>
  8. </RelativeLayout>
item.xml布局文件,用来显示listview中的一个单独的控件
Xml代码 复制代码 收藏代码
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:id="@+id/layout"
  4. android:layout_width="fill_parent" android:layout_height="fill_parent">
  5. <TextView android:id="@+id/tv" android:layout_width="wrap_content"
  6. android:layout_height="fill_parent"
  7. android:textSize="20dip"
  8. >
  9. </TextView>
  10. </RelativeLayout>
在layout下新建一个menu文件夹,在建一个menu.xml布局文件
Xml代码 复制代码 收藏代码
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <menu xmlns:android="http://schemas.android.com/apk/res/android">
  3. <item android:id="@+id/new_game" android:title="新游戏" />
  4. <item android:id="@+id/help" android:title="寻求帮助" />
  5. <item android:id="@+id/addnew" android:title="添加新游戏" />
  6. <item android:id="@+id/delete" android:title="删除游戏" />
  7. </menu>
主activity代码
Java代码 复制代码 收藏代码
  1. package org.ynu.android;
  2. import java.util.ArrayList;
  3. import java.util.HashMap;
  4. import android.app.Activity;
  5. import android.os.Bundle;
  6. import android.view.ContextMenu;
  7. import android.view.ContextMenu.ContextMenuInfo;
  8. import android.view.Menu;
  9. import android.view.MenuInflater;
  10. import android.view.MenuItem;
  11. import android.view.View;
  12. import android.view.View.OnClickListener;
  13. import android.widget.AdapterView.AdapterContextMenuInfo;
  14. import android.widget.Button;
  15. import android.widget.ListView;
  16. import android.widget.SimpleAdapter;
  17. import android.widget.TextView;
  18. import android.widget.Toast;
  19. public class MenuActivity extends Activity {
  20. private ListView lv;
  21. /** Called when the activity is first created. */
  22. @Override
  23. public void onCreate(Bundle savedInstanceState) {
  24. super.onCreate(savedInstanceState);
  25. setContentView(R.layout.main);
  26. //如定义了一个listview控件
  27. ArrayList<HashMap<String, String>> list = new ArrayList<HashMap<String,String>>();
  28. HashMap<String, String> map1 = new HashMap<String, String>();
  29. map1.put("item", "第一个菜单项");
  30. HashMap<String, String> map2 = new HashMap<String, String>();
  31. map2.put("item", "第二个菜单项");
  32. HashMap<String, String> map3 = new HashMap<String, String>();
  33. map3.put("item", "第三个菜单项");
  34. HashMap<String, String> map4 = new HashMap<String, String>();
  35. map4.put("item", "第四个菜单项");
  36. HashMap<String, String> map5 = new HashMap<String, String>();
  37. map5.put("item", "第五个菜单项");
  38. list.add(map1);
  39. list.add(map2);
  40. list.add(map3);
  41. list.add(map4);
  42. list.add(map5);
  43. //初始化该控件
  44. lv=(ListView)findViewById(R.id.lv_list);
  45. //定义适配器 参数为该显示信息用的布局文件 以及显示信息用的控件,这里是一个textview控件
  46. SimpleAdapter adapter = new SimpleAdapter(this, list, R.layout.item, new String[]{"item"}, new int[]{R.id.tv});
  47. lv.setAdapter(adapter);
  48. //注册上下文菜单显示用的view
  49. registerForContextMenu(this.lv);
  50. }
  51. //该方法在注册的view被被长按时创建该view的上下文菜单
  52. @Override
  53. public void onCreateContextMenu(ContextMenu menu, View v,
  54. ContextMenuInfo menuInfo) {
  55. // TODO Auto-generated method stub
  56. MenuInflater inflater = getMenuInflater();
  57. inflater.inflate(R.menu.menu, menu);
  58. super.onCreateContextMenu(menu, v, menuInfo);
  59. }
  60. //当菜单某个选项被点击时调用该方法
  61. @Override
  62. public boolean onContextItemSelected(MenuItem item) {
  63. // TODO Auto-generated method stub
  64. AdapterContextMenuInfo infor = (AdapterContextMenuInfo)item.getMenuInfo();
  65. switch(item.getItemId())
  66. {
  67. case R.id.help:
  68. Toast.makeText(this, "请求帮助", Toast.LENGTH_LONG).show();
  69. return true;
  70. case R.id.addnew:
  71. Toast.makeText(this, "添加新的", Toast.LENGTH_LONG).show();
  72. return true;
  73. case R.id.delete:
  74. Toast.makeText(this, "删除信息", Toast.LENGTH_LONG).show();
  75. return true;
  76. case R.id.new_game:
  77. Toast.makeText(this, "新游戏", Toast.LENGTH_LONG).show();
  78. return true;
  79. default:
  80. return super.onContextItemSelected(item);
  81. }
  82. }
  83. //当上下文菜单关闭时调用的方法
  84. @Override
  85. public void onContextMenuClosed(Menu menu) {
  86. // TODO Auto-generated method stub
  87. super.onContextMenuClosed(menu);
  88. }
  89. }
package org.ynu.android;

import java.util.ArrayList;
import java.util.HashMap;

import android.app.Activity;
import android.os.Bundle;
import android.view.ContextMenu;
import android.view.ContextMenu.ContextMenuInfo;
import android.view.Menu;
import android.view.MenuInflater;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.AdapterView.AdapterContextMenuInfo;
import android.widget.Button;
import android.widget.ListView;
import android.widget.SimpleAdapter;
import android.widget.TextView;
import android.widget.Toast;

public class MenuActivity extends Activity {

	private ListView lv;
	
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
     
        //如定义了一个listview控件
        ArrayList<HashMap<String, String>> list = new ArrayList<HashMap<String,String>>();
        HashMap<String, String> map1 = new HashMap<String, String>();
        map1.put("item", "第一个菜单项");
        HashMap<String, String> map2 = new HashMap<String, String>();
        map2.put("item", "第二个菜单项");
        HashMap<String, String> map3 = new HashMap<String, String>();
        map3.put("item", "第三个菜单项");
        HashMap<String, String> map4 = new HashMap<String, String>();
        map4.put("item", "第四个菜单项");
        HashMap<String, String> map5 = new HashMap<String, String>();
        map5.put("item", "第五个菜单项");
        list.add(map1);
        list.add(map2);
        list.add(map3);
        list.add(map4);
        list.add(map5);
        
        //初始化该控件
        lv=(ListView)findViewById(R.id.lv_list);
        
        //定义适配器 参数为该显示信息用的布局文件 以及显示信息用的控件,这里是一个textview控件
        SimpleAdapter adapter = new SimpleAdapter(this, list, R.layout.item, new String[]{"item"}, new int[]{R.id.tv});
        lv.setAdapter(adapter);
        
        //注册上下文菜单显示用的view
        registerForContextMenu(this.lv);
    }

    //该方法在注册的view被被长按时创建该view的上下文菜单
	@Override
	public void onCreateContextMenu(ContextMenu menu, View v,
			ContextMenuInfo menuInfo) {
		// TODO Auto-generated method stub
		MenuInflater inflater = getMenuInflater();
		inflater.inflate(R.menu.menu, menu);
		super.onCreateContextMenu(menu, v, menuInfo);
	}

	//当菜单某个选项被点击时调用该方法
	@Override
	public boolean onContextItemSelected(MenuItem item) {
		// TODO Auto-generated method stub
		AdapterContextMenuInfo infor = (AdapterContextMenuInfo)item.getMenuInfo();
		switch(item.getItemId())
		{
		case R.id.help:
			Toast.makeText(this, "请求帮助", Toast.LENGTH_LONG).show();
			return true;
		case R.id.addnew:
			Toast.makeText(this, "添加新的", Toast.LENGTH_LONG).show();
			return true;
		case R.id.delete:
			Toast.makeText(this, "删除信息", Toast.LENGTH_LONG).show();
			return true;
		case R.id.new_game:
			Toast.makeText(this, "新游戏", Toast.LENGTH_LONG).show();
			return true;
			default:
				return super.onContextItemSelected(item);
		}
	}

	//当上下文菜单关闭时调用的方法
	@Override
	public void onContextMenuClosed(Menu menu) {
		// TODO Auto-generated method stub
		super.onContextMenuClosed(menu);
	}

}
效果图
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值