これを理解しようと何時間もかけて、非常に多くの質問、フォーラム、回答を読みました..しかし、それでもUIは更新されません.
私の最終的な目標は、ユーザーから検索語を取得し、JSON で応答する httprequest を PHP スクリプトに送信することです。これは問題なく機能するので、詳しくは説明しません。
私の問題は、これが完了した後にUIを更新することです。HTTP の結果を取得できますが、今のところ、すべての結果でリスナーを含むボタンなどの大きな変更を実装する前に、基本的な文字列で UI を更新しようとしています。今のところ、UI への単純な文字列の追加だけです。
onPreExecute() は文字列を UI に追加します。これは、以下に実装されているように、何らかの形で正常に機能します。
問題は onPostExecute にあります。私が言ったように、今のところ、テストする文字列だけです (最終的にはリストか何かになります)。まったく機能せず、常に例外がスローされます。
public class DisplaySearchActivity extends ListActivity {
ArrayList<String> listItems=new ArrayList<String>();
ArrayAdapter<String> adapter = null;
private class updateUI extends AsyncTask<String, Void, String>{
@Override
protected void onPreExecute() {
listItems.add("Retrieving Results...");
// This actually works just like that
}
@Override
protected String doInBackground(String... message) {
final List<HashMap<String,String>> blist = httpSearch.search(message[0]);
return "It has done";
}
@Override
protected void onPostExecute(String b){
Log.v("ok", "shane - "+ b);
listItems.add("Business: "+ b);
adapter.notifyDataSetChanged();
}
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_display_search);
final ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,android.R.layout.simple_list_item_1,listItems);
setListAdapter(adapter);
// final String message = getIntent().getStringExtra("input");
final String message = "third+level";
new updateUI().execute(message);
} // end onCreate
}
ここに例外があります
03-15 13:38:41.190: V/ok(15732): shane - It has done
03-15 13:38:41.190: D/AndroidRuntime(15732): Shutting down VM
03-15 13:38:41.190: W/dalvikvm(15732): threadid=1: thread exiting with uncaught exception (group=0x4142a2a0)
03-15 13:38:41.200: E/AndroidRuntime(15732): FATAL EXCEPTION: main
03-15 13:38:41.200: E/AndroidRuntime(15732): java.lang.NullPointerException
03-15 13:38:41.200: E/AndroidRuntime(15732): at ie.whereis.DisplaySearchActivity$updateUI.onPostExecute(DisplaySearchActivity.java:34)
03-15 13:38:41.200: E/AndroidRuntime(15732): at ie.whereis.DisplaySearchActivity$updateUI.onPostExecute(DisplaySearchActivity.java:1)
03-15 13:38:41.200: E/AndroidRuntime(15732): at android.os.AsyncTask.finish(AsyncTask.java:631)
03-15 13:38:41.200: E/AndroidRuntime(15732): at android.os.AsyncTask.access$600(AsyncTask.java:177)
03-15 13:38:41.200: E/AndroidRuntime(15732): at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:644)
03-15 13:38:41.200: E/AndroidRuntime(15732): at android.os.Handler.dispatchMessage(Handler.java:99)
03-15 13:38:41.200: E/AndroidRuntime(15732): at android.os.Looper.loop(Looper.java:137)
03-15 13:38:41.200: E/AndroidRuntime(15732): at android.app.ActivityThread.main(ActivityThread.java:4898)
03-15 13:38:41.200: E/AndroidRuntime(15732): at java.lang.reflect.Method.invokeNative(Native Method)
03-15 13:38:41.200: E/AndroidRuntime(15732): at java.lang.reflect.Method.invoke(Method.java:511)
03-15 13:38:41.200: E/AndroidRuntime(15732): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1006)
03-15 13:38:41.200: E/AndroidRuntime(15732): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:773)
03-15 13:38:41.200: E/AndroidRuntime(15732): at dalvik.system.NativeStart.main(Native Method)
私はそれが行によってスローされていると思います:
adapter.notifyDataSetChanged();
しかし、たくさん読んだ後でも、アダプターが何をするのかよくわかりません。なぜだかわかりません
listItems.add("Retrieving Results...");
pre Execute では動作しますが、post では動作しません。
どんな助けでも大歓迎です。
ありがとう、私は解決策をコメントしました。票を処理できなかったことをお詫び申し上げます。<15カルマ