[英]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()
啟動它。
另外,按鈕名稱應代表其用途,以便您輕松閱讀代碼。 使用goToGame
或goToMainMenu
將使人們更容易跟蹤。
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.