我正在编写我的第一个 Android 应用程序。我有三个活动:BaseballCardList、BaseballCardDetails 和 FilterBaseballCards。BaseballCardList 作为主 Activity 加载。它有一个菜单,其中包含两个选项来显示其他两个活动之一。BaseballCardDetails 加载得很好。但是,当我尝试加载 FilterBaseballCards 时,我收到“不幸的是,Android 版 BBCT 已停止”。错误信息。我在 Android 模拟器中运行我的应用程序。这是相关的代码:
资源/布局/card_list.xml:
<?xml version="1.0" encoding="utf-8"?>
<ListView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/card_list"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
/>
资源/布局/filter_cards.xml:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
>
<TextView android:text="@string/filter_by_label" />
<RadioGroup android:id="@+id/filter_by">
<RadioButton android:id="@+id/year"
android:text="@string/year_radio_button"
/>
<RadioButton android:id="@+id/number"
android:text="@string/number_radio_button"
/>
<RadioButton android:id="@+id/year_and_number"
android:text="@string/year_and_number_radio_button"
/>
<RadioButton android:id="@+id/player_name"
android:text="@string/player_name_radio_button"
/>
</RadioGroup>
<Button android:id="@+id/ok"
android:text="@string/ok_button"
/>
<Button android:id="@+id/cancel"
android:text="@string/cancel_button"
/>
</LinearLayout>
棒球卡列表.java:
package bbct.android;
import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.util.Log;
import android.view.Menu;
import android.view.MenuInflater;
import android.view.MenuItem;
public class BaseballCardList extends Activity {
private static final String DEBUG_TAG = "BaseballCardList";
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.card_list);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
new MenuInflater(this).inflate(R.menu.option, menu);
return super.onCreateOptionsMenu(menu);
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case R.id.add:
Log.d(DEBUG_TAG, "Starting BaseballCardDetails");
this.startActivity(new Intent(this, BaseballCardDetails.class));
return true;
case R.id.filter:
Log.d(DEBUG_TAG, "Starting FilterBaseballCards");
this.startActivity(new Intent(this, FilterBaseballCards.class));
return true;
}
return super.onOptionsItemSelected(item);
}
}
FilterBaseballCards.java:
package bbct.android;
import android.app.Activity;
import android.os.Bundle;
public class FilterBaseballCards extends Activity{
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.filter_cards);
}
}
AndroidManifest.xml:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="bbct.android"
android:versionCode="1"
android:versionName="1.0">
<application android:label="@string/app_name" android:icon="@drawable/ic_launcher">
<activity android:name=".BaseballCardList"
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=".BaseballCardDetails" />
<activity android:name=".FilterBaseballCards" />
</application>
</manifest>
BaseballCardDetails.java 与 FilterBaseballCards.java 几乎相同,所以我不会发布它。
为什么我会收到此错误消息?更重要的是,我如何自己去追踪问题?我使用的是 Android 命令行工具,而不是 Eclipse。我开始添加一些日志消息,但我不知道如何查看可能有助于我追踪问题根源的日志输出。
更新:
我将setContentView()
FilterBaseballCards 中setContentView(R.layout.card_details);
的更改为,并且card_details
视图加载得很好。这将问题缩小到我的filter_cards.xml
文件。
另一个更新:
我简化filter_cards.xml
为:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
>
<TextView android:text="@string/filter_by_label" />
</LinearLayout>
并继续得到与以前相同的错误。