ti-enxame.com

Não é possível criar o manipulador dentro do encadeamento que não chamou Looper.prepare () dentro do AsyncTask para ProgressDialog

Eu não entendo porque estou recebendo este erro. Estou usando o AsyncTask para executar alguns processos em segundo plano.

Eu tenho:

protected void onPreExecute() 
{
    connectionProgressDialog = new ProgressDialog(SetPreference.this);
    connectionProgressDialog.setCancelable(true);
    connectionProgressDialog.setProgressStyle(ProgressDialog.STYLE_SPINNER);
    connectionProgressDialog.setMessage("Connecting to site...");
    connectionProgressDialog.show();

    downloadSpinnerProgressDialog = new ProgressDialog(SetPreference.this);
    downloadSpinnerProgressDialog.setProgressStyle(ProgressDialog.STYLE_SPINNER);
    downloadSpinnerProgressDialog.setMessage("Downloading wallpaper...");
}

Quando eu entro em doInBackground() dependendo de uma condição eu:

[...]    
connectionProgressDialog.dismiss();
downloadSpinnerProgressDialog.show();
[...]

Sempre que tento downloadSpinnerProgressDialog.show() recebo o erro.

Alguma idéia caras?

78
mlevit

O método show() deve ser chamado pelo thread ser-Interface (UI) , enquanto doInBackground() é executado em um thread diferente, que é a principal razão pela qual o AsyncTask foi projetado.

Você precisa chamar show() em onProgressUpdate() ou onPostExecute().

Por exemplo:

class ExampleTask extends AsyncTask<String, String, String> {

    // Your onPreExecute method.

    @Override
    protected String doInBackground(String... params) {
        // Your code.
        if (condition_is_true) {
            this.publishProgress("Show the dialog");
        }
        return "Result";
    }

    @Override
    protected void onProgressUpdate(String... values) {
        super.onProgressUpdate(values);
        connectionProgressDialog.dismiss();
        downloadSpinnerProgressDialog.show();
    }
}
105
Konstantin Burov

Eu tive um problema semelhante, mas da leitura desta questão eu percebi que eu poderia rodar em thread de interface do usuário:

YourActivity.this.runOnUiThread(new Runnable() {
    public void run() {
        alertDialog.show();
    }
});

Parece fazer o truque para mim.

81
hyui

Eu tive dificuldade em fazer este trabalho também, a solução para mim foi usar as respostas hyui e konstantin,

class ExampleTask extends AsyncTask<String, String, String> {

// Your onPreExecute method.

@Override
protected String doInBackground(String... params) {
    // Your code.
    if (condition_is_true) {
        this.publishProgress("Show the dialog");
    }
    return "Result";
}

@Override
protected void onProgressUpdate(String... values) {

    super.onProgressUpdate(values);
    YourActivity.this.runOnUiThread(new Runnable() {
       public void run() {
           alertDialog.show();
       }
     });
 }

}
1
caiocpricci2
final Handler handler = new Handler() {
        @Override
        public void handleMessage(final Message msgs) {
        //write your code hear which give error
        }
        }

new Thread(new Runnable() {
    @Override
    public void run() {
    handler.sendEmptyMessage(1);
        //this will call handleMessage function and hendal all error
    }
    }).start();
0
jayesh kavathiya