#android #listview #progressdialog
#Android #просмотр списка #progressdialog
Вопрос:
Я использую следующий код, чтобы открыть XML-файл и просмотреть его информацию в ListView.
Я включил ProgressDialog в первую часть своего кода, чтобы показывать его до загрузки файлов, и как только они будут загружены, ProgressDialog исчезнет.
Проблема в том, что ProgressDialog отображается, когда файлы уже загружены. Экран черный, пока файлы не будут загружены, и когда они будут полностью загружены, отображается ListView и одновременно отображается ProgressDialog.
Пожалуйста, помогите мне.
Спасибо
public class Main extends ListActivity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
final ProgressDialog _progressDialog = new ProgressDialog(this);
_progressDialog.setIcon(R.drawable.icon);
_progressDialog.setTitle("Loading ...");
_progressDialog.setProgressStyle(ProgressDialog.STYLE_SPINNER);
runOnUiThread(new Runnable() {
@Override
public void run() {
_progressDialog.show();
Thread t = new Thread() {
public void run(){
GetData();
_progressDialog.dismiss();
}
};
t.run();
}
});
}
public boolean GetData() {
ArrayList<HashMap<String, String>> mylist = new ArrayList<HashMap<String, String>>();
setContentView(R.layout.listplaceholder);
String xml = XMLfunctions.getXML();
Document doc = XMLfunctions.XMLfromString(xml);
int numResults = XMLfunctions.numResults(doc);
if((numResults <= 0)){
Toast.makeText(Main.this, "Geen resultaten gevonden", Toast.LENGTH_LONG).show();
finish();
}
NodeList nodes = doc.getElementsByTagName("result");
for (int i = 0; i < nodes.getLength(); i ) {
HashMap<String, String> map = new HashMap<String, String>();
Element e = (Element)nodes.item(i);
map.put("id", XMLfunctions.getValue(e, "id"));
map.put("name", "Naam:" XMLfunctions.getValue(e, "name"));
map.put("Score", "Score: " XMLfunctions.getValue(e, "score"));
mylist.add(map);
}
ListAdapter adapter = new SimpleAdapter(this, mylist , R.layout.main,
new String[] { "name", "Score", "name" },
new int[] { R.id.item_title, R.id.item_subtitle, R.id.item_subtitle2 });
setListAdapter(adapter);
final ListView lv = getListView();
lv.setTextFilterEnabled(true);
lv.setOnItemClickListener(new OnItemClickListener() {
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
@SuppressWarnings("unchecked")
HashMap<String, String> o = (HashMap<String, String>) lv.getItemAtPosition(position);
Toast.makeText(Main.this, "ID '" o.get("name") "' was clicked.", Toast.LENGTH_LONG).show();
}
});
return true;
}
}
Ответ №1:
Используйте AsyncTask и покажите диалоговое окно прогресса в onPreExecute()
:
public class Main extends ListActivity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
final ProgressDialog _progressDialog = new ProgressDialog(this);
_progressDialog.setIcon(R.drawable.icon);
_progressDialog.setTitle("Loading ...");
_progressDialog.setProgressStyle(ProgressDialog.STYLE_SPINNER);
new AsyncTask<Void, Void, Void>() {
protected Long doInBackground(Void ... urls) {
GetData();
}
protected void onPostExecute(Void result) {
_progressDialog.dismiss();
}
protected void onPreExecute(Void no) {
_progressDialog.show();
}
}.execute();
}
Комментарии:
1. Проблема! при использовании функции getData() в doInBackground приложение принудительно закрывается! почему ?!
2. @maxoya — Это моя вина, что я не смотрел
GetData()
так, как должен был. интегрируйтеGetData
функциональность в AsyncTask, чтобы вы не изменяли пользовательский интерфейс из фонового потока (например, doInBackground), а в потоке пользовательского интерфейса (например, onProgressUpdate, onPostExecute и т. Д.)
Ответ №2:
В зависимости от того, готовы вы или нет использовать новый API фрагментов, вы также можете расширить ListFragment (используя пакет совместимости с Android) и использовать setListShown(логическое значение). Я часто использую это с LoaderManager.LoaderCallbacks<Курсор> (не тот же контекст, что и у вас, возможно, вы могли бы использовать AsyncTaskLoader).
В любом случае: 1 для ответа AsyncTask.