单击开始按钮时Android应用程序崩溃
我正在尝试用android开发一款游戏,不过我还是有点新手!无论如何,我的游戏包括两个活动(1.主菜单2.游戏)。游戏从主菜单活动开始,当用户单击ID=(button2)的按钮时,应启动游戏的第二个活动: 以下是我的主菜单的.xml代码:单击开始按钮时Android应用程序崩溃,android,button,android-activity,crash,Android,Button,Android Activity,Crash,我正在尝试用android开发一款游戏,不过我还是有点新手!无论如何,我的游戏包括两个活动(1.主菜单2.游戏)。游戏从主菜单活动开始,当用户单击ID=(button2)的按钮时,应启动游戏的第二个活动: 以下是我的主菜单的.xml代码: <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" andro
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:paddingBottom="@dimen/activity_vertical_margin"
tools:context=".MainMenu"
android:background="@drawable/starting_page">
<Button
android:layout_width="400dp"
android:layout_height="45dp"
android:text="Exit Game"
android:id="@+id/button"
android:background="#f6d89d00"
android:textSize="30sp"
android:layout_alignParentBottom="true"
android:layout_alignParentLeft="true"
android:layout_alignParentStart="true"
android:layout_marginBottom="39dp" />
<Button
android:layout_width="400dp"
android:layout_height="45dp"
android:text="Start Game"
android:id="@+id/button2"
android:background="#f6d86d00"
android:textSize="30sp"
android:layout_above="@+id/button"
android:layout_alignParentLeft="true"
android:layout_alignParentStart="true"
android:clickable="true"
android:enabled="true"
android:visibility="visible"
android:focusableInTouchMode="true" />
<CheckBox
android:layout_width="100dp"
android:layout_height="wrap_content"
android:text="Sound"
android:id="@+id/checkBox"
android:textSize="20dp"
android:longClickable="false"
android:layout_alignParentBottom="true"
android:layout_alignRight="@+id/button"
android:layout_alignEnd="@+id/button"
android:enabled="true" />
</RelativeLayout>
下面我提供了AndroidManifest.xml,以防您需要使用它来总结错误:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.user.catchthefly" >
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<activity
android:name=".MainMenu"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity
android:name=".MainGame"
android:label="@string/app_name" >
</activity>
<activity
android:name=".ScorePage"
android:label="@string/app_name" >
</activity>
</application>
</manifest>
logcat
07-21 13:50:53.828 811-811/com.example.user.catchthefly E/Trace﹕ error opening trace file: No such file or directory (2)
07-21 13:50:55.478 811-811/com.example.user.catchthefly D/dalvikvm﹕ GC_FOR_ALLOC freed 55K, 7% free 2564K/2740K, paused 36ms, total 39ms
07-21 13:50:55.588 811-811/com.example.user.catchthefly D/dalvikvm﹕ GC_FOR_ALLOC freed 2K, 6% free 2901K/3080K, paused 26ms, total 27ms
07-21 13:50:55.868 811-811/com.example.user.catchthefly D/libEGL﹕ loaded /system/lib/egl/libEGL_emulation.so
07-21 13:50:55.888 811-811/com.example.user.catchthefly D/﹕ HostConnection::get() New Host Connection established 0x2a154d08, tid 811
07-21 13:50:55.938 811-811/com.example.user.catchthefly D/libEGL﹕ loaded /system/lib/egl/libGLESv1_CM_emulation.so
07-21 13:50:55.979 811-811/com.example.user.catchthefly D/libEGL﹕ loaded /system/lib/egl/libGLESv2_emulation.so
07-21 13:50:56.308 811-811/com.example.user.catchthefly W/EGL_emulation﹕ eglSurfaceAttrib not implemented
07-21 13:50:56.328 811-811/com.example.user.catchthefly D/OpenGLRenderer﹕ Enabling debug mode 0
07-21 13:50:56.548 811-814/com.example.user.catchthefly D/dalvikvm﹕ GC_CONCURRENT freed 359K, 14% free 2937K/3416K, paused 6ms+46ms, total 117ms
07-21 13:51:49.189 811-811/com.example.user.catchthefly D/AndroidRuntime﹕ Shutting down VM
07-21 13:51:49.199 811-811/com.example.user.catchthefly W/dalvikvm﹕ threadid=1: thread exiting with uncaught exception (group=0x40a71930)
07-21 13:51:49.229 811-811/com.example.user.catchthefly E/AndroidRuntime﹕ FATAL EXCEPTION: main
java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.example.user.catchthefly/com.example.user.catchthefly.MainGame}: java.lang.NullPointerException
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2106)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
at android.app.ActivityThread.access$600(ActivityThread.java:141)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:5041)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.NullPointerException
at android.app.Activity.findViewById(Activity.java:1839)
at com.example.user.catchthefly.MainGame.<init>(MainGame.java:25)
at java.lang.Class.newInstanceImpl(Native Method)
at java.lang.Class.newInstance(Class.java:1319)
at android.app.Instrumentation.newActivity(Instrumentation.java:1054)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2097)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
at android.app.ActivityThread.access$600(ActivityThread.java:141)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:5041)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
at dalvik.system.NativeStart.main(Native Method)
07-21 13:50:53.828 811-811/com.example.user.catchthefly E/Trace﹕ 打开跟踪文件时出错:没有此类文件或目录(2)
07-21 13:50:55.478 811-811/com.example.user.catchoffly D/dalvikvm﹕ 释放55K,7%释放2564K/2740K,暂停36ms,总计39ms
07-21 13:50:55.588 811-811/com.example.user.catchoffly D/dalvikvm﹕ GC_FOR_ALLOC freed 2K,6%free 2901K/3080K,暂停26ms,总计27ms
07-21 13:50:55.868 811-811/com.example.user.catchthefly D/libEGL﹕ 加载的/system/lib/egl/libEGL_.so
07-21 13:50:55.888 811-811/com.example.user.catchthefly D/﹕ HostConnection::get()已建立新主机连接0x2a154d08,tid 811
07-21 13:50:55.938 811-811/com.example.user.catchthefly D/libEGL﹕ loaded/system/lib/egl/libGLESv1_CM_emulation.so
07-21 13:50:55.979 811-811/com.example.user.catchthefly D/libEGL﹕ loaded/system/lib/egl/libGLESv2_emulation.so
07-21 13:50:56.308 811-811/com.example.user.catchthefly W/EGL_仿真﹕ 未实现eglSurfaceAttrib
07-21 13:50:56.328 811-811/com.example.user.catchoffly D/opengl﹕ 正在启用调试模式0
07-21 13:50:56.548 811-814/com.example.user.catchoffly D/dalvikvm﹕ GC_并发释放359K,14%释放2937K/3416K,暂停6ms+46ms,总计117ms
07-21 13:51:49.189 811-811/com.example.user.catchthefly D/AndroidRuntime﹕ 关闭虚拟机
07-21 13:51:49.199 811-811/com.example.user.catchthefly W/dalvikvm﹕ threadid=1:线程以未捕获异常退出(组=0x40a71930)
07-21 13:51:49.229811-811/com.example.user.catchthefly E/AndroidRuntime﹕ 致命异常:主
java.lang.RuntimeException:无法实例化活动组件信息{com.example.user.catchthefly/com.example.user.catchthefly.MainGame}:java.lang.NullPointerException
在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2106)上
位于android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
在android.app.ActivityThread.access$600(ActivityThread.java:141)
在android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
位于android.os.Handler.dispatchMessage(Handler.java:99)
位于android.os.Looper.loop(Looper.java:137)
位于android.app.ActivityThread.main(ActivityThread.java:5041)
位于java.lang.reflect.Method.Invokenactive(本机方法)
位于java.lang.reflect.Method.invoke(Method.java:511)
在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)上
位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
在dalvik.system.NativeStart.main(本机方法)
原因:java.lang.NullPointerException
在android.app.Activity.findviewbyd(Activity.java:1839)上
位于com.example.user.catchthefly.MainGame(MainGame.java:25)
位于java.lang.Class.newInstanceImpl(本机方法)
位于java.lang.Class.newInstance(Class.java:1319)
位于android.app.Instrumentation.newActivity(Instrumentation.java:1054)
在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2097)上
位于android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
在android.app.ActivityThread.access$600(ActivityThread.java:141)
在android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
位于android.os.Handler.dispatchMessage(Handler.java:99)
位于android.os.Looper.loop(Looper.java:137)
位于android.app.ActivityThread.main(ActivityThread.java:5041)
位于java.lang.reflect.Method.Invokenactive(本机方法)
位于java.lang.reflect.Method.invoke(Method.java:511)
在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)上
位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
在dalvik.system.NativeStart.main(本机方法)
问题是,当我启动程序时,所有程序都正常运行,但当我单击按钮“开始游戏”(id为(Button2))时,游戏会在模拟器中崩溃。。。
我花了几个小时试图找出问题出在哪里,但我似乎无法发现问题所在
所以欢迎任何帮助
非常感谢
解决方案:
我在onCreate方法上面的main game.class中启动了按钮、布局、文本视图和图像视图,这就是程序崩溃的原因
谢谢您的回答:)更改此代码
btn1.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent intent = new Intent(MainMenu.this, MainGame.class);
MainMenu.this.startActivity(intent);
finish();
}
});
对此
btn1.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent intent = new Intent(MainMenu.this, MainGame.class);
startActivity(intent);
finish();
}
});
您可能希望更改两个按钮的id值:
final Button btn1 = (Button) findViewById(R.id.button2);
final Button btn2 = (Button) findViewById(R.id.button);
附带说明:您在此处告知要停止当前活动并退出应用程序:
btn2.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
finish();
System.exit(0);
}
});
您正在使用
btn2.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
finish();
System.exit(0);
}
});
这里finish()
什么都不是,但您正在尝试关闭当前活动和系统。退出(0):
什么都不是,但您正在退出应用程序
并将btn1代码更改为如下所示:
btn1.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent intent = new Intent(MainMenu.this, MainGame.class);
startActivity(intent);
finish();
}
});
我认为主游戏代码有一些问题,其他明智的张贴您的日志猫过滤器错误。
但是我建议您在您调用的代码
System.exit(0)
中检查MainGame类的代码,这会导致VM停止运行,并且程序以给定的出口退出
btn1.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent intent = new Intent(MainMenu.this, MainGame.class);
startActivity(intent);
finish();
}
});
btn2.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent intent = new Intent(MainMenu.this, MainGame.class);
startActivity(intent);
finish();
}
Caused by: java.lang.NullPointerException
at android.app.Activity.findViewById(Activity.java:1839)
at com.example.user.catchthefly.MainGame.<init>(MainGame.java:25)