上一讲我们讲解了android中在代码或者xml文件中定义菜单,这一讲我们继续来讲解一下定义菜单的其他方式:创建上下文的菜单。查看API文档 Menus :Creating Contextual Menus 模块
上下文菜单主要是给特定的选项或者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.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>
2) 定义菜单资源文件 main.xml
<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>
3) 程序主要代码 MainActivity.java
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);    }}
3. 程序执行结果



更多相关文章

  1. Android与WebView的插件管理机制
  2. android drawable xml文件 之 shape
  3. 【Android自定义View实战】之仿QQ运动步数圆弧及动画,Dylan计步中
  4. (转)android底部菜单应用
  5. Android官方Toolbar自定义高度最靠谱的解决办法「Android」
  6. Android(安卓)无法解决的几处硬伤
  7. 直接拿来用!最火的Android开源项目
  8. Android(安卓)Context关于POWER_SERVICE的实际应用
  9. Android仿百度外卖自定义下拉刷新效果

随机推荐

  1. android获取3G或wifi流量信息
  2. android中将中文以粗体显示
  3. TextView设置一行最多显示6个字是什么属
  4. Android(安卓)HandlerThread使用方法
  5. 完美解决android Studio打开报错 https:/
  6. Launcher
  7. Android(安卓)中Button点击频率的控制
  8. android提示错误: The process android.pr
  9. android各种声音类型级数设定及默认值
  10. 重写dialog