main.xml で定義されている listView にオブジェクトのリストを表示させようとしています。私のアクティビティが ListActivity で拡張され、getListView() を使用した場合、これはうまくいきました。ただし、通常のアクティビティから拡張し、次のようにカスタム アダプターを R.id.list にプラグインしたいと考えています。
ListView lv = (ListView) findViewById(R.id.list);
lv.setTextFilterEnabled(true);
lv.setAdapter(new MyCustomAdapter(this, R.layout.custom_list, nameResults));
ここで、custom_list は行を定義する xml ファイルです。私のデバッガーは、setAdapter 部分に到達するとすぐにおかしくなり、奇妙なファイルに向かい、最終的に NullPointerException を返します。
私のカスタムアダプターところで:
public class MyCustomAdapter extends ArrayAdapter<String> {
private String[] nameResults;
public MyCustomAdapter(Context context, int textViewResourceId, String[] names) {
super(context, textViewResourceId, names);
nameResults = names;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
LayoutInflater inflater=getLayoutInflater();
View row=inflater.inflate(R.layout.custom_list, parent, false);
TextView label=(TextView)row.findViewById(R.id.Name);
label.setText(nameResults[position]);
TextView descr=(TextView)row.findViewById(R.id.Description);
descr.setText(linkedResults.get(nameResults[position]));
return row;
}
}
動作を取り戻す方法はありますか?前/次のページ構造のためにその上にいくつかのボタンを取得できるように変更しただけです。つまり、setContentView(R.layout.main); が必要です。(右? :P 。このリンクを使用してリストビューを作成しました: Custom listview with adapter .
スタックトレース:
07-03 12:18:02.936: ERROR/AndroidRuntime(2747): Uncaught handler: thread main exiting due to uncaught exception
07-03 12:18:03.026: ERROR/AndroidRuntime(2747): java.lang.NullPointerException
07-03 12:18:03.026: ERROR/AndroidRuntime(2747): at com.rvthof.ShowPage.buildPage(ShowPage.java:102)
07-03 12:18:03.026: ERROR/AndroidRuntime(2747): at com.rvthof.ShowPage.access$0(ShowPage.java:78)
07-03 12:18:03.026: ERROR/AndroidRuntime(2747): at com.rvthof.ShowPage$1.run(ShowPage.java:74)
07-03 12:18:03.026: ERROR/AndroidRuntime(2747): at android.os.Handler.handleCallback(Handler.java:587)
07-03 12:18:03.026: ERROR/AndroidRuntime(2747): at android.os.Handler.dispatchMessage(Handler.java:92)
07-03 12:18:03.026: ERROR/AndroidRuntime(2747): at android.os.Looper.loop(Looper.java:123)
07-03 12:18:03.026: ERROR/AndroidRuntime(2747): at android.app.ActivityThread.main(ActivityThread.java:4363)
07-03 12:18:03.026: ERROR/AndroidRuntime(2747): at java.lang.reflect.Method.invokeNative(Native Method)
07-03 12:18:03.026: ERROR/AndroidRuntime(2747): at java.lang.reflect.Method.invoke(Method.java:521)
07-03 12:18:03.026: ERROR/AndroidRuntime(2747): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
07-03 12:18:03.026: ERROR/AndroidRuntime(2747): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
07-03 12:18:03.026: ERROR/AndroidRuntime(2747): at
dalvik.system.NativeStart.main(ネイティブメソッド)