单击开始按钮时Android应用程序崩溃

单击开始按钮时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

我正在尝试用android开发一款游戏,不过我还是有点新手!无论如何,我的游戏包括两个活动(1.主菜单2.游戏)。游戏从主菜单活动开始,当用户单击ID=(button2)的按钮时,应启动游戏的第二个活动: 以下是我的主菜单的.xml代码:

<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)