Я звоню из одного класса в другой класс. Я могу устанавливать значения и получать значения при создании объекта (см. Журнал), но существует множество методов, которые выдают исключение (см. Также журнал). Например, поджаривание чего-нибудь. Если я помещаю код в тост в оригинальном классе, он работает, если я пытаюсь вызвать его, он не работает. В моем коде ниже эти вещи, которые не работают, закомментированы (// code...
).
Вот главный класс:
public class Main extends Activity {
private MyMenu myMenu;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
myMenu = new MyMenu ();
myMenu.setMyMenu (3, "some text");
int number = myMenu.getMyMenuNumber();
String text = myMenu.getMyMenuString();
Log.d("LOG", "number is " + number + " and text is '" + text + "'.");
try {
Log.d ("LOG", "startMain error");
//myMenu.startMain();
startActivity(new Intent (this, Page1.class));
} catch (NullPointerException e) {
e.printStackTrace();
}
try {
Log.d ("LOG", "putToast error");
//myMenu.putToast();
Toast.makeText(
this,
"This is a toast",
Toast.LENGTH_LONG)
.show();
} catch (NullPointerException e) {
e.printStackTrace();
}
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
try {
Log.d ("LOG", "inflateMenu error");
//myMenu.inflateMenu(menu);
getMenuInflater().inflate(R.menu.menu, menu);
} catch (NullPointerException e) {
e.printStackTrace();
}
return super.onCreateOptionsMenu(menu);
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
try {
Log.d ("LOG", "isOptionsButtonClicked error");
//myMenu.isOptionsButtonClicked(item);
switch (item.getItemId()) {
case R.id.feedback:
startActivity(new Intent (this, Page1.class));
break;
case R.id.more_information:
startActivity(new Intent (this, Page1.class));
break;
}
} catch (NullPointerException e) {
e.printStackTrace();
}
return super.onOptionsItemSelected(item);
}
}
и это MyMenu.class:
public class MyMenu extends Activity {
int number;
String text;
public MyMenu() {
}
public void setMyMenu (int number, String text) {
this.number = number;
this.text = text;
}
public int getMyMenuNumber () {
return number;
}
public String getMyMenuString () {
return text;
}
public void startMain () {
startActivity(new Intent (this, Page1.class));
}
public void inflateMenu (Menu menu) {
getMenuInflater().inflate(R.menu.menu, menu);
}
public void putToast () {
Toast.makeText(
this,
"This is a toast",
Toast.LENGTH_LONG)
.show();
}
public void isOptionsButtonClicked (MenuItem item) {
switch (item.getItemId()) {
case R.id.feedback:
startActivity(new Intent (this, Page1.class));
break;
case R.id.more_information:
startActivity(new Intent (this, Page1.class));
break;
}
}
}
Еще раз подчеркну, что все в Main.class работает отлично, но вызов других классов не работает.
UPDATE
Вот части Log / StackTrace:
05-15 08:13:13.502: DEBUG/LOG(546): inflateMenu error
05-15 08:13:13.513: WARN/System.err(546): java.lang.NullPointerException
05-15 08:13:13.522: WARN/System.err(546): at android.content.ContextWrapper.getResources(ContextWrapper.java:80)
05-15 08:13:13.522: WARN/System.err(546): at android.view.MenuInflater.inflate(MenuInflater.java:77)
05-15 08:13:13.522: WARN/System.err(546): at com.test.MyMenu.inflateMenu(MyMenu.java:34)
05-15 08:13:13.533: WARN/System.err(546): at com.test.Main.onCreateOptionsMenu(Main.java:52)
05-15 08:13:13.542: WARN/System.err(546): at android.app.Activity.onCreatePanelMenu(Activity.java:2123)
05-15 08:13:13.542: WARN/System.err(546): at com.android.internal.policy.impl.PhoneWindow.preparePanel(PhoneWindow.java:305)
05-15 08:13:13.542: WARN/System.err(546): at com.android.internal.policy.impl.PhoneWindow.onKeyDownPanel(PhoneWindow.java:550)
05-15 08:13:13.582: WARN/System.err(546): at com.android.internal.policy.impl.PhoneWindow.onKeyDown(PhoneWindow.java:1192)
05-15 08:13:13.582: WARN/System.err(546): at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchKeyEvent(PhoneWindow.java:1636)
05-15 08:13:13.582: WARN/System.err(546): at android.view.ViewRoot.deliverKeyEventToViewHierarchy(ViewRoot.java:2368)
05-15 08:13:13.582: WARN/System.err(546): at android.view.ViewRoot.handleFinishedEvent(ViewRoot.java:2338)
05-15 08:13:13.582: WARN/System.err(546): at android.view.ViewRoot.handleMessage(ViewRoot.java:1641)
05-15 08:13:13.582: WARN/System.err(546): at android.os.Handler.dispatchMessage(Handler.java:99)
05-15 08:13:13.592: WARN/System.err(546): at android.os.Looper.loop(Looper.java:123)
05-15 08:13:13.592: WARN/System.err(546): at android.app.ActivityThread.main(ActivityThread.java:4363)
05-15 08:13:13.602: WARN/System.err(546): at java.lang.reflect.Method.invokeNative(Native Method)
05-15 08:13:13.602: WARN/System.err(546): at java.lang.reflect.Method.invoke(Method.java:521)
05-15 08:13:13.602: WARN/System.err(546): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
05-15 08:13:13.602: WARN/System.err(546): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
05-15 08:13:13.602: WARN/System.err(546): at dalvik.system.NativeStart.main(Native Method)
и
05-15 08:13:03.592: DEBUG/LOG(546): putToast error
05-15 08:13:03.612: WARN/System.err(546): java.lang.NullPointerException
05-15 08:13:03.621: WARN/System.err(546): at android.content.ContextWrapper.getResources(ContextWrapper.java:80)
05-15 08:13:03.633: WARN/System.err(546): at android.widget.Toast.<init>(Toast.java:89)
05-15 08:13:03.633: WARN/System.err(546): at android.widget.Toast.makeText(Toast.java:231)
05-15 08:13:03.633: WARN/System.err(546): at com.test.MyMenu.putToast(MyMenu.java:37)
05-15 08:13:03.641: WARN/System.err(546): at com.test.Main.onCreate(Main.java:37)
05-15 08:13:03.641: WARN/System.err(546): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
05-15 08:13:03.652: WARN/System.err(546): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2459)
05-15 08:13:03.652: WARN/System.err(546): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2512)
05-15 08:13:03.652: WARN/System.err(546): at android.app.ActivityThread.access$2200(ActivityThread.java:119)
05-15 08:13:03.661: WARN/System.err(546): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1863)
05-15 08:13:03.661: WARN/System.err(546): at android.os.Handler.dispatchMessage(Handler.java:99)
05-15 08:13:03.671: WARN/System.err(546): at android.os.Looper.loop(Looper.java:123)
05-15 08:13:03.671: WARN/System.err(546): at android.app.ActivityThread.main(ActivityThread.java:4363)
05-15 08:13:03.671: WARN/System.err(546): at java.lang.reflect.Method.invokeNative(Native Method)
05-15 08:13:03.683: WARN/System.err(546): at java.lang.reflect.Method.invoke(Method.java:521)
05-15 08:13:03.683: WARN/System.err(546): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
05-15 08:13:03.691: WARN/System.err(546): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
05-15 08:13:03.691: WARN/System.err(546): at dalvik.system.NativeStart.main(Native Method)
надеюсь, это поможет!
UDATE 2
Вот запрошенный Page1.class. Но опять же все работает нормально, когда я не использую MyMenu.class.
public class Page1 extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.page1);
}
}
Кроме того, вы можете скачать проект Android с Microsoft Live / Windows Live Skydrive:
http://cid -f45ce92851885387.office.live.com / browse.aspx / Stackoverflow