创建上下文菜单

1、res下创建menu目录,在该目录下创建contextmenu.xml的菜单资源文件

<?xml version="1.0" encoding="UTF-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:id="@+id/color1" android:title="红色"/>
    <item android:id="@+id/color2" android:title="绿色"/>
    <item android:id="@+id/color3" android:title="蓝色"/>
    <item android:id="@+id/color4" android:title="橙色"/>
    <item android:id="@+id/color5" android:title="恢复默认"/>
</menu>

2、布局文件

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:padding="5px"
    android:orientation="vertical" >
    <TextView
        android:id="@+id/show"
        android:textSize="28px"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="打开菜单..." />
 
</LinearLayout>

3、MainActivity.java

public class MainActivity extends Activity {
	private TextView tv;

	@Override
	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		tv = (TextView) findViewById(R.id.show);
		registerForContextMenu(tv); // 为文本框注册上下文菜单

	}

	// 创建上下文菜单
	/************************************************************/
	@Override
	public void onCreateContextMenu(ContextMenu menu, View v,
			ContextMenuInfo menuInfo) {
		MenuInflater inflator = new MenuInflater(this); // 实例化一个MenuInflater对象
		inflator.inflate(R.menu.contextmenu, menu); // 解析菜单文件
		menu.setHeaderIcon(R.drawable.ic_launcher); // 为菜单头设置图标
		menu.setHeaderTitle("请选择文字颜色:"); // 为菜单头设置标题

	}

	@Override
	public boolean onContextItemSelected(MenuItem item) {
		switch (item.getItemId()) {
		case R.id.color1: // 当选择红颜色时
			tv.setTextColor(Color.rgb(255, 0, 0));
			break;
		case R.id.color2: // 当选择绿颜色时
			tv.setTextColor(Color.rgb(0, 255, 0));
			break;
		case R.id.color3: // 当选择蓝颜色时
			tv.setTextColor(Color.rgb(0, 0, 255));
			break;
		case R.id.color4: // 当选择橙色时
			tv.setTextColor(Color.rgb(255, 180, 0));
			break;
		default:
			tv.setTextColor(Color.rgb(255, 255, 255));
		}
		return true;
	}

}


长按不放弹出菜单



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在 VS Code 中创建上下文菜单,您需要编写一个扩展。以下是一个简单的步骤: 1. 打开 VS Code 并创建一个新的文件夹,例如 `my-extension`。 2. 在终端中导航到该文件夹,并运行以下命令:`yo code`。这将启动 Yeoman 代码生成器,用于创建新的扩展。 3. 选择 `New Extension (TypeScript)`,然后按照提示进行操作。您需要提供一些基本信息,例如扩展的名称和描述。 4. 在生成的扩展项目中,找到 `package.json` 文件并打开它。在 `activationEvents` 中添加以下行: ``` "activationEvents": [ "onCommand:myExtension.myCommand", "onContextMenu" ] ``` 这将激活您的扩展,并在 VS Code 中显示上下文菜单。 5. 打开 `src/extension.ts` 文件,找到 `activate` 函数。在此函数中,使用以下代码创建上下文菜单: ``` vscode.commands.registerCommand('myExtension.myCommand', () => { const disposable = vscode.commands.registerCommand('myExtension.myCommand', () => { vscode.window.showInformationMessage('Hello World!'); }); vscode.window.showInformationMessage('My Extension is now active!'); const contextMenuDisposable = vscode.commands.registerCommand('myExtension.contextMenuCommand', () => { vscode.window.showInformationMessage('Context Menu Command!'); }); vscode.window.registerTreeDataProvider('myExtension.treeView', treeDataProvider); context.subscriptions.push(disposable); context.subscriptions.push(contextMenuDisposable); }); ``` 这将创建一个名为 `myExtension.contextMenuCommand` 的上下文菜单命令,并将其添加到扩展的订阅列表中。 6. 运行您的扩展。在 VS Code 中,使用快捷键 `F5` 或打开调试器并选择 `Run Extension`。一旦扩展启动,右键单击编辑器中的内容,您应该会看到您的上下文菜单。 这只是一个简单的示例,您可以根据需要自定义上下文菜单。有关更多信息,请参阅 VS Code 扩展开发文档。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值