Reputation: 163
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
Upvotes: 0
Views: 425
Reputation: 21736
android.view.InflateException
: Couldn't resolve menu item onClick handlerdoAction
in classcom.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();
}
}
Upvotes: 1
Reputation: 37404
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
Upvotes: 2