简体   繁体   中英

Failed When onCreateOptionsMenu

I was newbie android programmer so I want make menu for my application, but have some thing error when I try to launching it to the AVD this is my code :

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.Menu;
public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.main_menu,menu);
        return super.onCreateOptionsMenu(menu);
    }
    }

This is my XML main

<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.simasjiwa.testingheadermenu.MainActivity">

This is the menu what I try to create:

  <?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto">
    <item android:icon="@mipmap/ic_launcher"
        android:title="clickhere"
        android:onClick="doAction"
        app:showAsAction="always"
        android:id="@+id/testing"></item>

</menu>

This is my logcat error:

FATAL EXCEPTION: main
                                                                           Process: com.simasjiwa.testingheadermenu, PID: 8322
                                                                           android.view.InflateException: Couldn't resolve menu item onClick handler doAction in class com.simasjiwa.testingheadermenu.MainActivity
                                                                               at android.support.v7.view.SupportMenuInflater$InflatedOnMenuItemClickListener.<init>(SupportMenuInflater.java:248)
                                                                               at android.support.v7.view.SupportMenuInflater$MenuState.setItem(SupportMenuInflater.java:448)
                                                                               at android.support.v7.view.SupportMenuInflater$MenuState.addItem(SupportMenuInflater.java:483)
                                                                               at android.support.v7.view.SupportMenuInflater.parseMenu(SupportMenuInflater.java:200)
                                                                               at android.support.v7.view.SupportMenuInflater.inflate(SupportMenuInflater.java:122)
                                                                               at com.simasjiwa.testingheadermenu.MainActivity.onCreateOptionsMenu(MainActivity.java:17)
                                                                               at android.app.Activity.onCreatePanelMenu(Activity.java:2538)
                                                                               at android.support.v4.app.FragmentActivity.onCreatePanelMenu(FragmentActivity.java:362)
                                                                               at android.support.v7.view.WindowCallbackWrapper.onCreatePanelMenu(WindowCallbackWrapper.java:98)
                                                                               at android.support.v7.app.AppCompatDelegateImplBase$AppCompatWindowCallbackBase.onCreatePanelMenu(AppCompatDelegateImplBase.java:335)
                                                                               at android.support.v7.app.AppCompatDelegateImplV9.preparePanel(AppCompatDelegateImplV9.java:1368)
                                                                               at android.support.v7.app.AppCompatDelegateImplV9.doInvalidatePanelMenu(AppCompatDelegateImplV9.java:1648)
                                                                               at android.support.v7.app.AppCompatDelegateImplV9$1.run(AppCompatDelegateImplV9.java:140)
                                                                               at android.os.Handler.handleCallback(Handler.java:733)
                                                                               at android.os.Handler.dispatchMessage(Handler.java:95)
                                                                               at android.os.Looper.loop(Looper.java:136)
                                                                               at android.app.ActivityThread.main(ActivityThread.java:5017)
                                                                               at java.lang.reflect.Method.invokeNative(Native Method)
                                                                               at java.lang.reflect.Method.invoke(Method.java:515)
                                                                               at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
                                                                               at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
                                                                               at dalvik.system.NativeStart.main(Native Method)
                                                                            Caused by: java.lang.NoSuchMethodException: doAction [interface android.view.MenuItem]
                                                                               at java.lang.Class.getConstructorOrMethod(Class.java:472)
                                                                               at java.lang.Class.getMethod(Class.java:857)
                                                                               at android.support.v7.view.SupportMenuInflater$InflatedOnMenuItemClickListener.<init>(SupportMenuInflater.java:244)
                                                                               at android.support.v7.view.SupportMenuInflater$MenuState.setItem(SupportMenuInflater.java:448) 
                                                                               at android.support.v7.view.SupportMenuInflater$MenuState.addItem(SupportMenuInflater.java:483) 
                                                                               at android.support.v7.view.SupportMenuInflater.parseMenu(SupportMenuInflater.java:200) 
                                                                               at android.support.v7.view.SupportMenuInflater.inflate(SupportMenuInflater.java:122) 
                                                                               at com.simasjiwa.testingheadermenu.MainActivity.onCreateOptionsMenu(MainActivity.java:17) 
                                                                               at android.app.Activity.onCreatePanelMenu(Activity.java:2538) 
                                                                               at android.support.v4.app.FragmentActivity.onCreatePanelMenu(FragmentActivity.java:362) 
                                                                               at android.support.v7.view.WindowCallbackWrapper.onCreatePanelMenu(WindowCallbackWrapper.java:98) 
                                                                               at android.support.v7.app.AppCompatDelegateImplBase$AppCompatWindowCallbackBase.onCreatePanelMenu(AppCompatDelegateImplBase.java:335) 
                                                                               at android.support.v7.app.AppCompatDelegateImplV9.preparePanel(AppCompatDelegateImplV9.java:1368) 
                                                                               at android.support.v7.app.AppCompatDelegateImplV9.doInvalidatePanelMenu(AppCompatDelegateImplV9.java:1648) 
                                                                               at android.support.v7.app.AppCompatDelegateImplV9$1.run(AppCompatDelegateImplV9.java:140) 
                                                                               at android.os.Handler.handleCallback(Handler.java:733) 
                                                                               at android.os.Handler.dispatchMessage(Handler.java:95) 
                                                                               at android.os.Looper.loop(Looper.java:136) 
                                                                               at android.app.ActivityThread.main(ActivityThread.java:5017) 
                                                                               at java.lang.reflect.Method.invokeNative(Native Method) 
                                                                               at java.lang.reflect.Method.invoke(Method.java:515) 
                                                                               at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779) 
                                                                               at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595) 
                                                                               at dalvik.system.NativeStart.main(Native Method) 

my question is, why i can run to the AVD? is my code was wrong or something i forget to insert? Thank you before

There is no corresponding handler in your MainActivity against android:onClick="doAction" so you can add it

public class MainActivity extends AppCompatActivity {

    // fields
    // other methods
    public void doAction(MenuItem item){
       // perform your action here 
    }
}

Note : It supports API Level 11 or above otherwise use onOptionsItemSelected

android.view.InflateException : Couldn't resolve menu item onClick handler doAction in class com.simasjiwa.testingheadermenu.MainActivity

There is no doAction() method in your MainActivity.java file.

SOLUTION:

#. Remove attribute android:onClick="doAction" from <item> .

Update main_menu.xml as below:

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto">

    <item android:icon="@mipmap/ic_launcher"
        android:title="clickhere"
        app:showAsAction="always"
        android:id="@+id/testing">
    </item>
</menu>

#. Override onOptionsItemSelected() and do some operation when specific menu item get selected.

Update MainActivity.java as below:

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.Menu;
public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.main_menu,menu);
        return super.onCreateOptionsMenu(menu);
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        // Handle action bar item clicks here. The action bar will
        // automatically handle clicks on the Home/Up button, so long
        // as you specify a parent activity in AndroidManifest.xml.
        int id = item.getItemId();

        if (id == R.id.testing) {

            doAction();
            return true;
        }
        return super.onOptionsItemSelected(item);
    }

    public void doAction() {
        // Do something...
        Toast.makeText(getApplicationContext(), "Clicked!", Toast.LENGTH_SHORT).show();
    }
}

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM