对于想了解一手遮天Android-view的读者,本文将提供新的信息,我们将详细介绍弹出类:ContextMenu样式,并且为您提供关于AndroidContextMenuforView(非活动)、a
对于想了解一手遮天 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/ContextMenuDemo2.java
/**
* ContextMenu - 上下文菜单(长按 view 弹出的菜单)
*
* 本例会演示如何自定义 ContextMenu 的样式
* 需要通过 activity 的主题来指定 ContextMenu 的样式,参见 res/values/styles.xml 中的 MyTheme_MyContextMenuStyle
*
* 注:如果觉得 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.View;
import android.widget.Button;
import android.widget.Toast;
import com.webabcd.androiddemo.R;
public class ContextMenuDemo2 extends AppCompatActivity {
private Button mButton1;
// 用于保存当前显示的上下文菜单数据
private ContextMenu mCurrentMenu;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// 指定 activity 的主题,用于修改 ContextMenu 的样式
setTheme(R.style.MyTheme_MyContextMenuStyle);
setContentView(R.layout.activity_view_flyout_contextmenudemo2);
mButton1 = findViewById(R.id.button1);
sample();
}
private void sample() {
registerForContextMenu(mButton1);
mButton1.setonClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// showContextMenu() - 手动显示上下文菜单
v.showContextMenu();
}
});
}
@Override
public void onCreateContextMenu(ContextMenu menu, View v, ContextMenu.ContextMenuInfo menuInfo) {
mCurrentMenu = menu;
new MenuInflater(this).inflate(R.menu.menu_view_flyout_contextmenudemo2, menu);
super.onCreateContextMenu(menu, v, menuInfo);
}
@Override
public boolean onContextItemSelected(MenuItem item) {
Toast.makeText(ContextMenuDemo2.this, String.format("id:%d, title:%s", item.getItemId(), item.getTitle()), Toast.LENGTH_SHORT).show();
// 如果 item 数据来自 xml 的话,则可以通过此方式来判断用户点击的是哪个 item
if (item.getItemId() == mCurrentMenu.getItem(1).getItemId()) {
}
return true;
}
}
/layout/activity_view_flyout_contextmenudemo2.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" />
</LinearLayout>
/menu/menu_view_flyout_contextmenudemo2.xml
<?xml version="1.0" encoding="utf-8"?>
<!--
用于构造 ContextMenu 的选项数据,参见 view/flyout/ContextMenuDemo2.java
-->
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<item android:id="@+id/item1" android:title="菜单 1" />
<item android:id="@+id/item2" android:title="菜单 2" />
<item android:id="@+id/item3" android:title="菜单 3" />
</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值调用的相关信息,请在本站查询。
本文标签: