Engage SDK Watch: Üçüncü taraf teknik entegrasyon talimatları

Kullanıcılarınıza bulundukları yerde ulaşarak uygulama etkileşimini artırın. Engage SDK'yı entegre ederek "İzlemeye Devam Et" içeriklerini ve kişiselleştirilmiş önerileri doğrudan kullanıcılara cihaz üzerindeki birden fazla yüzeyde (Koleksiyonlar, Entertainment Space ve Play Store) sunun. Entegrasyon, ortalama APK'ya 50 KB'tan daha az (sıkıştırılmış) boyut ekler ve çoğu uygulamada yaklaşık bir haftalık geliştirici süresi gerektirir. Daha fazla bilgi için işletme sitemizi ziyaret edin.

Bu kılavuzda, geliştirici iş ortaklarının hem bu yeni yüzey alanını hem de mevcut Google yüzeylerini doldurmak için Engage SDK'yı kullanarak video içeriklerini entegre etme talimatları yer almaktadır.

Entegrasyon ayrıntıları

Terminoloji

Bu entegrasyon aşağıdaki üç küme türünü içerir: Öneri, Devam ve Öne Çıkanlar.

  • Öneri kümelerinde, tek bir geliştirici iş ortağının izlenecek içerikleriyle ilgili kişiselleştirilmiş öneriler gösterilir.

    Önerileriniz aşağıdaki yapıda olmalıdır:

    • Öneri Kümesi: Aynı geliştirici iş ortağının önerilerinden oluşan bir grubu içeren kullanıcı arayüzü görünümü.

      1. şekil. Tek bir iş ortağının öneri grubunu gösteren Entertainment Space kullanıcı arayüzü.
    • Varlık: Bir kümedeki tek bir öğeyi temsil eden nesne. Öğe; film, TV programı, TV dizisi, canlı video vb. olabilir. Desteklenen öğe türlerinin listesi için Öğe verileri sağlama bölümüne bakın.

      Şekil 2. Tek bir iş ortağının öneri kümesinde tek bir öğeyi gösteren Entertainment Space kullanıcı arayüzü.
      <0x0x0A>
  • Devam kümesinde, tamamlanmamış videolar ve birden fazla geliştirici iş ortağının yeni yayınlanan ilgili bölümleri tek bir kullanıcı arayüzü grubunda gösterilir. Her geliştirici iş ortağı, Devam kümesinde en fazla 10 öğe yayınlayabilir. Araştırmalar, kişiselleştirilmiş önerilerin ve kişiselleştirilmiş Devam Etme içeriklerinin en iyi kullanıcı etkileşimini sağladığını göstermiştir.

    3.şekil Birden fazla iş ortağının tamamlanmamış önerilerini içeren bir Devam Ettirme grubu gösteren Entertainment Space kullanıcı arayüzü (şu anda yalnızca bir öneri görünür).
  • Öne çıkanlar kümesi, birden fazla geliştirici iş ortağının seçilmiş öğelerini tek bir kullanıcı arayüzü grubunda gösterir. Tek bir Öne Çıkan küme bulunur. Bu küme, kullanıcı arayüzünün üst kısmına yakın bir yerde, tüm Öneri kümelerinin üzerinde öncelikli bir yerleşimle gösterilir. Her geliştirici iş ortağı, Öne Çıkan kümede en fazla 10 öğe yayınlayabilir.

    Şekil 4. Birden fazla iş ortağının önerilerini içeren Öne Çıkanlar kümesini gösteren Entertainment Space kullanıcı arayüzü (şu anda yalnızca bir öneri görünür).

Ön çalışma

Minimum API düzeyi: 19

Uygulamanıza com.google.android.engage:engage-core kitaplığını ekleyin:

dependencies {
    // Make sure you also include that repository in your project's build.gradle file.
    implementation 'com.google.android.engage:engage-core:1.5.2'
}

Daha fazla bilgi için Android 11'de paket görünürlüğü başlıklı makaleyi inceleyin.

Özet

Tasarım, bağlı bir hizmetin uygulanmasına dayanır.

Bir istemcinin yayınlayabileceği veriler, farklı küme türleri için aşağıdaki sınırlara tabidir:

Küme türü Küme sınırları Bir kümedeki maksimum öğe sınırları
Öneri kümeleri En fazla 7 En fazla 50
Devamlılık Kümesi En fazla 1 En fazla 20
Öne Çıkan Küme En fazla 1 En fazla 20

0. adım: Mevcut Media Home SDK entegrasyonundan geçiş

Mevcut entegrasyondaki veri modellerini eşleme

Mevcut bir Media Home entegrasyonundan geçiş yapıyorsanız aşağıdaki tabloda, mevcut SDK'lardaki veri modellerinin yeni Engage SDK'ya nasıl eşleneceği açıklanmaktadır:

MediaHomeVideoContract entegrasyonuna eşdeğer Engage SDK entegrasyonuna eşdeğer
com.google.android.mediahome.video.PreviewChannel com.google.android.engage.common.datamodel.RecommendationCluster
com.google.android.mediahome.video.PreviewChannel.Builder com.google.android.engage.common.datamodel.RecommendationCluster.Builder
com.google.android.mediahome.video.PreviewChannelHelper com.google.android.engage.video.service.AppEngageVideoClient
com.google.android.mediahome.video.PreviewProgram Ayrı sınıflara ayrılmıştır: EventVideo, LiveStreamingVideo, Movie, TvEpisode, TvSeason, TvShow, VideoClipEntity
com.google.android.mediahome.video.PreviewProgram.Builder Ayrı sınıflardaki oluşturuculara bölünmüştür: EventVideo, LiveStreamingVideo, Movie, TvEpisode, TvSeason, TvShow, VideoClipEntity
com.google.android.mediahome.video.VideoContract Artık gerekli değil.
com.google.android.mediahome.video.WatchNextProgram Ayrı sınıflardaki özelliklere bölünür: EventVideoEntity, LiveStreamingVideoEntity, MovieEntity, TvEpisodeEntity, TvSeasonEntity, TvShowEntity, VideoClipEntity
com.google.android.mediahome.video.WatchNextProgram.Builder Ayrı sınıflardaki özelliklere bölünür: EventVideoEntity, LiveStreamingVideoEntity, MovieEntity, TvEpisodeEntity, TvSeasonEntity, TvShowEntity, VideoClipEntity

Media Home SDK ile Engage SDK'daki yayınlama kümeleri

Media Home SDK ile kümeler ve öğeler ayrı API'ler aracılığıyla yayınlanıyordu:

// 1. Fetch existing channels
List<PreviewChannel> channels = PreviewChannelHelper.getAllChannels();

// 2. If there are no channels, publish new channels
long channelId = PreviewChannelHelper.publishChannel(builder.build());

// 3. If there are existing channels, decide whether to update channel contents
PreviewChannelHelper.updatePreviewChannel(channelId, builder.build());

// 4. Delete all programs in the channel
PreviewChannelHelper.deleteAllPreviewProgramsByChannelId(channelId);

// 5. publish new programs in the channel
PreviewChannelHelper.publishPreviewProgram(builder.build());

Engage SDK ile küme ve öğe yayınlama tek bir API çağrısında birleştirilir. Bir kümeye ait tüm öğeler, söz konusu küme ile birlikte yayınlanır:

Kotlin

RecommendationCluster.Builder()
            .addEntity(MOVIE_ENTITY)
            .addEntity(MOVIE_ENTITY)
            .addEntity(MOVIE_ENTITY)
            .setTitle("Top Picks For You")
            .build()

Java

new RecommendationCluster.Builder()
                        .addEntity(MOVIE_ENTITY)
                        .addEntity(MOVIE_ENTITY)
                        .addEntity(MOVIE_ENTITY)
                        .setTitle("Top Picks For You")
                        .build();

1. adım: Tüzel kişi verilerini sağlayın

SDK, her öğe türünü temsil etmek için farklı öğeler tanımlamıştır. İzleme kategorisi için aşağıdaki öğeleri destekliyoruz:

  1. MovieEntity
  2. TvShowEntity
  3. TvSeasonEntity
  4. TvEpisodeEntity
  5. LiveStreamingVideoEntity
  6. VideoClipEntity

Aşağıdaki tabloda, her türün özellikleri ve koşulları özetlenmiştir.

MovieEntity

Özellik Şartlar Notlar
Ad Zorunlu
Poster resimleri Zorunlu En az bir resim gereklidir ve en boy oranıyla birlikte sağlanmalıdır. (Yatay resimler tercih edilir ancak farklı senaryolar için hem dikey hem de yatay resimler göndermeniz önerilir.)

Yardım için Resim Özellikleri bölümüne bakın.

Oynatma URI'si Zorunlu

Filmi oynatmaya başlamak için sağlayıcı uygulamasının derin bağlantısı.

Not: Derin bağlantıları ilişkilendirme için kullanabilirsiniz. Bu SSS'ye bakın

Bilgi sayfası URI'si İsteğe bağlı

Filmle ilgili ayrıntıları göstermek için sağlayıcı uygulamasının derin bağlantısı.

Not: Derin bağlantıları ilişkilendirme için kullanabilirsiniz. Bu SSS'ye bakın

Çıkış tarihi İsteğe bağlı Milisaniye cinsinden süre.
Kullanılabilirlik Zorunlu

KULLANILABİLİR: İçerik, kullanıcının başka bir işlem yapmasına gerek kalmadan kullanılabilir.

FREE_WITH_SUBSCRIPTION: İçerik, kullanıcı abonelik satın aldıktan sonra kullanılabilir.

PAID_CONTENT: İçerik için kullanıcının satın alma veya kiralama işlemi yapması gerekir.

SATIN ALINAN: İçerik, kullanıcı tarafından satın alınmış veya kiralanmıştır.

Teklif fiyatı İsteğe bağlı Serbest metin
Süre Zorunlu Milisaniye cinsinden.
Tür Zorunlu Serbest metin
İçerik derecelendirmeleri İsteğe bağlı Serbest metin, sektör standardına uyun. (Örnek)
Sonraki videoyu izleme türü Koşula bağlı olarak gerekli

Öğe, Devam kümesindeyken sağlanmalı ve aşağıdaki dört türden biri olmalıdır:

DEVAM ET: Kullanıcı bu içeriği 1 dakikadan uzun süredir izliyor.

YENİ: Kullanıcı, bazı bölümlük içeriklerdeki tüm bölümleri izlemiş ancak yeni bir bölüm yayınlanmış ve tam olarak bir bölüm izlenmemiştir. Bu özellik; TV programları, bir serideki kayıtlı futbol maçları vb. için kullanılabilir.

SONRAKİ: Kullanıcı, bazı bölümlük içeriklerden bir veya daha fazla bölümün tamamını izlemiş ancak ya birden fazla bölüm ya da son bölümün "YENİ" olmadığı ve kullanıcının bölümlük içeriği izlemeye başlamadan önce yayınlandığı tek bir bölüm kalmıştır.

İZLEME LİSTESİ: Kullanıcı, bir filmi, etkinliği veya diziyi izleme listesine ekleyerek bir sonraki izlemek istediği içeriği manuel olarak seçmeyi tercih etmiştir.

Son etkileşim zamanı Koşula bağlı olarak gerekli Öğe, devamlılık kümesindeyken sağlanmalıdır. Milisaniye cinsinden süre.
Son oynatma konumu zamanı Koşula bağlı olarak gerekli Öğe, Devam kümesindeyken ve WatchNextType CONTINUE olduğunda sağlanmalıdır. Milisaniye cinsinden süre.

TvShowEntity

Özellik Şartlar Notlar
Ad Zorunlu
Poster resimleri Zorunlu En az bir resim gereklidir ve en boy oranıyla birlikte sağlanmalıdır. (Yatay resimler tercih edilir ancak farklı senaryolar için hem dikey hem de yatay resimler göndermeniz önerilir.)

Yardım için Resim Özellikleri bölümüne bakın.

Bilgi sayfası URI'si Zorunlu

TV programının ayrıntılarını göstermek için sağlayıcı uygulamasının derin bağlantısı.

Not: Derin bağlantıları ilişkilendirme için kullanabilirsiniz. Bu SSS'ye bakın

Oynatma URI'si İsteğe bağlı

TV programını oynatmaya başlamak için sağlayıcı uygulamasının derin bağlantısı.

Not: Derin bağlantıları ilişkilendirme için kullanabilirsiniz. Bu SSS'ye bakın

İlk bölümün yayın tarihi İsteğe bağlı Milisaniye cinsinden süre.
Son bölümün yayın tarihi İsteğe bağlı Milisaniye cinsinden süre.
Kullanılabilirlik Zorunlu

KULLANILABİLİR: İçerik, kullanıcının başka bir işlem yapmasına gerek kalmadan kullanılabilir.

