簡體   English   中英

單擊開始按鈕時,Android應用程序崩潰

[英]Android App Crashes When Start Button is Clicked

我正在嘗試在android中開發游戲,但是我還算是新手! 無論如何,我的游戲包含兩個活動(1.主菜單2.游戲)。 游戲從主菜單活動開始,當用戶單擊ID =(button2)的按鈕時,它應該啟動游戲的第二個活動:這是我MainMenu的.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>

到目前為止,他是該活動中的代碼:

package com.example.user.catchthefly;

import android.support.v7.app.ActionBarActivity; 
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.content.Intent;
import android.widget.ImageView;
import android.graphics.Color;
import static android.graphics.Color.*;

public class MainMenu extends ActionBarActivity {

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main_menu);
    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);
        }
    });
    btn1.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {

            Intent intent = new Intent(MainMenu.this, MainGame.class);
            MainMenu.this.startActivity(intent);
            finish();
        }
    });
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.main_menu, menu);
    return true;
}

@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.action_settings) {
        return true;
    }
    return super.onOptionsItemSelected(item);
}
}

在下面,我提供了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)

問題是,當我啟動程序時一切正常,但是當我單擊“開始游戲”按鈕(ID為(Button2))時,游戲在模擬器中崩潰了……我花了數小時試圖找出問題所在,但我似乎無法發現問題,因此歡迎任何幫助,謝謝!!!

解決方案:我已經在onCreate方法上方的MainGame.class中啟動了按鈕,布局,文本視圖,圖像視圖,這就是程序崩潰的原因,謝謝您的回答:)

您正在使用

btn2.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View view) {

        finish();
        System.exit(0);
    }
});

在這里finish(); 什么都沒有,但是您正在嘗試關閉當前活動,而System.exit(0):什么也沒有,但是您正在退出應用程序。

並將btn1代碼更改如下:

btn1.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View view) {

        Intent intent = new Intent(MainMenu.this, MainGame.class);
        startActivity(intent);
        finish();

    }
});

更改此代碼...。

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

我認為MainGame代碼還有其他問題,明智的做法是將您的日志貓發布到過濾器錯誤中。 但是我建議檢查MainGame類的代碼

在您的代碼中,調用System.exit(0) ,這將導致VM停止運行,並以給定的退出狀態退出程序。 這里拍攝 換句話說,這將關閉您的應用程序。 您試圖做的是僅關閉通過調用finish()的活動,您可以在此處查看其用途和描述。

同樣,在點擊代碼的按鈕2中,您沒有啟動任何活動。 要開始活動,只需像在按鈕1代碼中那樣使用fromActivity和toActivity添加該行即可。 然后使用startActivity(intent)啟動它。

您的代碼應該像這樣...

btn2.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View view) {

        Intent intent = new Intent(MainMenu.this, MainGame.class);
        startActivity(intent);
        finish();
    }

我不確定您的第二個按鈕打算做什么,但是不確定MainMenu是否是您的主要活動,因為您已經在其中,因此不需要使用startActivity()啟動它。

另外,按鈕名稱應代表其用途,以便您輕松閱讀代碼。 使用goToGamegoToMainMenu將使人們更容易跟蹤。

Caused by: java.lang.NullPointerException
  at android.app.Activity.findViewById(Activity.java:1839)
  at com.example.user.catchthefly.MainGame.<init>(MainGame.java:25)

MainGame ,初始化成員變量時調用findViewById()太早。

setContentView()之后將findViewById()移動到onCreate() setContentView()

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM