Çalışma durumunu bildirme

Bu kılavuzda, arka plan hizmetinde çalıştırılan bir iş isteğinin durumunun isteği gönderen bileşene nasıl bildirileceği gösterilmektedir. Bu, örneğin, bir Activity nesnesinin kullanıcı arayüzünde isteğin durumunu raporlamanıza olanak tanır. Durumu gönderip almak için önerilen yöntem, yayın Intent nesnelerini kendi uygulamanızdaki bileşenlerle sınırlayan bir LocalBroadcastManager kullanmaktır.

JobIntentService'ten durumu bildirme

JobIntentService içindeki bir iş isteğinin durumunu diğer bileşenlere göndermek için önce genişletilmiş verilerinde durumu içeren bir Intent oluşturun. Alternatif olarak, bu Intent öğesine bir işlem ve veri URI'si ekleyebilirsiniz.

Ardından, LocalBroadcastManager.sendBroadcast() numaralı telefonu arayarak Intent numaralı telefonu gönderin. Bu işlem, Intent öğesini almak için kaydolmuş uygulamanızda bulunan herhangi bir bileşene gönderir. LocalBroadcastManager örneğini almak için getInstance() numaralı telefonu arayın.

Örneğin:

Kotlin

...
// Defines a custom Intent action
const val BROADCAST_ACTION = "com.example.android.threadsample.BROADCAST"
...
// Defines the key for the status "extra" in an Intent
const val EXTENDED_DATA_STATUS = "com.example.android.threadsample.STATUS"
...
class RSSPullService : JobIntentService() {
    ...
    /*
     * Creates a new Intent containing a Uri object
     * BROADCAST_ACTION is a custom Intent action
     */
    val localIntent = Intent(BROADCAST_ACTION).apply {
        // Puts the status into the Intent
        putExtra(EXTENDED_DATA_STATUS, status)
    }
    // Broadcasts the Intent to receivers in this app.
    LocalBroadcastManager.getInstance(this).sendBroadcast(localIntent)
    ...
}

Java

public final class Constants {
    ...
    // Defines a custom Intent action
    public static final String BROADCAST_ACTION =
        "com.example.android.threadsample.BROADCAST";
    ...
    // Defines the key for the status "extra" in an Intent
    public static final String EXTENDED_DATA_STATUS =
        "com.example.android.threadsample.STATUS";
    ...
}
public class RSSPullService extends JobIntentService {
...
    /*
     * Creates a new Intent containing a Uri object
     * BROADCAST_ACTION is a custom Intent action
     */
    Intent localIntent =
            new Intent(Constants.BROADCAST_ACTION)
            // Puts the status into the Intent
            .putExtra(Constants.EXTENDED_DATA_STATUS, status);
    // Broadcasts the Intent to receivers in this app.
    LocalBroadcastManager.getInstance(this).sendBroadcast(localIntent);
...
}

Sonraki adım, orijinal çalışma isteğini gönderen bileşende gelen Intent yayını nesnelerini işlemektir.

Bir JobIntentService'ten durum yayınları alma

Yayınlanan Intent nesnelerini almak için BroadcastReceiver alt sınıfını kullanın. Alt sınıfta, Intent aldığında LocalBroadcastManager tarafından çağırılan BroadcastReceiver.onReceive() geri çağırma yöntemini uygulayın. LocalBroadcastManager, gelen Intent değerini BroadcastReceiver.onReceive() cihazına iletir.

Örneğin:

Kotlin

// Broadcast receiver for receiving status updates from the IntentService.
private class DownloadStateReceiver : BroadcastReceiver() {

    override fun onReceive(context: Context, intent: Intent) {
        ...
        /*
         * Handle Intents here.
         */
        ...
    }
}

Java

// Broadcast receiver for receiving status updates from the IntentService.
private class DownloadStateReceiver extends BroadcastReceiver
{
    // Called when the BroadcastReceiver gets an Intent it's registered to receive
    @Override
    public void onReceive(Context context, Intent intent) {
...
        /*
         * Handle Intents here.
         */
...
    }
}

BroadcastReceiver öğesini tanımladıktan sonra bunun için belirli işlemler, kategoriler ve verilerle eşleşen filtreler tanımlayabilirsiniz. Bunun için bir IntentFilter oluşturun. Bu ilk snippet'te, filtrenin nasıl tanımlanacağı gösterilmektedir:

Kotlin

// Class that displays photos
class DisplayActivity : FragmentActivity() {
    ...
    override fun onCreate(savedInstanceState: Bundle?) {
        ...
        super.onCreate(savedInstanceState)
        ...
        // The filter's action is BROADCAST_ACTION
        var statusIntentFilter = IntentFilter(BROADCAST_ACTION).apply {
            // Adds a data filter for the HTTP scheme
            addDataScheme("http")
        }
        ...

Java

// Class that displays photos
public class DisplayActivity extends FragmentActivity {
    ...
    public void onCreate(Bundle stateBundle) {
        ...
        super.onCreate(stateBundle);
        ...
        // The filter's action is BROADCAST_ACTION
        IntentFilter statusIntentFilter = new IntentFilter(
                Constants.BROADCAST_ACTION);

        // Adds a data filter for the HTTP scheme
        statusIntentFilter.addDataScheme("http");
        ...

BroadcastReceiver ve IntentFilter öğelerini sisteme kaydetmek için LocalBroadcastManager örneği alın ve registerReceiver() yöntemini çağırın. Aşağıdaki snippet, BroadcastReceiver ve IntentFilter öğesinin nasıl kaydedileceğini gösterir:

Kotlin

        // Instantiates a new DownloadStateReceiver
        val downloadStateReceiver = DownloadStateReceiver()
        // Registers the DownloadStateReceiver and its intent filters
        LocalBroadcastManager.getInstance(this)
                .registerReceiver(downloadStateReceiver, statusIntentFilter)
        ...

Java

        // Instantiates a new DownloadStateReceiver
        DownloadStateReceiver downloadStateReceiver =
                new DownloadStateReceiver();
        // Registers the DownloadStateReceiver and its intent filters
        LocalBroadcastManager.getInstance(this).registerReceiver(
                downloadStateReceiver,
                statusIntentFilter);
        ...

Tek bir BroadcastReceiver, her biri kendi işlemine sahip olan birden fazla Intent yayın nesnesi türünü işleyebilir. Bu özellik, her işlem için ayrı bir BroadcastReceiver tanımlamanıza gerek kalmadan her işlem için farklı kod çalıştırmanızı sağlar. Aynı BroadcastReceiver için başka bir IntentFilter tanımlamak isterseniz IntentFilter öğesini oluşturup çağrıyı registerReceiver() için tekrarlayın. Örneğin:

Kotlin

        /*
         * Instantiates a new action filter.
         * No data filter is needed.
         */
        statusIntentFilter = IntentFilter(ACTION_ZOOM_IMAGE)
        // Registers the receiver with the new filter
        LocalBroadcastManager.getInstance(this)
                .registerReceiver(downloadStateReceiver, statusIntentFilter)

Java

        /*
         * Instantiates a new action filter.
         * No data filter is needed.
         */
        statusIntentFilter = new IntentFilter(Constants.ACTION_ZOOM_IMAGE);
        // Registers the receiver with the new filter
        LocalBroadcastManager.getInstance(this).registerReceiver(
                downloadStateReceiver,
                statusIntentFilter);

Bir yayın Intent gönderildiğinde Activity işlemi başlatılmaz veya devam ettirilmez. Activity için BroadcastReceiver, uygulamanız arka plandayken bile Intent nesnelerini alır ve işler, ancak uygulamanızı ön plana zorlamaz. Uygulamanız görünür değilken arka planda gerçekleşen bir etkinliği kullanıcıya bildirmek istiyorsanız Notification kullanın. Gelen bir Intent yayınına yanıt olarak hiçbir zaman Activity başlatmayın.