FREE_WITH_SUBSCRIPTION: İçerik, kullanıcı abonelik satın aldıktan sonra kullanılabilir.

PAID_CONTENT: İçerik için kullanıcının satın alma veya kiralama işlemi yapması gerekir.

SATIN ALINAN: İçerik, kullanıcı tarafından satın alınmış veya kiralanmıştır.

Teklif fiyatı İsteğe bağlı Serbest metin
Sezon sayısı Zorunlu Pozitif tam sayı
Tür Zorunlu Serbest metin
İçerik derecelendirmeleri İsteğe bağlı Serbest metin, sektör standardına uyun. (Örnek)
Sonraki videoyu izleme türü Koşula bağlı olarak gerekli

Öğe, Devam kümesindeyken sağlanmalı ve aşağıdaki dört türden biri olmalıdır:

DEVAM ET: Kullanıcı bu içeriği 1 dakikadan uzun süredir izliyor.

YENİ: Kullanıcı, bazı bölümlük içeriklerdeki tüm bölümleri izlemiş ancak yeni bir bölüm yayınlanmış ve tam olarak bir bölüm izlenmemiştir. Bu özellik; TV programları, bir serideki kayıtlı futbol maçları vb. için kullanılabilir.

SONRAKİ: Kullanıcı, bazı bölümlük içeriklerden bir veya daha fazla bölümün tamamını izlemiş ancak ya birden fazla bölüm ya da son bölümün "YENİ" olmadığı ve kullanıcının bölümlük içeriği izlemeye başlamadan önce yayınlandığı tek bir bölüm kalmıştır.

İZLEME LİSTESİ: Kullanıcı, bir filmi, etkinliği veya diziyi izleme listesine ekleyerek bir sonraki izlemek istediği içeriği manuel olarak seçmeyi tercih etmiştir.

Son etkileşim zamanı Koşula bağlı olarak gerekli Öğe, devamlılık kümesindeyken sağlanmalıdır. Milisaniye cinsinden süre.
Son oynatma konumu zamanı Koşula bağlı olarak gerekli Öğe, Devam kümesindeyken ve WatchNextType CONTINUE olduğunda sağlanmalıdır. Milisaniye cinsinden süre.

TvSeasonEntity

Özellik Şartlar Notlar
Ad Zorunlu
Poster resimleri Zorunlu En az bir resim gereklidir ve en boy oranıyla birlikte sağlanmalıdır. (Yatay resimler tercih edilir ancak farklı senaryolar için hem dikey hem de yatay resimler göndermeniz önerilir.)

Yardım için Resim Özellikleri bölümüne bakın.

Bilgi sayfası URI'si Zorunlu

TV programı sezonunun ayrıntılarını göstermek için sağlayıcı uygulamasının derin bağlantısı.

Not: Derin bağlantıları ilişkilendirme için kullanabilirsiniz. Bu SSS'ye bakın

Oynatma URI'si İsteğe bağlı

TV programı sezonunu oynatmaya başlamak için sağlayıcı uygulamasının derin bağlantısı.

Not: Derin bağlantıları ilişkilendirme için kullanabilirsiniz. Bu SSS'ye bakın

Sezon numarasını görüntüleme

İsteğe bağlı

1.3.1 sürümünde kullanılabilir

Dize
İlk bölümün yayın tarihi İsteğe bağlı Milisaniye cinsinden süre.
Son bölümün yayın tarihi İsteğe bağlı Milisaniye cinsinden süre.
Kullanılabilirlik Zorunlu

KULLANILABİLİR: İçerik, kullanıcının başka bir işlem yapmasına gerek kalmadan kullanılabilir.

FREE_WITH_SUBSCRIPTION: İçerik, kullanıcı abonelik satın aldıktan sonra kullanılabilir.

PAID_CONTENT: İçerik için kullanıcının satın alma veya kiralama işlemi yapması gerekir.

SATIN ALINAN: İçerik, kullanıcı tarafından satın alınmış veya kiralanmıştır.

Teklif fiyatı İsteğe bağlı Serbest metin
Bölüm sayısı Zorunlu Pozitif tam sayı
Tür Zorunlu Serbest metin
İçerik derecelendirmeleri İsteğe bağlı Serbest metin, sektör standardına uyun. (Örnek)
Sonraki videoyu izleme türü Koşula bağlı olarak gerekli

Öğe, Devam kümesindeyken sağlanmalı ve aşağıdaki dört türden biri olmalıdır:

DEVAM ET: Kullanıcı bu içeriği 1 dakikadan uzun süredir izliyor.

YENİ: Kullanıcı, bazı bölümlük içeriklerdeki tüm bölümleri izlemiş ancak yeni bir bölüm yayınlanmış ve tam olarak bir bölüm izlenmemiştir. Bu özellik; TV programları, bir serideki kayıtlı futbol maçları vb. için kullanılabilir.

SONRAKİ: Kullanıcı, bazı bölümlük içeriklerden bir veya daha fazla bölümün tamamını izlemiş ancak ya birden fazla bölüm ya da son bölümün "YENİ" olmadığı ve kullanıcının bölümlük içeriği izlemeye başlamadan önce yayınlandığı tek bir bölüm kalmıştır.

İZLEME LİSTESİ: Kullanıcı, bir filmi, etkinliği veya diziyi izleme listesine ekleyerek bir sonraki izlemek istediği içeriği manuel olarak seçmeyi tercih etmiştir.

Son etkileşim zamanı Koşula bağlı olarak gerekli Öğe, devamlılık kümesindeyken sağlanmalıdır. Milisaniye cinsinden süre.
Son oynatma konumu zamanı Koşula bağlı olarak gerekli Öğe, Devam kümesindeyken ve WatchNextType CONTINUE olduğunda sağlanmalıdır. Milisaniye cinsinden süre.

TvEpisodeEntity

Özellik Şartlar Notlar
Ad Zorunlu
Poster resimleri Zorunlu En az bir resim gereklidir ve en boy oranıyla birlikte sağlanmalıdır. (Yatay resimler tercih edilir ancak farklı senaryolar için hem dikey hem de yatay resimler göndermeniz önerilir.)

Yardım için Resim Özellikleri bölümüne bakın.

Oynatma URI'si Zorunlu

Bölümü oynatmaya başlamak için sağlayıcı uygulamasının derin bağlantısı.

Not: Derin bağlantıları ilişkilendirme için kullanabilirsiniz. Bu SSS'ye bakın

