第44章、上下文菜单ContextMenu(从零开始学Android)

  上下文菜单ContextMenu可以像操作Options Menu那样给上下文菜单增加菜单项。

  上下文菜单与Options Menu最大的不同在于,Options Menu的拥有者是Activity,而上下文菜单的拥有者是Activity中的View。每个Activity有且只有一个Options Menu,它为整个Activity服务。而一个Activity往往有多个View,并不是每个View都有上下文菜单,这就需要我们显示地通过registerForContextMenu(View view)来指定。
 
  尽管上下文菜单的拥有者是View,生成上下文菜单却是通过Activity中的onCreateContextMenu(ContextMenu menu, View v, ContextMenu.ContextMenuInfo menuInfo)方法,该方法很像生成Options Menu的onCreateOptionsMenu(Menu menu)方法。两者的不同在于,onCreateOptionsMenu只在用户第一次按“Menu”键时被调用,而onCreateContextMenu会在用户每一次长按View时被调用,而且View必须已经注册了上下文菜单。

  一、程序文件 

  在上一章节OptionsMenu我们通过xml文件配置菜单项,本章我们直接采用代码完成,故不使用布局文件。

  打开“src/com.genwoxue.contextmenu/MainActivity.java”文件。

  然后输入以下代码:

package com.genwoxue.contextmenu;

import android.os.Bundle;
import android.view.View;  
import android.app.ListActivity;  
import android.view.ContextMenu;  
import android.view.ContextMenu.ContextMenuInfo;  
import android.view.Menu;  
import android.view.MenuItem;  
import android.widget.ArrayAdapter;  
import android.widget.Toast;

public class MainActivity extends ListActivity {

	@Override    
	protected void onCreate(Bundle savedInstanceState) {
		
		super.onCreate(savedInstanceState);
		// 显示列表
		simpleShowList();
		// 为所有列表项注册上下文菜单
		this.registerForContextMenu(getListView());    
	
	}
	
	private void simpleShowList() {
		
		// 模拟文件列表,在项目中可以实际读取文件列表
		String[] files =new String[] {
				"关于工信部网站备案通知.doc", 
				"企业年度预决算报表.xls",
				"客户说明会.ppt",
				"企业形像宣传片.avi" 
		};
		
		// 数据适配器 simple array adapter
		ArrayAdapter<String> adapter =new ArrayAdapter<String>(this,android.R.layout.simple_list_item_1,files); 
		
		// 填充列表
		this.setListAdapter(adapter);

		}

	@Override
	public void onCreateContextMenu(ContextMenu menu, View v,ContextMenuInfo menuInfo) {

		// 设置ContextMenu标题
		menu.setHeaderTitle("文件操作");
		// 添加ContextMenu菜单项
		menu.add(0, 1, Menu.NONE, "蓝牙发送");
		menu.add(0, 2, Menu.NONE, "标记为重要");
		menu.add(0, 3, Menu.NONE, "重命名");
		menu.add(0, 4, Menu.NONE, "删除");
	}
	
	@Override
	public boolean onContextItemSelected(MenuItem item) {
		    
		// 得到当前被选中的item信息
	    switch(item.getItemId()) {
		    case 1:
		    	Toast.makeText(getApplicationContext(), "发送文件", Toast.LENGTH_SHORT).show();
		    	break;
		    case 2:
		    	Toast.makeText(getApplicationContext(), "标记为重要☆☆☆", Toast.LENGTH_SHORT).show();
		    	break;
		    case 3:
		    	Toast.makeText(getApplicationContext(), "重命名", Toast.LENGTH_SHORT).show();
		    	break;
		    case 4:
		    	Toast.makeText(getApplicationContext(), "删除", Toast.LENGTH_SHORT).show();
		    	break;
		    default:
		        return super.onContextItemSelected(item);
		    }
		return true;
	}
}

  ContextMenu与OptionsMenu菜单有着很多相似之和,在此就不赘述了。

  二、运行结果

  

     

 

特别说明:


  另一个值得注意的ContextMenuInfo,该类的对象被传入onCreateContextMenu(ContextMenu menu, View v, ContextMenu.ContextMenuInfo menuInfo)方法,那么它有什么用呢?有时候,视图元素需要向上下文菜单传递一些信息,比如该View对应DB记录的ID等,这就要使用ContextMenuInfo。需要传递额外信息的View需要重写getContextMenuInfo()方法,返回一个带有数据的ContextMenuInfo实现类对象。

  由于本安全不涉及数据库,仅作参考。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

蒋会全

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值