Pergunta

Usei o IntentService com sucesso algumas vezes, mas no aplicativo atual não consigo iniciar o onReceive() do BroadcastReceiver.Eu tenho a String exata na ação do Intent do IntentService e no IntentFilter que foi registrado no onResume junto com o BroadcastReceiver.

    filter = new IntentFilter("com.currencyconverter2.intent.action.MESSAGE");
    Log.d("CC2", "intent filter created");
    filter.addCategory(Intent.CATEGORY_DEFAULT);
    Log.d("CC2", "filter category added");
    receiver = new MessageReceiver();
    Log.d("CC2", "receiver instantiated");
}

public void onResume(){
    super.onResume();
    registerReceiver(receiver, filter);
    Log.d("CC2", "receiver registered");
}

public void onPause(){
    super.onPause();
    unregisterReceiver(receiver);
    Log.d("CC2", "receiver unregistered");
}

public class MessageReceiver extends BroadcastReceiver{
    public void onReceive(Context context, Intent intent){
        Log.d(Tag, "entered onReceive...");
        String html = intent.getStringExtra("OUTPUT");
        webView.setBackgroundColor(Color.parseColor("#f4f36f"));
        webView.loadDataWithBaseURL(null, html, "text/html", "utf-8", null);
    }
}

Também especifiquei o serviço em Manifest.xml.

<service android:name=".IntentServiceTest"></service>

Meu log me diz que o intentBroadcast foi transmitido do IntentService e o aplicativo parou aí.BroadcastReceiver não parece ter recebido.O que pode estar errado?Obrigado!

Editar:

Meu IntentService

        Intent broadcastIntent = new Intent();
        Log.d(Tag, "setting intent action");
        broadcastIntent.setAction("com.currencyconverter2.intent.action.MESSAGE");
        Log.d(Tag, "adding intent category");
        broadcastIntent.addCategory(Intent.CATEGORY_DEFAULT);
        Log.d(Tag, "putting intent extra");
        broadcastIntent.putExtra("OUTPUT", data.text());
        Log.d(Tag, "sending broadcast");
        sendBroadcast(intent);

    }catch(Exception e){
        e.printStackTrace();
        //System.out.println("f");
    }
}

}

Editar 2:

Encontrei o bug.

                          Intent broadcastIntent = new Intent();
        Log.d(Tag, "setting intent action");
        broadcastIntent.setAction("com.currencyconverter2.intent.action.MESSAGE");
        Log.d(Tag, "adding intent category");
        broadcastIntent.addCategory(Intent.CATEGORY_DEFAULT);
        Log.d(Tag, "putting intent extra");
        broadcastIntent.putExtra("OUTPUT", data.text());
        Log.d(Tag, "sending broadcast");
        sendBroadcast(intent);

Eu deveria ter sendBroadcast(broadcastIntent);em vez de.

Foi útil?

Solução

Verifique seu AndroidManifest.xml:

<receiver android:name=".MessageReceiver">
<intent-filter>
<action android:name="com.currencyconverter2.intent.action.MESSAGE" />
<category android:name="android.intent.category.Default" />
</intent-filter>
</receiver>

^-^

Outras dicas

IntentService use para executar a tarefa e desligá-la, mas de acordo com seu código, parece que você está usando um longo tempo de execução, use Serviço em vez de IntentService

Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top