【Android(安卓)开发】:UI控件之 Menu 菜单的的使用(二)
16lz
2021-01-25
上一讲我们讲解了android中在代码或者xml文件中定义菜单,这一讲我们继续来讲解一下定义菜单的其他方式:创建上下文的菜单。查看API文档 Menus :Creating Contextual Menus 模块
1. 创建浮动的上下文菜单 (floating context menu) 1. 通过调用 registerForContextMenu() 方法来注册上下文菜单,同时关联到这个 View。如果你的 activity 使用 ListView或者 GridView ,你想每一个选项都提供相同的上下文菜单,就要通过 registerForContextMenu() 方法为关联到 ListView或者 GridView 注册上下文菜单。 2. 在你的Activity 或者Fragment中实现onCreateContextMenu()方法,注册完视图之后,当它接受一个长按的事件时,系统就会调用onCreateContextMenu() 方法。这就是你需要定义你菜单选项的地方,通常是通过动态加载菜单资源来定义的。 3. 实现onContextItemSelected() 方法,当用户选择了菜单选项之后,系统就会调用这里面的方法,这样你就可以执行适当的动作。
2. 代码实现
上下文菜单主要是给特定的选项或者UI中的上下文框架提供一个动作,这种创建上下文菜单的方式可以用在任何视图控件中,一般用在 ListView 和 GridView 这种控件中。有两种方式提供上下文菜单的动作:
1. 悬浮的窗口的形式,类似于对话框,当用户长按选项时候触发事件。 2. 使用ActionMode的形式,是在屏幕顶端实现。[后续再讲]下面我们来讲解一下第一种定义上下文菜单的方式.
注意这种菜单是用在Android 3.0 版本或者更高版本中。
1. 创建浮动的上下文菜单 (floating context menu) 1. 通过调用 registerForContextMenu() 方法来注册上下文菜单,同时关联到这个 View。如果你的 activity 使用 ListView或者 GridView ,你想每一个选项都提供相同的上下文菜单,就要通过 registerForContextMenu() 方法为关联到 ListView或者 GridView 注册上下文菜单。 2. 在你的Activity 或者Fragment中实现onCreateContextMenu()方法,注册完视图之后,当它接受一个长按的事件时,系统就会调用onCreateContextMenu() 方法。这就是你需要定义你菜单选项的地方,通常是通过动态加载菜单资源来定义的。 3. 实现onContextItemSelected() 方法,当用户选择了菜单选项之后,系统就会调用这里面的方法,这样你就可以执行适当的动作。
2. 代码实现
1) 布局文件 activity_main.xml3. 程序执行结果
2) 定义菜单资源文件 main.xml<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:paddingBottom="@dimen/activity_vertical_margin" android:paddingLeft="@dimen/activity_horizontal_margin" android:paddingRight="@dimen/activity_horizontal_margin" android:paddingTop="@dimen/activity_vertical_margin" tools:context=".MainActivity" > <ListView android:id="@+id/listView1" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_alignParentLeft="true" android:layout_alignParentTop="true" > </ListView></RelativeLayout>
3) 程序主要代码 MainActivity.java<menu xmlns:android="http://schemas.android.com/apk/res/android" > <item android:id="@+id/edit" android:orderInCategory="100" android:showAsAction="never" android:title="edit"/> <item android:id="@+id/share" android:orderInCategory="100" android:showAsAction="never" android:title="share"/> <item android:id="@+id/delete" android:orderInCategory="100" android:showAsAction="never" android:title="delete"/></menu>
package com.android.contextmenudemo;import android.os.Bundle;import android.app.Activity;import android.view.ContextMenu;import android.view.Menu;import android.view.MenuInflater;import android.view.MenuItem;import android.view.View;import android.view.ContextMenu.ContextMenuInfo;import android.widget.ArrayAdapter;import android.widget.ListView;import android.widget.Toast;import java.util.ArrayList;import java.util.List;public class MainActivity extends Activity { private ListView listView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initComponent(); ArrayAdapter<String> adapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, getData()); listView.setAdapter(adapter); // 给ListView注册上下文菜单 registerForContextMenu(listView); // 这里接受的参数是一个View的类型 } private List<String> getData() { List<String> list = new ArrayList<String>(); for (int i = 0; i <= 6; i++) { list.add("AHuier" + i); } return list; } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true; } /** * onCreateOptionsMenu() 与 onCreateContextMenu()的区别 第一个是普通的可选菜单 第二个是添加上下文的菜单 */ @Override public void onCreateContextMenu(ContextMenu menu, View v, ContextMenuInfo menuInfo) { // 加载xml中的上下文菜单 super.onCreateContextMenu(menu, v, menuInfo); MenuInflater inflate = getMenuInflater(); inflate.inflate(R.menu.main, menu); } // 响应上下文菜单的操作 @Override public boolean onContextItemSelected(MenuItem item) { // TODO Auto-generated method stub switch (item.getItemId()) { case R.id.edit: Toast.makeText(MainActivity.this, "Edit", Toast.LENGTH_LONG).show(); break; case R.id.share: Toast.makeText(MainActivity.this, "share", Toast.LENGTH_LONG).show(); break; case R.id.delete: Toast.makeText(MainActivity.this, "delete", Toast.LENGTH_LONG).show(); break; default: break; } return super.onContextItemSelected(item); } private void initComponent() { listView = (ListView) findViewById(R.id.listView1); }}
更多相关文章
- Android与WebView的插件管理机制
- android drawable xml文件 之 shape
- 【Android自定义View实战】之仿QQ运动步数圆弧及动画,Dylan计步中
- (转)android底部菜单应用
- Android官方Toolbar自定义高度最靠谱的解决办法「Android」
- Android(安卓)无法解决的几处硬伤
- 直接拿来用!最火的Android开源项目
- Android(安卓)Context关于POWER_SERVICE的实际应用
- Android仿百度外卖自定义下拉刷新效果