2011-08-15 18 views
0

データベースをインストールしてからアプリケーションを初めて実行するときに進行状況ダイアログを表示しようとしていますが、DBサイズのためにこれを行うのに時間がかかります。私が使用しているListAcitityは次のとおりです。 package samples.employeedirectory;androidにsqlliteデータベースをインストールする際の進行状況の表示方法

​​

}

私が活動を開始する前に、私はプログレスバーを表示することができないことを、その後実現。これを達成するための最良のアプローチは何ですか?

編集: はこのコードを使用する:

package samples.employeedirectory; 

import android.app.ProgressDialog; 
import android.content.Context; 
import android.database.sqlite.SQLiteDatabase; 
import android.os.AsyncTask; 

public class progressBar extends AsyncTask<String, Void, String> { 
protected Context context; 
protected SQLiteDatabase db; 
protected ProgressDialog dialog; 
@Override 
protected String doInBackground(String... params) { 
    db = (new DatabaseHelper(context)).getWritableDatabase(); 
    return null; 
} 

/* (non-Javadoc) 
* @see android.os.AsyncTask#onPostExecute(java.lang.Object) 
*/ 
@Override 
protected void onPostExecute(String result) { 
    // TODO Auto-generated method stub 
    super.onPostExecute(result); 
    dialog.dismiss(); 
} 

/* (non-Javadoc) 
* @see android.os.AsyncTask#onPreExecute() 
*/ 
@Override 
protected void onPreExecute() { 
    // super.onPreExecute(); 
dialog = ProgressDialog.show(context, "", 
      "Please wait for few seconds...", true); 
} 

/* (non-Javadoc) 
* @see android.os.AsyncTask#onProgressUpdate(Progress[]) 
*/ 
@Override 
protected void onProgressUpdate(Void... values) { 
    // TODO Auto-generated method stub 
    super.onProgressUpdate(values); 
} 

}

私はこれらのエラーを受け取った:

08-15 23:21:26.743: ERROR/AndroidRuntime(5170): java.lang.RuntimeException: Unable to start activity ComponentInfo{samples.employeedirectory/samples.employeedirectory.EmployeeList}: java.lang.NullPointerException 
    08-15 23:21:26.743: ERROR/AndroidRuntime(5170):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1659) 
    08-15 23:21:26.743: ERROR/AndroidRuntime(5170):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1675) 
    08-15 23:21:26.743: ERROR/AndroidRuntime(5170):  at android.app.ActivityThread.access$1500(ActivityThread.java:121) 
    08-15 23:21:26.743: ERROR/AndroidRuntime(5170):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:943) 
    08-15 23:21:26.743: ERROR/AndroidRuntime(5170):  at android.os.Handler.dispatchMessage(Handler.java:99) 
    08-15 23:21:26.743: ERROR/AndroidRuntime(5170):  at android.os.Looper.loop(Looper.java:123) 
    08-15 23:21:26.743: ERROR/AndroidRuntime(5170):  at android.app.ActivityThread.main(ActivityThread.java:3701) 
    08-15 23:21:26.743: ERROR/AndroidRuntime(5170):  at java.lang.reflect.Method.invokeNative(Native Method) 
    08-15 23:21:26.743: ERROR/AndroidRuntime(5170):  at java.lang.reflect.Method.invoke(Method.java:507) 
    08-15 23:21:26.743: ERROR/AndroidRuntime(5170):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:862) 
    08-15 23:21:26.743: ERROR/AndroidRuntime(5170):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:620) 
    08-15 23:21:26.743: ERROR/AndroidRuntime(5170):  at dalvik.system.NativeStart.main(Native Method) 
    08-15 23:21:26.743: ERROR/AndroidRuntime(5170): Caused by: java.lang.NullPointerException 
    08-15 23:21:26.743: ERROR/AndroidRuntime(5170):  at android.app.Dialog.<init>(Dialog.java:141) 
    08-15 23:21:26.743: ERROR/AndroidRuntime(5170):  at android.app.AlertDialog.<init>(AlertDialog.java:67) 
    08-15 23:21:26.743: ERROR/AndroidRuntime(5170):  at android.app.ProgressDialog.<init>(ProgressDialog.java:80) 
    08-15 23:21:26.743: ERROR/AndroidRuntime(5170):  at android.app.ProgressDialog.<init>(ProgressDialog.java:76) 
    08-15 23:21:26.743: ERROR/AndroidRuntime(5170):  at android.app.ProgressDialog.show(ProgressDialog.java:101) 
    08-15 23:21:26.743: ERROR/AndroidRuntime(5170):  at android.app.ProgressDialog.show(ProgressDialog.java:90) 
    08-15 23:21:26.743: ERROR/AndroidRuntime(5170):  at samples.employeedirectory.progressBar.onPreExecute(progressBar.java:34) 
    08-15 23:21:26.743: ERROR/AndroidRuntime(5170):  at android.os.AsyncTask.execute(AsyncTask.java:391) 
    08-15 23:21:26.743: ERROR/AndroidRuntime(5170):  at samples.employeedirectory.EmployeeList.onCreate(EmployeeList.java:27) 
    08-15 23:21:26.743: ERROR/AndroidRuntime(5170):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 
    08-15 23:21:26.743: ERROR/AndroidRuntime(5170):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1623) 

答えて

0

あなたは(PreexecuteにAsyntaskコンセプト を使用することができます)進捗対話を開始doinginbackground()メソッドでDB をpostexecute()にインストールしてください。 GUE

this

+0

を参照してください私はAsyntaskを実装する受信エラーで私の質問を編集しました。私はウェブ上の例を試してみましたが、どちらもうまくいきませんでした。 –

+0

context = thisを割り当ててください。アクティビティクラスのonCreate()で –

+0

またはダイアログ= ProgressDialog.show(EmployeeList.this、 ""、 "しばらくお待ちください..."、true); –

関連する問題