Bilgi sayfası URI'si İsteğe bağlı

TV programı bölümüyle ilgili ayrıntıları göstermek için sağlayıcı uygulamasının derin bağlantısı.

Not: Derin bağlantıları ilişkilendirme için kullanabilirsiniz. Bu SSS'ye bakın

Bölüm numarasını görüntüleme

İsteğe bağlı

1.3.1 sürümünde kullanılabilir

Dize
Yayınlanma tarihi Zorunlu Milisaniye cinsinden süre.
Kullanılabilirlik Zorunlu

KULLANILABİLİR: İçerik, kullanıcının başka bir işlem yapmasına gerek kalmadan kullanılabilir.

FREE_WITH_SUBSCRIPTION: İçerik, kullanıcı abonelik satın aldıktan sonra kullanılabilir.

PAID_CONTENT: İçerik için kullanıcının satın alma veya kiralama işlemi yapması gerekir.

SATIN ALINAN: İçerik, kullanıcı tarafından satın alınmış veya kiralanmıştır.

Teklif fiyatı İsteğe bağlı Serbest metin
Süre Zorunlu Milisaniye cinsinden pozitif bir değer olmalıdır.
Tür Zorunlu Serbest metin
İçerik derecelendirmeleri İsteğe bağlı Serbest metin, sektör standardına uyun. (Örnek)
Sonraki videoyu izleme türü Koşula bağlı olarak gerekli

Öğe, Devam kümesindeyken sağlanmalı ve aşağıdaki dört türden biri olmalıdır:

DEVAM ET: Kullanıcı bu içeriği 1 dakikadan uzun süredir izliyor.

YENİ: Kullanıcı, bazı bölümlük içeriklerdeki tüm bölümleri izlemiş ancak yeni bir bölüm yayınlanmış ve tam olarak bir bölüm izlenmemiştir. Bu özellik; TV programları, bir serideki kayıtlı futbol maçları vb. için kullanılabilir.

SONRAKİ: Kullanıcı, bazı bölümlük içeriklerden bir veya daha fazla bölümün tamamını izlemiş ancak ya birden fazla bölüm ya da son bölümün "YENİ" olmadığı ve kullanıcının bölümlük içeriği izlemeye başlamadan önce yayınlandığı tek bir bölüm kalmıştır.

İZLEME LİSTESİ: Kullanıcı, bir filmi, etkinliği veya diziyi izleme listesine ekleyerek bir sonraki izlemek istediği içeriği manuel olarak seçmeyi tercih etmiştir.

Son etkileşim zamanı Koşula bağlı olarak gerekli Öğe, devamlılık kümesindeyken sağlanmalıdır. Milisaniye cinsinden süre.
Son oynatma konumu zamanı Koşula bağlı olarak gerekli Öğe, Devam kümesindeyken ve WatchNextType CONTINUE olduğunda sağlanmalıdır. Milisaniye cinsinden süre.

LiveStreamingVideoEntity

Özellik Şartlar Notlar
Ad Zorunlu
Poster resimleri Zorunlu En az bir resim gereklidir ve en boy oranıyla birlikte sağlanmalıdır. (Yatay resimler tercih edilir ancak farklı senaryolar için hem dikey hem de yatay resimler göndermeniz önerilir.)

Yardım için Resim Özellikleri bölümüne bakın.

Oynatma URI'si Zorunlu

Videoyu oynatmaya başlamak için sağlayıcı uygulamasının derin bağlantısı.

Not: Derin bağlantıları ilişkilendirme için kullanabilirsiniz. Bu SSS'ye bakın

Yayıncı Zorunlu Serbest metin
Başlangıç zamanı İsteğe bağlı Milisaniye cinsinden süre.
Bitiş zamanı İsteğe bağlı Milisaniye cinsinden süre.
Görüntüleme sayısı İsteğe bağlı Serbest metin, yerelleştirilmelidir.
Sonraki videoyu izleme türü Koşula bağlı olarak gerekli

Öğe, Devam kümesindeyken sağlanmalı ve aşağıdaki dört türden biri olmalıdır:

DEVAM ET: Kullanıcı bu içeriği 1 dakikadan uzun süredir izliyor.

YENİ: Kullanıcı, bazı bölümlük içeriklerdeki tüm bölümleri izlemiş ancak yeni bir bölüm yayınlanmış ve tam olarak bir bölüm izlenmemiştir. Bu özellik; TV programları, bir serideki kayıtlı futbol maçları vb. için kullanılabilir.

SONRAKİ: Kullanıcı, bazı bölümlük içeriklerden bir veya daha fazla bölümün tamamını izlemiş ancak ya birden fazla bölüm ya da son bölümün "YENİ" olmadığı ve kullanıcının bölümlük içeriği izlemeye başlamadan önce yayınlandığı tek bir bölüm kalmıştır.

İZLEME LİSTESİ: Kullanıcı, bir filmi, etkinliği veya diziyi izleme listesine ekleyerek bir sonraki izlemek istediği içeriği manuel olarak seçmeyi tercih etmiştir.

Son etkileşim zamanı Koşula bağlı olarak gerekli Öğe, devamlılık kümesindeyken sağlanmalıdır. Milisaniye cinsinden süre.
Son oynatma konumu zamanı Koşula bağlı olarak gerekli Öğe, Devam kümesindeyken ve WatchNextType CONTINUE olduğunda sağlanmalıdır. Milisaniye cinsinden süre.

VideoClipEntity

VideoClipEntity nesnesi, TikTok veya YouTube gibi sosyal medyadan gelen bir video öğesini temsil eder.

Özellik Şartlar Notlar
Ad Zorunlu
Poster resimleri Zorunlu En az bir resim gereklidir ve en boy oranıyla birlikte sağlanmalıdır. (Yatay resimler tercih edilir ancak farklı senaryolar için hem dikey hem de yatay resimler göndermeniz önerilir.)

Yardım için Resim Özellikleri bölümüne bakın.

Oynatma URI'si Zorunlu

Videoyu oynatmaya başlamak için sağlayıcı uygulamasının derin bağlantısı.

Not: Derin bağlantıları ilişkilendirme için kullanabilirsiniz. Bu SSS'ye bakın

Oluşturma zamanı Zorunlu Milisaniye cinsinden süre.
Süre Zorunlu Milisaniye cinsinden pozitif bir değer olmalıdır.
İçerik üretici Zorunlu Serbest metin
İçerik üreticinin resmi İsteğe bağlı İçerik üreticinin avatarının resmi
Görüntüleme sayısı İsteğe bağlı Serbest metin, yerelleştirilmelidir.
Sonraki videoyu izleme türü Koşula bağlı olarak gerekli

Öğe, Devam kümesindeyken sağlanmalı ve aşağıdaki dört türden biri olmalıdır:

DEVAM ET: Kullanıcı bu içeriği 1 dakikadan uzun süredir izliyor.

YENİ: Kullanıcı, bazı bölümlük içeriklerdeki tüm bölümleri izlemiş ancak yeni bir bölüm yayınlanmış ve tam olarak bir bölüm izlenmemiştir. Bu özellik; TV programları, bir serideki kayıtlı futbol maçları vb. için kullanılabilir.

SONRAKİ: Kullanıcı, bazı bölümlük içeriklerden bir veya daha fazla bölümün tamamını izlemiş ancak ya birden fazla bölüm ya da son bölümün "YENİ" olmadığı ve kullanıcının bölümlük içeriği izlemeye başlamadan önce yayınlandığı tek bir bölüm kalmıştır.

İZLEME LİSTESİ: Kullanıcı, bir filmi, etkinliği veya diziyi izleme listesine ekleyerek bir sonraki izlemek istediği içeriği manuel olarak seçmeyi tercih etmiştir.

Son etkileşim zamanı Koşula bağlı olarak gerekli Öğe, devamlılık kümesindeyken sağlanmalıdır. Milisaniye cinsinden süre.
Son oynatma konumu zamanı Koşula bağlı olarak gerekli Öğe, Devam kümesindeyken ve WatchNextType CONTINUE olduğunda sağlanmalıdır. Milisaniye cinsinden süre.

Resim özellikleri

Aşağıdaki bölümde, resim öğeleri için gerekli özellikler listelenmektedir:

Dosya biçimleri

PNG, JPG, statik GIF, WebP

Maksimum dosya boyutu

5.120 KB

Ek öneriler

  • Resim güvenli alanı: Önemli içeriklerinizi yatay ve dikey yönde ortalanmış olarak resmin% 80'ini kaplayacak şekilde yerleştirin.

Örnek

Kotlin

var movie = MovieEntity.Builder()
    .setName("Avengers")
    .addPosterImage(Image.Builder()
                          .setImageUri(Uri.parse("http://www.x.com/image.png"))
                          .setImageHeightInPixel(960)
                          .setImageWidthInPixel(408)
                          .build())
    .setPlayBackUri(Uri.parse("http://tv.com/playback/1"))
    .setReleaseDateEpochMillis(1633032895L)
    .setAvailability(ContentAvailability.AVAILABILITY_AVAILABLE)
    .setDurationMillis(12345678L)
    .addGenre("action")
    .addContentRating("R")
    .setWatchNextType(WatchNextType.TYPE_NEW)
    .setLastEngagementTimeMillis(1664568895L)
    .build()

Java

MovieEntity movie = new MovieEntity.Builder()
                  .setName("Avengers")
                  .addPosterImage(
                      new Image.Builder()
                          .setImageUri(Uri.parse("http://www.x.com/image.png"))
                          .setImageHeightInPixel(960)
                          .setImageWidthInPixel(408)
                          .build())
                  .setPlayBackUri(Uri.parse("http://tv.com/playback/1"))
                  .setReleaseDateEpochMillis(1633032895L)
                  .setAvailability(ContentAvailability.AVAILABILITY_AVAILABLE)
                  .setDurationMillis(12345678L)
                  .addGenre("action")
                  .addContentRating("R")
                  .setWatchNextType(WatchNextType.TYPE_NEW)
                  .setLastEngagementTimeMillis(1664568895L)
                  .build();

2. adım: Küme verilerini sağlama

İçerik yayınlama işinin arka planda (örneğin, WorkManager kullanılarak) yürütülmesi ve düzenli olarak veya etkinlik bazında (örneğin, kullanıcı uygulamayı her açtığında ya da sepete bir ürün eklediğinde) planlanması önerilir.

AppEngagePublishClient, yayınlama kümelerinden sorumludur. İstemcide aşağıdaki API'ler kullanılabilir:

  • isServiceAvailable
  • publishRecommendationClusters
  • publishFeaturedCluster
  • publishContinuationCluster
  • publishUserAccountManagementRequest
  • updatePublishStatus
  • deleteRecommendationsClusters
  • deleteFeaturedCluster
  • deleteContinuationCluster
  • deleteUserManagementCluster
  • deleteClusters

isServiceAvailable

Bu API, hizmetin entegrasyona uygun olup olmadığını ve içeriğin cihazda sunulup sunulamayacağını kontrol etmek için kullanılır.

Kotlin

client.isServiceAvailable.addOnCompleteListener { task ->
    if (task.isSuccessful) {
        // Handle IPC call success
        if(task.result) {
          // Service is available on the device, proceed with content publish
          // calls.
        } else {
          // Service is not available, no further action is needed.
        }
    } else {
      // The IPC call itself fails, proceed with error handling logic here,
      // such as retry.
    }
}

Java

client.isServiceAvailable().addOnCompleteListener(task - > {
    if (task.isSuccessful()) {
        // Handle success
        if(task.getResult()) {
          // Service is available on the device, proceed with content publish
          // calls.
        } else {
          // Service is not available, no further action is needed.
        }
    } else {
      // The IPC call itself fails, proceed with error handling logic here,
      // such as retry.
    }
});

publishRecommendationClusters

Bu API, RecommendationCluster nesnelerinin listesini yayınlamak için kullanılır.

Kotlin

client.publishRecommendationClusters(
      PublishRecommendationClustersRequest.Builder()
        .addRecommendationCluster(
          RecommendationCluster.Builder()
            .addEntity(entity1)
            .addEntity(entity2)
            .setTitle("Top Picks For You")
            .build()
        )
        .build()
    )

Java

client.publishRecommendationClusters(
            new PublishRecommendationClustersRequest.Builder()
                .addRecommendationCluster(
                    new RecommendationCluster.Builder()
                        .addEntity(entity1)
                        .addEntity(entity2)
                        .setTitle("Top Picks For You")
                        .build())
                .build());

Hizmet isteği aldığında tek bir işlemde aşağıdaki işlemler gerçekleşir:

  • Geliştirici iş ortağından alınan mevcut RecommendationCluster verileri kaldırılır.
  • İstekten gelen veriler ayrıştırılır ve güncellenen RecommendationCluster'da depolanır.

