0

IntentServiceを数回使用しましたが、現在のアプリでは、BroadcastReceiverのonReceive()を起動できません。IntentServiceのIntentのアクションと、BroadcastReceiverとともにonResumeに登録されたIntentFilterに正確な文字列があります。

    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);
    }
}

また、Manifest.xmlでサービスを指定しました。

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

私のログには、intentBroadcastがIntentServiceからブロードキャストされ、アプリがそこで停止したことが示されています。BroadcastReceiverはそれを受信して​​いないようです。何が間違っている可能性がありますか?ありがとう!

編集:

私の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");
    }
}

}

編集2:

バグが見つかりました。

                          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);

sendBroadcast(broadcastIntent);が必要です。代わりは。

4

2 に答える 2

1

IntentServiceはタスクを実行してシャットアウトするために使用しますが、コードと同様に、実行時間が長いように思われるため、 IntentServiceの代わりにServiceを使用してください

于 2012-07-29T08:03:01.927 に答える
0

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>

^-^

于 2012-07-29T08:34:45.527 に答える