O que pode estar errado no IntentService
-
13-12-2019 - |
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.
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