Java onContextItemSelected中奇怪的int比较错误

Java onContextItemSelected中奇怪的int比较错误,java,android,Java,Android,我在onContextItemSelected事件处理程序中遇到了一个奇怪的错误。这是密码- @Override public boolean onContextItemSelected(MenuItem item) { // Handle item selection int itemIntegerId = item.getItemId(); if(itemIntegerId == 0) { // Edit

我在onContextItemSelected事件处理程序中遇到了一个奇怪的错误。这是密码-

@Override
 public boolean onContextItemSelected(MenuItem item) {
     // Handle item selection
    int itemIntegerId = item.getItemId();
    if(itemIntegerId == 0)
    {           
        // Edit
        return true;            
    }
    else if(itemIntegerId == 1)
    {
        // Delete
        return true;
    }
    else 
    {
        return super.onContextItemSelected(item);
    }
 }
所有这些都放在ListActivity类中。事件按其应该的方式触发,但即使已选择id为0的项

    int itemIntegerId = item.getItemId();
    if(itemIntegerId == 0)
    {           
        // Edit
        return true;            
    }
正在失败

我花了半个多小时试图找到解决办法。任何帮助都将不胜感激。我附上了相关图片


嗯。。。为什么不使用R.id uu常量来标识上下文菜单项?每次添加新资源时,都会重新生成资源ID,因此实际值可能会更改。

如何判断它是否失败?如果只是调试器标记了方法的最后一次
返回
,那并不一定意味着该行实际被调用

将代码更改为

if(itemIntegerId == 0)
{           
    // Edit
    Log.d("sometag", "Edit");
    return true;            
}

查看是否记录了“编辑”——或者在
Log.d
行上设置断点,并检查是否命中它。

尝试以下示例代码以了解如何使用上下文菜单:

package com.test;

import android.app.Activity;
import android.os.Bundle;
import android.view.ContextMenu;
import android.view.ContextMenu.ContextMenuInfo;
import android.view.Menu;
import android.view.MenuItem;
import android.view.SubMenu;
import android.view.View;
import android.widget.TextView;
import android.widget.Toast;

public class MenuActivity extends Activity{

    private final static int MENU_PARAMETRE = 1;
    private final static int MENU_QUITTER = 2;
    private final static int SOUSMENU_VIDEO = 11;
    private final static int SOUSMENU_AUDIO = 12;
    private final static int MENU_CONTEXT_1 = 13;
    private final static int MENU_CONTEXT_2 = 14;


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.menu);
        TextView textView = (TextView)findViewById(R.id.textViewClick);
        registerForContextMenu(textView);
    }


    @Override
    public boolean onCreateOptionsMenu(Menu menu) {

        SubMenu sousMenu = menu.addSubMenu(0, MENU_PARAMETRE, Menu.NONE, "Paramètres");
        sousMenu.setIcon(R.drawable.image1);
        sousMenu.add(0, SOUSMENU_AUDIO, Menu.NONE, "Audio");
        sousMenu.add(0, SOUSMENU_VIDEO, Menu.NONE, "Video");

        menu.add(0, MENU_QUITTER, Menu.NONE, "Quitter");

        return true;
    }


    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        switch(item.getItemId()){

        case MENU_PARAMETRE:
            Toast.makeText(this, "Ouverture des paramètres", Toast.LENGTH_SHORT).show();
            return true;

        case SOUSMENU_AUDIO:
            Toast.makeText(this, "Ouverture des Audio", Toast.LENGTH_SHORT).show();
            return true;

        case SOUSMENU_VIDEO:
            Toast.makeText(this, "Ouverture des Video", Toast.LENGTH_SHORT).show();
            return true;

        case MENU_QUITTER:
            this.finish();
            return true;

        default: return true;
        }

    }

    //on créé un menu contextuel sur la textview
    @Override
    public void onCreateContextMenu(ContextMenu menu, View v, ContextMenuInfo menuInfo) {
        switch(v.getId()){
        case R.id.textViewClick:
            {
                menu.setHeaderTitle("Menu Contextuel");
                menu.setHeaderIcon(R.drawable.image1);
                menu.add(0, MENU_CONTEXT_1, 0, "Menu Contextuel 1");
                menu.add(0, MENU_CONTEXT_2, 0, "Menu Contextuel 2");
            }
            break;

        }
        super.onCreateContextMenu(menu, v, menuInfo);
    }

    //On ajoute les actions sur les items du menu contextuel.
    @Override
    public boolean onContextItemSelected(MenuItem item) {

        switch(item.getItemId()){

        case MENU_CONTEXT_1:{
            Toast.makeText(this, "Menu Contextuel 1 cliqué!", Toast.LENGTH_SHORT).show();
            break;
        }
        case MENU_CONTEXT_2:{
            Toast.makeText(this, "Menu Contextuel 2 cliqué!", Toast.LENGTH_SHORT).show();
            break;
        }
        }
        return super.onContextItemSelected(item);
    }
}
并加上:

<?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" android:gravity="center_vertical|center_horizontal">

    <TextView
        android:id="@+id/textViewClick"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:text="@string/hello" 
        android:textSize="30dip" 
        android:gravity="center_horizontal"/>


</LinearLayout>


item.getItemId()可能是原因,我们能看到一些来源吗?你能附上相关代码吗?我的意思是完整的活动代码和菜单xml,如果你正在使用的话。好吧,我尝试了你的建议,@Ridcully和@Jarvis的组合,我在类的顶部声明了常量,我正在比较我的id和它们。我还在
if
语句中添加了
Log.d
,看起来它们确实被调用了,但是为什么
return
语句没有运行呢?始终调用
else
中的return语句。如果记录了
Edit
,则可以确保以下
返回true也被执行。添加一个
Log.d(“sometag”,“callingsuper”)
返回super.onContextItemSelected(项目)之前
我跟你赌1000美元,不是所有的,
编辑
调用super
都是为同一个方法调用记录的。我不打算打赌,我两年赚那么多!我会尽量让你知道的。很抱歉我花了这么长时间才尝试,但你是对的。非常感谢。不客气。我也不止一次被Eclipse调试器的这种行为弄糊涂了。您能把注释转换成英语吗?