Hata durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

publishFeaturedCluster

Bu API, FeaturedCluster nesnelerinin listesini yayınlamak için kullanılır.

Kotlin

client.publishFeaturedCluster(
    PublishFeaturedClusterRequest.Builder()
      .setFeaturedCluster(
        FeaturedCluster.Builder()
          .addEntity(entity1)
          .addEntity(entity2)
          .build())
      .build())

Java

client.publishFeaturedCluster(
            new PublishFeaturedClustersRequest.Builder()
                .addFeaturedCluster(
                    new FeaturedCluster.Builder()
                        .addEntity(entity1)
                        .addEntity(entity2)
                        .build())
                .build());

Hizmet isteği aldığında tek bir işlemde aşağıdaki işlemler gerçekleşir:

  • Geliştirici iş ortağından alınan mevcut FeaturedCluster verileri kaldırılır.
  • İstekten gelen veriler ayrıştırılır ve güncellenen Öne Çıkan Küme'de saklanır.

Hata durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

publishContinuationCluster

Bu API, ContinuationCluster nesnesini yayınlamak için kullanılır.

Kotlin

client.publishContinuationCluster(
    PublishContinuationClusterRequest.Builder()
      .setContinuationCluster(
        ContinuationCluster.Builder()
          .addEntity(entity1)
          .addEntity(entity2)
          .build())
      .build())

Java

client.publishContinuationCluster(
            new PublishContinuationClusterRequest.Builder()
                .setContinuationCluster(
                    new ContinuationCluster.Builder()
                        .addEntity(entity1)
                        .addEntity(entity2)
                        .build())
                .build());

Hizmet isteği aldığında tek bir işlemde aşağıdaki işlemler gerçekleşir:

  • Geliştirici iş ortağından alınan mevcut ContinuationCluster verileri kaldırılır.
  • İstekten gelen veriler ayrıştırılır ve güncellenen Continuation Cluster'da depolanır.

Hata durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

publishUserAccountManagementRequest

Bu API, oturum açma kartı yayınlamak için kullanılır . Oturum açma işlemi, kullanıcıları uygulamanın oturum açma sayfasına yönlendirir. Böylece uygulama, içerik yayınlayabilir (veya daha kişiselleştirilmiş içerikler sunabilir).

Aşağıdaki meta veriler, oturum açma kartının bir parçasıdır:

Özellik Şartlar Açıklama
İşlem URI'si Zorunlu İşleme derin bağlantı (ör. uygulama oturum açma sayfasına yönlendirir)
Resim İsteğe bağlıdır. Bu alan sağlanmazsa Başlık alanı sağlanmalıdır.

Kartta Gösterilen Resim

1264x712 çözünürlüğünde 16:9 en boy oranına sahip resimler

Başlık İsteğe bağlıdır. Sağlanmazsa resim sağlanmalıdır. Kart üzerindeki başlık
İşlem Metni İsteğe bağlı CTA'da gösterilen metin (ör. Oturum aç)
Alt başlık İsteğe bağlı Kartta İsteğe Bağlı Altyazı

Kotlin

var SIGN_IN_CARD_ENTITY =
      SignInCardEntity.Builder()
          .addPosterImage(
              Image.Builder()
                  .setImageUri(Uri.parse("http://www.x.com/image.png"))
                  .setImageHeightInPixel(500)
                  .setImageWidthInPixel(500)
                  .build())
          .setActionText("Sign In")
          .setActionUri(Uri.parse("http://xx.com/signin"))
          .build()

client.publishUserAccountManagementRequest(
            PublishUserAccountManagementRequest.Builder()
                .setSignInCardEntity(SIGN_IN_CARD_ENTITY)
                .build());

Java

SignInCardEntity SIGN_IN_CARD_ENTITY =
      new SignInCardEntity.Builder()
          .addPosterImage(
              new Image.Builder()
                  .setImageUri(Uri.parse("http://www.x.com/image.png"))
                  .setImageHeightInPixel(500)
                  .setImageWidthInPixel(500)
                  .build())
          .setActionText("Sign In")
          .setActionUri(Uri.parse("http://xx.com/signin"))
          .build();

client.publishUserAccountManagementRequest(
            new PublishUserAccountManagementRequest.Builder()
                .setSignInCardEntity(SIGN_IN_CARD_ENTITY)
                .build());

Hizmet isteği aldığında tek bir işlemde aşağıdaki işlemler gerçekleşir:

  • Geliştirici iş ortağından alınan mevcut UserAccountManagementCluster verileri kaldırılır.
  • İstekten gelen veriler ayrıştırılır ve güncellenen UserAccountManagementCluster kümesinde depolanır.

Hata durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

updatePublishStatus

Herhangi bir dahili ticari nedenden dolayı kümelerin hiçbiri yayınlanmıyorsa updatePublishStatus API'sini kullanarak yayın durumunu güncellemenizi önemle tavsiye ederiz. Bu önemlidir, çünkü :

  • İçerik yayınlanmış olsa bile (STATUS == PUBLISHED) tüm senaryolarda durumu sağlamak, entegrasyonunuzun durumunu ve diğer metriklerini iletmek için bu açık durumu kullanan kontrol panellerini doldurmak açısından kritik öneme sahiptir.
  • İçerik yayınlanmamış ancak entegrasyon durumu bozulmamışsa (STATUS == NOT_PUBLISHED), Google, uygulama sağlığı kontrol panellerinde uyarı tetiklemeyi önleyebilir. İçeriğin, sağlayıcının bakış açısıyla beklenen bir durum nedeniyle yayınlanmadığını onaylar.
  • Geliştiricilerin, verilerin ne zaman yayınlandığına dair analizler sunmasına yardımcı olur.
  • Google, kullanıcıyı uygulamada belirli işlemleri yapmaya yönlendirmek için durum kodlarını kullanabilir. Böylece kullanıcılar uygulama içeriğini görebilir veya sorunu aşabilir.

Uygun yayın durumu kodlarının listesi :

// Content is published
AppEngagePublishStatusCode.PUBLISHED,

// Content is not published as user is not signed in
AppEngagePublishStatusCode.NOT_PUBLISHED_REQUIRES_SIGN_IN,

// Content is not published as user is not subscribed
AppEngagePublishStatusCode.NOT_PUBLISHED_REQUIRES_SUBSCRIPTION,

// Content is not published as user location is ineligible
AppEngagePublishStatusCode.NOT_PUBLISHED_INELIGIBLE_LOCATION,

// Content is not published as there is no eligible content
AppEngagePublishStatusCode.NOT_PUBLISHED_NO_ELIGIBLE_CONTENT,

// Content is not published as the feature is disabled by the client
// Available in v1.3.1
AppEngagePublishStatusCode.NOT_PUBLISHED_FEATURE_DISABLED_BY_CLIENT,

// Content is not published as the feature due to a client error
// Available in v1.3.1
AppEngagePublishStatusCode.NOT_PUBLISHED_CLIENT_ERROR,

// Content is not published as the feature due to a service error
// Available in v1.3.1
AppEngagePublishStatusCode.NOT_PUBLISHED_SERVICE_ERROR,

// Content is not published due to some other reason
// Reach out to engage-developers@ before using this enum.
AppEngagePublishStatusCode.NOT_PUBLISHED_OTHER

İçerik, oturum açmamış bir kullanıcı nedeniyle yayınlanmıyorsa Google, oturum açma kartının yayınlanmasını önerir. Sağlayıcılar herhangi bir nedenle oturum açma kartını yayınlayamıyorsa updatePublishStatus API'sinin NOT_PUBLISHED_REQUIRES_SIGN_IN durum koduyla çağrılması önerilir.

Kotlin

client.updatePublishStatus(
   PublishStatusRequest.Builder()
     .setStatusCode(AppEngagePublishStatusCode.NOT_PUBLISHED_REQUIRES_SIGN_IN)
     .build())

Java

client.updatePublishStatus(
    new PublishStatusRequest.Builder()
        .setStatusCode(AppEngagePublishStatusCode.NOT_PUBLISHED_REQUIRES_SIGN_IN)
        .build());

deleteRecommendationClusters

Bu API, Öneri Grupları'nın içeriğini silmek için kullanılır.

Kotlin

client.deleteRecommendationClusters()

Java

client.deleteRecommendationClusters();

Hizmet isteği aldığında mevcut verileri Öneri Kümeleri'nden kaldırır. Hata durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

deleteFeaturedCluster

Bu API, Öne Çıkan Küme'nin içeriğini silmek için kullanılır.

Kotlin

client.deleteFeaturedCluster()

Java

client.deleteFeaturedCluster();

Hizmet isteği aldığında mevcut verileri Öne Çıkan Küme'den kaldırır. Hata durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

deleteContinuationCluster

Bu API, devam ettirme kümesinin içeriğini silmek için kullanılır.

Kotlin

client.deleteContinuationCluster()

Java

client.deleteContinuationCluster();

Hizmet, isteği aldığında mevcut verileri devamlılık kümesinden kaldırır. Hata durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

deleteUserManagementCluster

Bu API, UserAccountManagement kümesinin içeriğini silmek için kullanılır.

Kotlin

client.deleteUserManagementCluster()

Java

client.deleteUserManagementCluster();

Hizmet isteği aldığında mevcut verileri UserAccountManagement kümesinden kaldırır. Hata durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

deleteClusters

Bu API, belirli bir küme türünün içeriğini silmek için kullanılır.

Kotlin

client.deleteClusters(
    DeleteClustersRequest.Builder()
      .addClusterType(ClusterType.TYPE_CONTINUATION)
      .addClusterType(ClusterType.TYPE_FEATURED)
      .addClusterType(ClusterType.TYPE_RECOMMENDATION)
      .build())

Java

client.deleteClusters(
            new DeleteClustersRequest.Builder()
                .addClusterType(ClusterType.TYPE_CONTINUATION)
                .addClusterType(ClusterType.TYPE_FEATURED)
                .addClusterType(ClusterType.TYPE_RECOMMENDATION)
                .build());

Hizmet isteği aldığında, belirtilen küme türleriyle eşleşen tüm kümelerdeki mevcut verileri kaldırır. İstemciler bir veya daha fazla küme türü iletmeyi seçebilir. Hata durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

Hata işleme

Başarılı bir görevi kurtarmak ve yeniden göndermek için takip işlemi yapılabilmesi amacıyla, yayınlama API'lerinden gelen görev sonucunu dinlemeniz önemle tavsiye edilir.

Kotlin

client.publishRecommendationClusters(
        PublishRecommendationClustersRequest.Builder()
          .addRecommendationCluster(..)
          .build())
      .addOnCompleteListener { task ->
        if (task.isSuccessful) {
          // do something
        } else {
          val exception = task.exception
          if (exception is AppEngageException) {
            @AppEngageErrorCode val errorCode = exception.errorCode
            if (errorCode == AppEngageErrorCode.SERVICE_NOT_FOUND) {
              // do something
            }
          }
        }
      }

Java

client.publishRecommendationClusters(
              new PublishRecommendationClustersRequest.Builder()
                  .addRecommendationCluster(...)
                  .build())
          .addOnCompleteListener(
              task -> {
                if (task.isSuccessful()) {
                  // do something
                } else {
                  Exception exception = task.getException();
                  if (exception instanceof AppEngageException) {
                    @AppEngageErrorCode
                    int errorCode = ((AppEngageException) exception).getErrorCode();
                    if (errorCode == AppEngageErrorCode.SERVICE_NOT_FOUND) {
                      // do something
                    }
                  }
                }
              });

Hata, nedenini içeren bir AppEngageException olarak döndürülür.

Hata kodu Hata adı Not
1 SERVICE_NOT_FOUND Hizmet, belirtilen cihazda kullanılamıyor.
2 SERVICE_NOT_AVAILABLE Hizmet, söz konusu cihazda kullanılabilir ancak arama sırasında kullanılamaz (örneğin, açıkça devre dışı bırakılmıştır).
3 SERVICE_CALL_EXECUTION_FAILURE İş parçacığı sorunları nedeniyle görev yürütme başarısız oldu. Bu durumda, işlem yeniden denenebilir.
4 SERVICE_CALL_PERMISSION_DENIED Arayan kullanıcının hizmet çağrısı yapmasına izin verilmiyor.
5 SERVICE_CALL_INVALID_ARGUMENT İstek geçersiz veriler içeriyor (örneğin, izin verilen küme sayısından daha fazla).
6 SERVICE_CALL_INTERNAL Hizmet tarafında bir hata var.
7 SERVICE_CALL_RESOURCE_EXHAUSTED Hizmet çağrısı çok sık yapılıyor.

