我有一個主頁活動,我從一個例子中得到,它工作正常。現在我試圖讓它有一個讓應用程序進入下一個屏幕的按鈕。Android - 如何構造新的Activity類?
所以我添加了第二個活動應用程序清單:
<activity
android:name=".AddProblemActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
但我不知道是否應該有以下兩行:
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
看來,主要是說,有應該是一個main()函數。但是,這不是隻應該在主頁上存在嗎?
以下是完整的堆棧跟蹤:
02-20 10:17:04.408: D/gralloc_goldfish(646): Emulator without GPU emulation detected.
02-20 10:18:58.655: D/AndroidRuntime(646): Shutting down VM
02-20 10:18:58.665: W/dalvikvm(646): threadid=1: thread exiting with uncaught exception (group=0x409c01f8)
02-20 10:18:58.745: E/AndroidRuntime(646): FATAL EXCEPTION: main
02-20 10:18:58.745: E/AndroidRuntime(646): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.problemio/com.problemio.AddProblemActivity}: java.lang.NullPointerException
02-20 10:18:58.745: E/AndroidRuntime(646): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1956)
02-20 10:18:58.745: E/AndroidRuntime(646): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1981)
02-20 10:18:58.745: E/AndroidRuntime(646): at android.app.ActivityThread.access$600(ActivityThread.java:123)
02-20 10:18:58.745: E/AndroidRuntime(646): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1147)
02-20 10:18:58.745: E/AndroidRuntime(646): at android.os.Handler.dispatchMessage(Handler.java:99)
02-20 10:18:58.745: E/AndroidRuntime(646): at android.os.Looper.loop(Looper.java:137)
02-20 10:18:58.745: E/AndroidRuntime(646): at android.app.ActivityThread.main(ActivityThread.java:4424)
02-20 10:18:58.745: E/AndroidRuntime(646): at java.lang.reflect.Method.invokeNative(Native Method)
02-20 10:18:58.745: E/AndroidRuntime(646): at java.lang.reflect.Method.invoke(Method.java:511)
02-20 10:18:58.745: E/AndroidRuntime(646): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
02-20 10:18:58.745: E/AndroidRuntime(646): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
02-20 10:18:58.745: E/AndroidRuntime(646): at dalvik.system.NativeStart.main(Native Method)
02-20 10:18:58.745: E/AndroidRuntime(646): Caused by: java.lang.NullPointerException
02-20 10:18:58.745: E/AndroidRuntime(646): at com.problemio.AddProblemActivity.onCreate(AddProblemActivity.java:28)
02-20 10:18:58.745: E/AndroidRuntime(646): at android.app.Activity.performCreate(Activity.java:4465)
02-20 10:18:58.745: E/AndroidRuntime(646): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)
02-20 10:18:58.745: E/AndroidRuntime(646): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1920)
02-20 10:18:58.745: E/AndroidRuntime(646): ... 11 more
這是AddProblemActivity我的onCreate的部分原因似乎錯誤:
final EditText problemName = (EditText) findViewById(R.id.problem_name);
String name = problemName.getText().toString(); // THIS LINE
這裏是我的xml的是problem_name從佈局XML:
<EditText
android:id="@+id/problem_name"
android:layout_height="wrap_content"
android:hint="@string/problem_name"
android:inputType="textPersonName"
android:layout_width="fill_parent">
</EditText>
謝謝, 亞歷克斯
@Sabastian謝謝!如果你想有一個意圖呢?關於第二個活動? :) – Genadinik 2012-02-20 18:05:02
不客氣。我很抱歉,但我不太明白你的問題。您可以有多個活動的意向過濾器。如果你需要幫助找出崩潰發生的原因,你應該發佈完整的堆棧跟蹤。 – 2012-02-20 18:09:37
我只是將完整的堆棧跟蹤添加到我原來的問題。此外,我將我的清單更改爲您在答案中給出的片段。 – Genadinik 2012-02-20 18:21:01