Сам столкнулся с этой проблемой, и мне удалось заставить ее работать:)
Я использовал AsyncTask
для обработки фоновых задач / потоков, но идея должна быть такой жеиспользуя Runnable/Handler
(хотя AsyncTask
чувствует себя лучше imo).
Итак, это то, что я сделал ... поместил setContentView(R.layout.my_screen);
в метод onPostExecute
!(т.е. вместо метода onCreate
)
Итак, код выглядит примерно так:
public class MyScreen extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// setContentView(R.layout.my_screen); !!! Don't setContentView here... (see bottom)
new MySpecialTask().execute();
}
private int somethingThatTakesALongTime() {
int result;
// blah blah blah
return result;
}
private void updateTheUiWithResult(int result) {
// Some code that changes the UI
// For exampe:
TextView myTextView = (TextView) findViewById(R.id.result_text);
myTextView.setText("Result is: " + result);
ProgressBar anyProgressBar = (ProgressBar) findViewById(R.id.custom_progressbar);
anyProgressBar.setProgressDrawable(res.getDrawable(R.drawable.progressbar_style));
anyProgressBar.setMax(100);
anyProgressBar.setProgress(result);
}
private class MySpecialTask extends AsyncTask<String, Void, Integer> {
ProgressDialog mProgressDialog;
@Override
protected void onPreExecute() {
mProgressDialog = ProgressDialog.show(MyScreen.this, "", "Calculating...\nPlease wait...", true);
}
@Override
protected Integer doInBackground(String... strings) {
return somethingThatTakesALongTime();
}
@Override
protected void onPostExecute(Integer result) {
mProgressDialog.dismiss();
setContentView(R.layout.my_screen); // setContent view here... then it works...
updateTheUiWithResult(result);
}
}
}
Если честно, зачем вам нужно вызывать setContentView
в onPostExecute
Понятия не имею ... но это означает, что вы можете установить собственные стили для ваших индикаторов выполнения (и они не исчезнут на вас!)