3. adım: Yayın amaçlarını işleme

İçerik yayınlama API çağrılarını bir iş aracılığıyla yapmanın yanı sıra, içerik yayınlama isteğini almak için bir BroadcastReceiver oluşturmanız da gerekir.

Yayın niyetlerinin temel amacı, uygulamayı yeniden etkinleştirmek ve veri senkronizasyonunu zorlamaktır. Yayın amaçları çok sık gönderilmek üzere tasarlanmamıştır. Bu özellik yalnızca Engage Hizmeti, içeriğin eski olabileceğini (örneğin, bir haftalık) belirlediğinde tetiklenir. Bu sayede, uygulama uzun süredir çalıştırılmamış olsa bile kullanıcının yeni bir içerik deneyimi yaşayabileceğine dair daha fazla güven duyulur.

BroadcastReceiver aşağıdaki iki şekilde ayarlanmalıdır:

  • BroadcastReceiver sınıfının bir örneğini Context.registerReceiver() kullanarak dinamik olarak kaydedin. Bu, bellekte hâlâ etkin olan uygulamalardan iletişime izin verir.

Kotlin

class AppEngageBroadcastReceiver : BroadcastReceiver(){
  // Trigger recommendation cluster publish when PUBLISH_RECOMMENDATION broadcast
  // is received
  // Trigger featured cluster publish when PUBLISH_FEATURED broadcast is received
  // Trigger continuation cluster publish when PUBLISH_CONTINUATION broadcast is
  // received
}

fun registerBroadcastReceivers(context: Context){
  var  context = context
  context = context.applicationContext

// Register Recommendation Cluster Publish Intent
  context.registerReceiver(AppEngageBroadcastReceiver(),
                           IntentFilter(Intents.ACTION_PUBLISH_RECOMMENDATION),
                           com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
                           /*scheduler=*/null)

// Register Featured Cluster Publish Intent
  context.registerReceiver(AppEngageBroadcastReceiver(),
                           IntentFilter(Intents.ACTION_PUBLISH_FEATURED),
                           com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
                           /*scheduler=*/null)

// Register Continuation Cluster Publish Intent
  context.registerReceiver(AppEngageBroadcastReceiver(),
                           IntentFilter(Intents.ACTION_PUBLISH_CONTINUATION),
                           com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
                           /*scheduler=*/null)
}

Java

class AppEngageBroadcastReceiver extends BroadcastReceiver {
// Trigger recommendation cluster publish when PUBLISH_RECOMMENDATION broadcast
// is received

// Trigger featured cluster publish when PUBLISH_FEATURED broadcast is received

// Trigger continuation cluster publish when PUBLISH_CONTINUATION broadcast is
// received
}

public static void registerBroadcastReceivers(Context context) {

context = context.getApplicationContext();

// Register Recommendation Cluster Publish Intent
context.registerReceiver(new AppEngageBroadcastReceiver(),
                         new IntentFilter(com.google.android.engage.service.Intents. ACTION_PUBLISH_RECOMMENDATION),
                         com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
                         /*scheduler=*/null);

// Register Featured Cluster Publish Intent
context.registerReceiver(new AppEngageBroadcastReceiver(),
                         new IntentFilter(com.google.android.engage.service.Intents.ACTION_PUBLISH_FEATURED),
                         com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
                         /*scheduler=*/null);

// Register Continuation Cluster Publish Intent
context.registerReceiver(new AppEngageBroadcastReceiver(),
                         new IntentFilter(com.google.android.engage.service.Intents.ACTION_PUBLISH_CONTINUATION),
                         com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
                         /*scheduler=*/null);

}
  • <receiver> etiketiyle bir uygulamayı AndroidManifest.xml dosyanızda statik olarak bildirin. Bu, uygulamanın çalışmadığı zamanlarda yayın amaçlarını almasına ve içeriği yayınlamasına olanak tanır.

<application>
   <receiver
      android:name=".AppEngageBroadcastReceiver"
      android:permission="com.google.android.engage.REQUEST_ENGAGE_DATA"
      android:exported="true"
      android:enabled="true">
      <intent-filter>
         <action android:name="com.google.android.engage.action.PUBLISH_RECOMMENDATION" />
      </intent-filter>
      <intent-filter>
         <action android:name="com.google.android.engage.action.PUBLISH_FEATURED" />
      </intent-filter>
      <intent-filter>
         <action android:name="com.google.android.engage.action.PUBLISH_CONTINUATION" />
      </intent-filter>
   </receiver>
</application>

Hizmet tarafından aşağıdaki amaçlar gönderilir:

  • com.google.android.engage.action.PUBLISH_RECOMMENDATION Bu amaç alındığında publishRecommendationClusters araması başlatmanız önerilir.
  • com.google.android.engage.action.PUBLISH_FEATURED Bu amaç alındığında publishFeaturedCluster araması başlatılması önerilir.
  • com.google.android.engage.action.PUBLISH_CONTINUATION Bu amaç alındığında publishContinuationCluster araması başlatılması önerilir.

Entegrasyon iş akışı

Entegrasyonunuz tamamlandıktan sonra doğrulama ile ilgili adım adım kılavuz için Engage geliştirici entegrasyonu iş akışı başlıklı makaleyi inceleyin.

SSS

SSS için Engage SDK Sık Sorulan Sorular bölümüne bakın.

İletişim

Entegrasyon işlemi sırasında sorularınız olursa engage-developers@google.com adresiyle iletişime geçin.

Sonraki adımlar

Bu entegrasyonu tamamladıktan sonraki adımlarınız şunlardır:

  • engage-developers@google.com adresine e-posta gönderin ve Google tarafından test edilmeye hazır olan entegre APK'nızı ekleyin.
  • Google, entegrasyonun beklendiği gibi çalıştığından emin olmak için doğrulama yapar ve şirket içinde inceleme gerçekleştirir. Değişiklik yapılması gerekiyorsa Google, gerekli ayrıntıları içeren bir e-posta göndererek sizinle iletişime geçer.
  • Test tamamlandığında ve herhangi bir değişiklik yapılması gerekmediğinde Google, güncellenmiş ve entegre edilmiş APK'yı Play Store'da yayınlamaya başlayabileceğinizi bildirmek için sizinle iletişime geçer.
  • Google, güncellenen APK'nızın Play Store'da yayınlandığını onayladıktan sonra Öneri, Öne Çıkanlar ve Devam kümeleriniz yayınlanabilir ve kullanıcılara gösterilebilir.