本文将为您提供关于一手遮天Android-view的详细介绍,我们还将为您解释弹出类:ContextMenu基础的相关知识,同时,我们还将为您提供关于AndroidContextMenuforView
本文将为您提供关于一手遮天 Android - view的详细介绍,我们还将为您解释弹出类: ContextMenu 基础的相关知识,同时,我们还将为您提供关于Android ContextMenu for View(非活动)、android ContextMenu 上下文菜单示例、Android ContextMenu和Listview配合使用、android – onCreateContextMenu使用ContextMenuInfo的null值调用的实用信息。
本文目录一览:- 一手遮天 Android - view(弹出类): ContextMenu 基础(搜索一手遮天)
- Android ContextMenu for View(非活动)
- android ContextMenu 上下文菜单示例
- Android ContextMenu和Listview配合使用
- android – onCreateContextMenu使用ContextMenuInfo的null值调用
一手遮天 Android - view(弹出类): ContextMenu 基础(搜索一手遮天)
项目地址 https://github.com/webabcd/AndroidDemo
作者 webabcd
一手遮天 Android - view(弹出类): ContextMenu 基础
示例如下:
/view/flyout/ContextMenuDemo1.java
/**
* ContextMenu - 上下文菜单(长按 view 弹出的菜单)
*
* 本例会演示如何弹出一个包含父菜单和子菜单的 ContextMenu(数据可以来自 xml 或 java)
*
* 注:如果觉得 ContextMenu 实现不了需求,就用 PopupWindow 吧
*/
package com.webabcd.androiddemo.view.flyout;
import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.view.ContextMenu;
import android.view.MenuInflater;
import android.view.MenuItem;
import android.view.SubMenu;
import android.view.View;
import android.widget.Button;
import android.widget.Toast;
import com.webabcd.androiddemo.R;
public class ContextMenuDemo1 extends AppCompatActivity {
private Button mButton1;
private Button mButton2;
// 用于保存当前显示的上下文菜单的关联的 view 的 id
private int mCurrentViewId;
// 用于保存当前显示的上下文菜单数据
private ContextMenu mCurrentMenu;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_view_flyout_contextmenudemo1);
mButton1 = findViewById(R.id.button1);
mButton2 = findViewById(R.id.button2);
sample();
}
private void sample() {
// registerForContextMenu() - 为指定的 view 注册上下文菜单(注册后,长按指定的 view 就会显示上下文菜单)
registerForContextMenu(mButton1);
registerForContextMenu(mButton2);
mButton1.setonClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
mCurrentViewId = v.getId();
// showContextMenu() - 手动显示上下文菜单
v.showContextMenu();
}
});
mButton2.setonClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
mCurrentViewId = v.getId();
v.showContextMenu();
}
});
}
// 长按通过 registerForContextMenu() 注册的 view 时,会调用此方法来构造并显示上下文菜单
@Override
public void onCreateContextMenu(ContextMenu menu, View v, ContextMenu.ContextMenuInfo menuInfo) {
mCurrentViewId = v.getId();
mCurrentMenu = menu;
if (v.getId() == R.id.button1) {
// 从 xml 中加载 ContextMenu 的显示数据(参见 res/menu/menu_view_flyout_contextmenudemo1.xml)
// 加载的数据会赋值给 menu,然后可以在 java 中对 menu 增删
new MenuInflater(this).inflate(R.menu.menu_view_flyout_contextmenudemo1, menu);
}
else if (v.getId() == R.id.button2) {
// 通过 java 构造 ContextMenu 的选项数据,增删都可以
// add() - 添加菜单项
// addSubMenu() - 添加具有子菜单的菜单项
// 第 1 个参数:分组 id(没用)
// 第 2 个参数:选项 id
// 第 3 个参数:选项排序
// 第 4 个参数:选项 title
// setEnabled() - 指定当前菜单是否可用
// setHeaderTitle() - 指定当前具有子菜单的菜单项展开后,它的标题需要显示的内容
menu.add(2, 10002, 2, "item 2").setEnabled(false);
menu.add(1, 10001, 1, "item 1");
SubMenu subMenu = menu.addSubMenu(0, 10000, 0, "item 0").setHeaderTitle("item 0 下的子菜单");
subMenu.add(0, 10000, 0, "item 0_0");
subMenu.add(0, 10001, 1, "item 0_1");
subMenu.add(0, 10002, 2, "item 0_2");
}
super.onCreateContextMenu(menu, v, menuInfo);
}
// 选中 ContextMenu 中的项时会调用此方法
@Override
public boolean onContextItemSelected(MenuItem item) {
// item.getItemId() - 选项的 id
// item.getTitle() - 选项的 title
if (mCurrentViewId == R.id.button1) {
Toast.makeText(ContextMenuDemo1.this, String.format("我是页面上第 1 个按钮的上下文菜单,选中项为 id:%d, title:%s", item.getItemId(), item.getTitle()), Toast.LENGTH_SHORT).show();
// 如果 item 数据来自 xml 的话,则可以通过此方式来判断用户点击的是哪个 item
if (item.getItemId() == mCurrentMenu.getItem(1).getItemId()) {
}
}
else if (mCurrentViewId == R.id.button2) {
Toast.makeText(ContextMenuDemo1.this, String.format("我是页面上第 2 个按钮的上下文菜单,选中项为 id:%d, title:%s", item.getItemId(), item.getTitle()), Toast.LENGTH_SHORT).show();
}
return true;
}
}
/layout/activity_view_flyout_contextmenudemo1.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<Button
android:id="@+id/button1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textAllCaps="false"
android:text="弹出一个 ContextMenu(通过 xml 构造选项数据)" />
<Button
android:id="@+id/button2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textAllCaps="false"
android:text="弹出一个 ContextMenu(通过 java 构造选项数据)" />
</LinearLayout>
/menu/menu_view_flyout_contextmenudemo1.xml
<?xml version="1.0" encoding="utf-8"?>
<!--
用于构造 ContextMenu 的选项数据,参见 view/flyout/ContextMenuDemo1.java
-->
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<item android:id="@+id/menu0" android:title="menu 0">
<menu>
<group>
<item android:id="@+id/menu0_0" android:title="menu 0_0"/>
<item android:id="@+id/menu0_1" android:title="menu 0_1"/>
<item android:id="@+id/menu0_2" android:title="menu 0_2"/>
</group>
</menu>
</item>
<item android:id="@+id/menu1" android:title="menu 1"/>
<item android:id="@+id/menu2" android:title="menu 2" android:enabled="false"/>
</menu>
项目地址 https://github.com/webabcd/AndroidDemo
作者 webabcd
Android ContextMenu for View(非活动)
我正在使用以下方法将ContextMenu添加到我已构建的自定义视图中,但我想知道如何对该上下文菜单的新闻做出反应.
这不是一个活动所以我不能这样做:
@override
public boolean onoptionsItemSelected(MenuItem item) {
这是代码
private View.OnCreateContextMenuListener vC = new View.OnCreateContextMenuListener() {
@Override
public void onCreateContextMenu(ContextMenu arg0, View arg1,
ContextMenuInfo arg2) {
// Todo Auto-generated method stub
arg0.add(0, 0, 0, "Call");
arg0.add(0, 1, 0, "Map");
arg0.add(0, 2, 0, "Market");
}
};
更新:
这是我班级非常简化的版本.
public final class NewView extends View {
public NewView(Context context, AttributeSet attrs) {
super(context, attrs);
cntxt = context;
this.setLongClickable(true);
this.setonLongClickListener(vLong);
this.setonCreateContextMenuListener(vC);
}
private View.OnLongClickListener vLong = new View.OnLongClickListener() {
public boolean onLongClick(View view) {
showContextMenu();
return true;
}
};
private View.OnCreateContextMenuListener vC = new View.OnCreateContextMenuListener() {
@Override
public void onCreateContextMenu(ContextMenu arg0, View arg1,
ContextMenuInfo arg2) {
// Todo Auto-generated method stub
arg0.add(0, 0, 0, "Call");
arg0.add(0, 1, 0, "Map");
arg0.add(0, 2, 0, "Market");
}
};
}
解决方法:
使用item.getItemId()并根据getItemId()返回的数字创建开关和案例
像这样的东西.
@override
public boolean onoptionsItemSelected(MenuItem item) {
switch(item.getItemId())
{
case 1:
Log.i("FirsT ITEM: ", "CALL");
break;
case 2:
Log.i("2nd ITEM: ", "MAP");
break;
case 3:
Log.i("3rd ITEM: ", "Market");
break;
default:
}
}
我希望这是你对菜单项选择作出反应的意思.
android ContextMenu 上下文菜单示例
ch2_contextmenu.xml:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<TextView android:id="@+id/tv"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="这是一个上下文菜单ContextMenu的示例"/>
<EditText android:id="@+id/myEd"
android:layout_width="fill_parent"
android:layout_height="wrap_content"/>
</LinearLayout>
ContextMenuActivity.java :
package com.example.ch7;
import com.example.baseexample.R;
import android.app.Activity;
import android.os.Bundle;
import android.view.ContextMenu;
import android.view.MenuItem;
import android.view.View;
import android.view.ContextMenu.ContextMenuInfo;
import android.widget.EditText;
import android.widget.TextView;
public class ContextMenuActivity extends Activity {
private String tempStr;
private TextView tv;
private EditText myEd;
public void onCreate(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.ch7_contextmenu);
this.registerForContextMenu(findViewById(R.id.tv));
this.registerForContextMenu(findViewById(R.id.myEd));
}
public void onCreateContextMenu(ContextMenu menu,View v,ContextMenuInfo menuInfo){
menu.setHeaderIcon(R.drawable.ic_launcher);
if(v==findViewById(R.id.tv)){
menu.add(0,1,0,"复制");
menu.add(0,2,0,"剪切");
menu.add(0,3,0,"删除");
}
if(v==findViewById(R.id.myEd)){
menu.add(0,4,0,"粘贴");
menu.add(0,5,0,"删除");
}
}
public boolean onContextItemSelected(MenuItem item){
tv = (TextView)findViewById(R.id.tv);
myEd = (EditText)findViewById(R.id.myEd);
switch(item.getItemId()){
case 1:
tempStr = tv.getText().toString();
break;
case 2:
tempStr = tv.getText().toString();
tv.setText("");
break;
case 3:
tv.setText("");
break;
case 4:
myEd.setText(tempStr);
break;
case 5:
myEd.setText("");
break;
}
return true;
}
}
Android ContextMenu和Listview配合使用
@Override
protected void onResume() {
// TODO Auto-generated method stub
ListView listView = (ListView) findViewById(R.id.listView1);
adapter= new ArrayAdapter<String>(
getApplicationContext(), android.R.layout.simple_list_item_1,
getResources().getStringArray(R.array.mylistitem));
listView.setAdapter(adapter);
registerForContextMenu(listView); //注册listview的ContextMenu
super.onResume();
}
@Override
public boolean onContextItemSelected(MenuItem item) {
// TODO Auto-generated method stub
AdapterContextMenuInfo menuInfo = (AdapterContextMenuInfo)item.getMenuInfo(); //获得AdapterContextMenuInfo,以此来获得选择的listview项目
Toast.makeText(getApplicationContext(), adapter.getItem(menuInfo.position)+"", 0).show();
return super.onContextItemSelected(item);
}
@Override
public void onCreateContextMenu(ContextMenu menu, View v,
ContextMenuInfo menuInfo) {
// TODO Auto-generated method stub
menu.setHeaderTitle("Context Menu");
menu.add(0, v.getId(), 0, "Action 1");
menu.add(0, v.getId(), 0, "Action 2");
super.onCreateContextMenu(menu, v, menuInfo);
}
android – onCreateContextMenu使用ContextMenuInfo的null值调用
我正在尝试使用ContextMenu.
我已经使用SimpleCursorAdapter为一个简单的ListActivity成功完成了这个.
接下来我想用CursorAdapter替换SimpleCursorAdapter但仍然保留ContextMenu行为,所以我添加了两个强制覆盖函数bindView和newView
public View newView(Context context, Cursor cursor, ViewGroup parent) {
View view = mLayoutInflater.inflate(R.layout.check_row, parent, false);
registerForContextMenu(view);
return view;
}
请注意registerForContextMenu,它替换了ListActivity的onCreate方法中的registerForContextMenu(getListView()).我发现有必要调用onCreateContextMenu(…)
所有这些都可行(使用预期的小部件创建的行,对它们的回调等工作等).除了提供给onCreateContextMenu(…)的ContextMenuInfo参数现在为null之外的所有内容 – 停止我访问rowId.
还有其他技巧要做 – 也许是在CursorAdapter的bindView(…)方法中?
解决方法:
我正在回答这个问题 – 但我会指出’commonsware.com’提供了线索和方向,见上文.
问题
– 在行布局中使用CheckBox会影响上下文菜单的使用
– 我相信CheckedTextView是用于多选的,它不适合初始化已检查状态.
我采用的解决方案如下
1.使用CheckedTextView
2.从CursorAdapter扩展到bindView(…)期间初始化检查状态
注意:这必须管理显示正确的图标
3.在onListItemClick(…)中管理CheckedTextView的状态并将其记录在dBase中,不要忘记更新光标.
今天关于一手遮天 Android - view和弹出类: ContextMenu 基础的介绍到此结束,谢谢您的阅读,有关Android ContextMenu for View(非活动)、android ContextMenu 上下文菜单示例、Android ContextMenu和Listview配合使用、android – onCreateContextMenu使用ContextMenuInfo的null值调用等更多相关知识的信息可以在本站进行查询。
本文标签: