Мне нужно извлечь огромные данные из одной базы данных, когда начинается действие.Чтобы предотвратить пользователя с замороженным окном, я решил запустить ProgressDialog во время обработки данных.
Из OnCreate я вызываю мой класс initDb:
new initDb (). Execute ();
И затем для этого у меня есть один класс внутри класса моей деятельности:
public class initDb extends AsyncTask<Void, Void, Void> {
ProgressDialog mDialog = new ProgressDialog(ClientsReg.this);
@Override
protected void onPreExecute() {
mDialog.setMessage("Please wait...");
mDialog.show();
}
@Override
protected Void doInBackground(Void... voids) {
opendb();
listCities();
return null;
}
@Override
protected void onPostExecute(Void unused) {
// Pass the result data back to the main activity
mDialog.dismiss();
}
}
Настоящая проблема возникает при установке адаптера:
private void listCities() {
mRedrawHandler.sleep(100000);
c = db.executeSQL("SELECT * FROM RegDB WHERE Reg_Type = 1 AND cad_uzkow = 0 ORDER BY _id DESC");
//add some list items
ArrayList<String> finalList = new ArrayList<String>();
c.moveToFirst();
while (!c.isAfterLast()){
finalList.add(c.getString(0) + ")"+ c.getString(5));
c.moveToNext();
}
ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,
R.layout.row, R.id.itemShow, finalList);
sp.setAdapter(adapter);
}
Всегда случается сбой в sp.setAdapter (адаптере);
Есть идеи?
Спасибо!