Engage SDK Health and Fitness: Üçüncü taraf teknik entegrasyon talimatları

Google, kullanıcıların uygulamalarını sektörlere göre düzenleyen ve kişiselleştirilmiş uygulama içeriği tüketimi ve keşfi için yeni bir sürükleyici deneyim sunan cihaz üzerinde bir yüzey oluşturuyor. Bu tam ekran deneyimi, geliştirici iş ortaklarına en iyi zengin içeriklerini uygulamalarının dışında özel bir kanalda sergileme fırsatı sunar. Bu kılavuzda, geliştirici iş ortaklarının bu yeni yüzey alanını doldurmak için Engage SDK'sını kullanarak sağlık ve fitness içeriklerini entegre etme talimatları yer alır.

Entegrasyon ayrıntısı

Terminoloji

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

  • Öneri kümeleri, geliştirici iş ortaklarından kişiselleştirilmiş sağlık ve fitness önerilerini gösterir. Bu öneriler kullanıcıya göre kişiselleştirilebilir veya genelleştirilebilir (örneğin, popüler fitness ve sağlık içerikleri). Sağlık ve fitness ile ilgili makaleleri veya kişileri öne çıkarmak için bu etiketleri kullanın.

    • Öneri kümesi ArticleEntity, PersonEntity veya EventEntity öğelerinden oluşabilir ancak farklı öğe türlerinin bir karışımı olamaz.

    Önerileriniz aşağıdaki yapıya sahiptir:

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

    • Varlık: Kümedeki tek bir öğeyi temsil eden nesne. Bu entegrasyon, öneri kümesi kullanılarak gösterilecek bazı öğeler sunar:

      • ArticleEntity: ArticleEntity, sağlık ve fitness ile ilgili metin tabanlı içerik önerilerini temsil eder. Makaleler, blog yayınları, pazarlama içerikleri, haber snippet'leri vb. için kullanılabilir.

        Şekil 1: Öneriler kümesinde tek bir ArticleEntity'yi gösteren kullanıcı arayüzü.
      • PersonEntity: PersonEntity bir kişiyi temsil eder. Öneriler, bir antrenörü veya sağlık ve fitness ile ilgili herhangi bir kişiyi öne çıkarmak olabilir.

        Şekil 2: Öneriler kümesinde tek bir PersonEntity'yi gösteren kullanıcı arayüzü.
      • EventEntity: EventEntity, gelecekte gerçekleşecek bir etkinliği temsil eder. Etkinlik başlangıç zamanı, kullanıcılara aktarılması gereken önemli bir bilgidir. Bu varlık kan bağışı kampı, antrenmanlar, spor salonu veya yoga dersleri gibi sağlık ve fitness ile ilgili etkinlikleri göstermek için kullanılabilir.

        Şekil 3: Öneriler kümesinde tek bir EventEntity'yi gösteren kullanıcı arayüzü.
  • Devam kümesi, tek bir kullanıcı arayüzü gruplandırmasında birden fazla geliştirici iş ortağının kullanıcıları tarafından yakın zamanda etkileşimde bulunulan içerikleri gösterir. Her geliştirici iş ortağının, Devam kümesinde en fazla 10 öğe yayınlamasına izin verilir.

    Devam içeriğiniz aşağıdaki yapıyı alabilir:

    • ArticleEntity: ArticleEntity, sağlık ve fitness ile ilgili metin tabanlı içerik önerilerini temsil eder. Bu varlık, tamamlanmamış haber makalelerini veya kullanıcının bıraktığı yerden tüketmeye devam etmek istediği diğer içerikleri temsil etmek için kullanılabilir. Ör. sağlık veya fitness ile ilgili konularda haber snippet'i, blog yayını snippet'i.

      Şekil 6. Devam kümesinde tek bir ArticleEntity'yi gösteren kullanıcı arayüzü.
    • EventReservationEntity: EventReservationEntity, bir etkinlik rezervasyonunu temsil eder ve kullanıcıların yaklaşan veya devam eden fitness ve sağlık etkinliği rezervasyonlarını izlemesine yardımcı olur. Örnek: Eğitim oturumları

      Şekil 8. Bir Continuation kümesi içinde tek bir EventReservationEntity gösteren kullanıcı arayüzü.
  • Öne Çıkan kümesi, birden fazla geliştirici iş ortağından seçilen öğeleri tek bir kullanıcı arayüzü gruplandırmasında 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 Öneriler kümelerinin üzerinde öncelikli olarak yerleştirilir. Her geliştirici iş ortağının, Öne Çıkanlar kümesinde en fazla 10 öğe yayınlamasına izin verilir.

    • GenelFeaturedEntity: Öne çıkarılan öğenin, geliştiricilerin tek bir en iyi içeriği için kullanılması ve kullanıcıların ilgi çekici ve alakalı olacak tek bir en önemli içeriği temsil etmesi açısından Öneri öğesinden farklıdır.

      Şekil 12: Öne Çıkan kümedeki tek bir hero GenericFeaturedEntity kartını gösteren kullanıcı arayüzü

Ön çalışma

Minimum API düzeyi: 19

com.google.android.engage:engage-core kitaplığını uygulamanıza 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'
}

Özet

Tasarım, bağlı hizmet uygulamasına dayanır.

İstemcilerin 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 minimum varlık sınırları Bir kümedeki maksimum varlık sınırları
Öneri Kümeleri En fazla 5 En az 5 En fazla 25 (ArticleEntity, PersonEntity veya EventEntity)
Devam Kümesi En fazla 1 En az 1 En fazla 10 (ArticleEntity veya EventReservationEntity)
Öne Çıkan Küme En fazla 1 En az 1 En fazla 10 (GenericFeaturedEntity)

1. adım: Öğe verilerini sağlayın

SDK, her öğe türünü temsil etmek için farklı öğeler tanımlamıştır. Sağlık ve Fitness kategorisinde aşağıdaki öğeler desteklenir:

  1. GenericFeaturedEntity
  2. ArticleEntity
  3. PersonEntity
  4. EventEntity
  5. EventReservationEntity

Aşağıdaki grafiklerde, her tür için kullanılabilen özellikler ve şartlar özetlenmiştir.

GenericFeaturedEntity

Özellik Şartlar Açıklama Biçim
İşlem URI'sı Zorunlu

Sağlayıcı uygulamasındaki varlığa derin bağlantı.

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

URI
Poster resimleri Zorunlu

Birden fazla resim sağlandığında yalnızca 1 resim gösterilir. Önerilen en boy oranı 16:9'dur.

Not: Rozet kullanılıyorsa lütfen resmin üst ve alt kısmında 24 dp'lik güvenli alan bırakın.

Yardım için Resim Özellikleri bölümüne bakın.
Başlık İsteğe bağlı Varlığın başlığı.

Serbest metin

Önerilen metin boyutu: 50 karakter

Açıklama İsteğe bağlı

Varlık için tek bir paragraflık metin.

Not: Kullanıcıya açıklama veya altyazı listesi gösterilir.

Serbest metin

Önerilen metin boyutu: 180 karakter

Altyazı listesi İsteğe bağlı

Her biri tek satırdan oluşan en fazla 3 altyazı.

Not: Kullanıcıya açıklama veya altyazı listesi gösterilir.

Serbest metin

Her altyazı için önerilen metin boyutu: en fazla 50 karakter

Rozetler İsteğe bağlı

Her rozet, serbest metin (en fazla 15 karakter) veya küçük resim olabilir.

Resmin/videonun üzerinde özel kullanıcı deneyimi kullanımı (ör. resmin üzerinde rozet yer paylaşımı)

  • "Canlı güncelleme"
  • Makale okuma süresi
Rozet - Metin İsteğe bağlı

Rozetin başlığı

Not: Rozet için metin veya resim gereklidir

Serbest metin

Önerilen metin boyutu: en fazla 15 karakter

Rozet - Resim İsteğe bağlı

Küçük resim

Resim/video küçük resminde rozet yer paylaşımı gibi özel kullanıcı deneyimi işlemleri.

Not: Rozet için metin veya resim gereklidir.

Yardım için Resim Özellikleri bölümüne bakın.
İçerik Kategorileri İsteğe bağlı Öğedeki içeriğin kategorisini açıklayın.

Sıralama Listesi

Rehberlik için İçerik Kategorisi bölümüne bakın.

ArticleEntity

Özellik Şartlar Açıklama Biçim
İşlem URI'sı Zorunlu

Sağlayıcı uygulamasındaki varlığa derin bağlantı.

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

URI
Başlık Zorunlu Varlığın başlığı.

Serbest metin

Önerilen metin boyutu: En fazla 50 karakter

Poster resimleri İsteğe bağlı

Birden fazla resim sağlandığında yalnızca 1 resim gösterilir. Önerilen en boy oranı 16:9'dur.

Not: Görsel eklemeniz önemle tavsiye edilir. Rozet sağlanıyorsa lütfen resmin üst ve alt kısmında 24 dp'lik güvenli alan bırakın

Yardım için Resim Özellikleri bölümüne bakın.
Kaynak - Başlık İsteğe bağlı Yazarın, kuruluşun veya muhabirin adı

Serbest metin

Önerilen metin boyutu: 25 karakterden kısa

Kaynak - Resim İsteğe bağlı Yazar, kuruluş, muhabir gibi kaynağın resmi Yardım için Resim Özellikleri bölümüne bakın.
Açıklama İsteğe bağlı

Varlık için tek bir paragraflık metin.

Not: Kullanıcıya açıklama veya altyazı listesi gösterilir.

Serbest metin

Önerilen metin boyutu: 180 karakter

Altyazı listesi İsteğe bağlı

Her biri tek satırdan oluşan en fazla 3 altyazı.

Not: Kullanıcıya açıklama veya altyazı listesi gösterilir.

Serbest metin

Her altyazı için önerilen metin boyutu: en fazla 50 karakter

Rozetler İsteğe bağlı

Her rozet, serbest metin (en fazla 15 karakter) veya küçük resim olabilir.

Resmin/videonun üzerinde özel kullanıcı deneyimi kullanımı (ör. resmin üzerinde rozet yer paylaşımı)

  • "Canlı güncelleme"
  • Makale okuma süresi
Rozet - Metin İsteğe bağlı

Rozetin başlığı

Not: Rozet için metin veya resim gereklidir

Serbest metin

Önerilen metin boyutu: en fazla 15 karakter

Rozet - Resim İsteğe bağlı

Küçük resim

Resim/video küçük resminde rozet yer paylaşımı gibi özel kullanıcı deneyimi işlemleri.

Not: Rozet için metin veya resim gereklidir

Yardım için Resim Özellikleri bölümüne bakın.
İçerik Yayınlama Zamanı İsteğe bağlı Bu, içeriğin uygulamada yayınlandığı/güncellendiği zamanın milisaniye cinsinden çağ zaman damgası. Milisaniye cinsinden Unix sıfır zaman damgası
Son Etkileşim Zamanı Koşullu Zorunlu

Kullanıcının bu öğeyle son etkileşimde bulunduğu zamanın milisaniye cinsinden çağ zaman damgası.

Not: Bu varlık devam kümesinin bir parçasıysa bu alan zorunludur.

Milisaniye cinsinden Epoch zaman damgası
İlerleme Yüzdesi Koşullu Zorunlu

Bugüne kadar kullanıcı tarafından tüketilen tam içeriğin yüzdesi.

Not: Bu varlık devam kümesinin bir parçasıysa bu alan zorunludur.

0 ile 100 arasında (0 ve 100 dahil) bir tam sayı.
İçerik Kategorileri İsteğe bağlı Öğedeki içeriğin kategorisini açıklayın.

Sıralamalar listesi

Yol gösterici bilgiler için İçerik Kategorisi bölümüne bakın.

PersonEntity

Özellik Şartlar Açıklama Biçim
İşlem URI'sı Zorunlu

Sağlayıcı uygulamasındaki varlığa derin bağlantı.

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

URI
Profil - Ad Zorunlu Profil adı veya kimliği ya da herkese açık kullanıcı adı (ör. "Can Doğru", "@TeamPixel" vb.)

Dize

Önerilen metin boyutu: Maksimum 50 karakter

Profil - Avatar Zorunlu

Kullanıcının profil resmi veya avatar resmi.

Not: Kare 1:1 resim olmalıdır.

Yardım için Resim Özellikleri bölümüne bakın.
Profil - Ek Metin İsteğe bağlı Profil herkese açık kullanıcı adı gibi serbest metin.

Serbest metin

Önerilen metin boyutu: En fazla 15 karakter

Profil - Ek Resim İsteğe bağlı Doğrulanmış rozet gibi küçük resim. Yardım için Resim Özellikleri bölümüne bakın.
Başlık resmi İsteğe bağlı

Birden fazla resim sağlandığında yalnızca 1 resim gösterilir. Önerilen en boy oranı 16:9'dur.

Not: Resim kesinlikle önerilir. Rozet sağlanıyorsa lütfen resmin üst ve alt kısmında 24 dp'lik güvenli alan bırakın

Yardım için Resim Özellikleri bölümüne bakın.
Popülerlik - Sayı İsteğe bağlı

Takipçi sayısını veya popülerlik değerini belirtin. Örneğin: "3,7 M".

Not: Hem Count hem de Count Value sağlanırsa Count kullanılır.

Dize

Önerilen metin boyutu: sayı + etiket için en fazla 20 karakter

Popülerlik - Sayı Değeri İsteğe bağlı

Takipçi sayısı veya popülerlik değeri.

Not: Uygulamanız, büyük bir sayının farklı ekran boyutları için nasıl optimize edilmesi gerektiğine dair mantığı işlemek istemiyorsa Sayı Değeri'ni sağlayın. Hem Sayı hem de Sayı Değeri sağlanırsa Sayı kullanılır.

Uzun
Popülerlik - Etiket İsteğe bağlı Popülerlik etiketinin ne olduğunu belirtin (ör. "Beğenilenler").

Dize

Önerilen metin boyutu: Sayı + etiket için en fazla 20 karakter

Popülerlik - Görsel İsteğe bağlı

Etkileşimin neyle ilgili olduğunu belirtin. Örneğin: Beğenme simgesini ve emojileri gösteren resim.

1'den fazla resim sağlayabilirsiniz ancak bunların hepsi tüm form faktörlerinde gösterilmeyebilir.

Not: Kare 1:1 resim olmalıdır.

Yardım için Resim Özellikleri bölümüne bakın.
Derecelendirme - Maksimum değer Zorunlu

Derecelendirme ölçeğinin maksimum değeri.

Derecelendirmenin mevcut değeri de sağlanıyorsa sağlanmalıdır.

Sayı >= 0,0
Derecelendirme - Mevcut değer Zorunlu

Derecelendirme ölçeğinin mevcut değeri.

Derecelendirmenin maksimum değeri de sağlanıyorsa sağlanmalıdır.

Sayı >= 0,0
Derecelendirme - Sayı İsteğe bağlı

Öğenin aldığı puanların sayısı.

Not: Uygulamanız sayının kullanıcılara nasıl gösterileceğini kontrol ediyorsa bu alanı sağlayın. Özet bir dize kullanın. Örneğin, sayı 1.000.000 ise sayının daha küçük ekran boyutlarında kısaltılmaması için 1M gibi bir kısaltma kullanabilirsiniz.

Dize
Derecelendirme - Sayı Değeri İsteğe bağlı

Öğenin aldığı puanların sayısı.

Not: Ekran kısaltması mantığını kendiniz siz yönetmiyorsanız bu alanı sağlayın. Hem Sayı hem de Sayı Değeri varsa kullanıcılara Sayı gösterilir.

Uzun
Konum - Ülke İsteğe bağlı Kullanıcının bulunduğu veya hizmet verdiği ülke.

Serbest metin

Önerilen metin boyutu: Maksimum ~20 karakter

Konum - Şehir İsteğe bağlı Kişinin bulunduğu veya hizmet verdiği şehir.

Serbest metin

Önerilen metin boyutu: en fazla 20 karakter

Konum - Görünen Adres İsteğe bağlı Kullanıcının bulunduğu veya reklam yayınladığı adres kullanıcıya gösterilir.

Serbest metin

Önerilen metin boyutu: en fazla 20 karakter

Konum - Açık Adres İsteğe bağlı Kişinin bulunduğu veya hizmet verdiği açık adres (varsa).

Serbest metin

Önerilen metin boyutu: Maksimum ~20 karakter

Konum - Eyalet İsteğe bağlı Kullanıcının bulunduğu veya hizmet verdiği eyalet (varsa).

Serbest metin

Önerilen metin boyutu: en fazla 20 karakter

Konum - Posta kodu İsteğe bağlı Kullanıcının bulunduğu veya hizmet verdiği posta kodu (varsa).

Serbest metin

Önerilen metin boyutu: en fazla 20 karakter

Konum - Mahalle İsteğe bağlı Kişinin bulunduğu veya hizmet verdiği mahalle (varsa).

Serbest metin

Önerilen metin boyutu: en fazla 20 karakter

Rozetler İsteğe bağlı

Her rozet, serbest metin (maks. 15 karakter) veya küçük resimdir.

Rozet - Metin İsteğe bağlı

Rozetin başlığı

Not: Rozet için metin veya resim gereklidir

Serbest metin

Önerilen metin boyutu: en fazla 15 karakter

Rozet - Resim İsteğe bağlı

Küçük resim

Resim/video küçük resminde rozet yer paylaşımı gibi özel kullanıcı deneyimi işlemleri.

Not: Rozet için metin veya resim gereklidir.

Yardım için Resim Özellikleri bölümüne bakın.
Açıklama İsteğe bağlı

Varlık için tek bir paragraflık metin.

Not: Kullanıcıya açıklama veya altyazı listesi gösterilir.

Serbest metin

Önerilen metin boyutu: 180 karakter

Altyazı listesi İsteğe bağlı

Her biri tek satırdan oluşan en fazla 3 altyazı.

Not: Kullanıcıya açıklama veya altyazı listesi gösterilir.

Serbest metin

Her altyazı için önerilen metin boyutu: en fazla 50 karakter

İçerik Kategorileri İsteğe bağlı Öğedeki içeriğin kategorisini açıklayın.

Uygun enumların listesi

  • TYPE_HEALTH_AND_FITENESS (Örnek: Yoga/fitness eğitmeni)
  • TYPE_HOME_AND_AUTO (Örnek: Tesisatçı)
  • TYPE_SPORTS (Örnek: Oyuncu)
  • TYPE_DATING

Rehberlik için İçerik Kategorisi bölümüne bakın.

EventEntity

Özellik Şartlar Açıklama Biçim
İşlem URI'sı Zorunlu

Sağlayıcı uygulamasındaki varlığa derin bağlantı.

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

URI
Başlık Zorunlu Varlığın başlığı.

Dize

Önerilen metin boyutu: En fazla 50 karakter

Başlangıç zamanı Zorunlu

Etkinliğin başlaması beklenen epoch zaman damgası.

Not: Bu değer milisaniye cinsinden gösterilir.

Milisaniye cinsinden Epoch zaman damgası
Etkinlik modu Zorunlu

Etkinliğin sanal, yüz yüze veya her ikisi olacağını belirten bir alan.

Liste: VIRTUAL, IN_PERSON veya HYBRID
Poster resimleri Zorunlu

Birden fazla resim sağlandığında yalnızca 1 resim gösterilir. Önerilen en boy oranı 16:9'dur.

Not: Resim kesinlikle önerilir. Rozet sağlanıyorsa lütfen resmin üst ve alt kısmında 24 dp'lik güvenli alan bırakın

Yardım için Resim Özellikleri bölümüne bakın.
Konum - Ülke Koşullu Zorunlu

Etkinliğin gerçekleştiği ülke.

Not: Bu, IN_PERSON veya HYBRID olan etkinlikler için gereklidir

Serbest metin

Önerilen metin boyutu: Maksimum ~20 karakter

Konum - Şehir Koşullu Zorunlu

Etkinliğin gerçekleştiği şehir.

Not: Bu, IN_PERSON veya HYBRID olan etkinlikler için gereklidir

Serbest metin

Önerilen metin boyutu: en fazla 20 karakter

Konum - Görünen Adres Koşullu Zorunlu

Etkinliğin gerçekleşeceği adres veya mekan adı. Bu ad kullanıcıya gösterilmelidir.

Not: Bu, IN_PERSON veya HYBRID olan etkinlikler için gereklidir.

Serbest metin

Önerilen metin boyutu: en fazla 20 karakter

Konum - Açık Adres İsteğe bağlı Etkinliğin düzenlendiği konumun sokak adresi (varsa).

Serbest metin

Önerilen metin boyutu: Maksimum ~20 karakter

Konum - Eyalet İsteğe bağlı Etkinliğin düzenlendiği eyalet veya il (varsa).

Serbest metin

Önerilen metin boyutu: en fazla 20 karakter

Konum - Posta kodu İsteğe bağlı Etkinliğin düzenlendiği konumun posta kodu (varsa).

Serbest metin

Önerilen metin boyutu: en fazla 20 karakter

Konum - Mahalle İsteğe bağlı Etkinliğin düzenlendiği mahalle (varsa).

Serbest metin

Önerilen metin boyutu: en fazla 20 karakter

Bitiş zamanı İsteğe bağlı

Etkinliğin sona ermesinin beklendiği çağ zaman damgası.

Not: Bu değer, milisaniye cinsinden gösterilir.

Milisaniye cinsinden Unix sıfır zaman damgası
Açıklama İsteğe bağlı

Varlık için tek bir paragraflık metin.

Not: Kullanıcıya açıklama veya altyazı listesi gösterilir.

Serbest metin

Önerilen metin boyutu: 180 karakter

Altyazı listesi İsteğe bağlı

Her biri tek satırdan oluşan en fazla 3 altyazı.

Not: Kullanıcıya açıklama veya altyazı listesi gösterilir.

Serbest metin

Her altyazı için önerilen metin boyutu: en fazla 50 karakter

Rozetler İsteğe bağlı

Her rozet, serbest metin (maks. 15 karakter) veya küçük resimdir.

Rozet - Metin İsteğe bağlı

Rozetin başlığı

Not: Rozet için metin veya resim gereklidir

Serbest metin

Önerilen metin boyutu: en fazla 15 karakter

Rozet - Resim İsteğe bağlı

Küçük resim

Resim/video küçük resminde rozet yer paylaşımı gibi özel kullanıcı deneyimi işlemleri.

Not: Rozet için metin veya resim gereklidir.

Yardım için Resim Özellikleri'ne bakın.
Fiyat - CurrentPrice Koşullu olarak zorunlu

Etkinlik biletinin/geçişinin mevcut fiyatı.

Üstü çizili fiyat sağlanıyorsa belirtilmelidir.

Serbest metin
Fiyat - Üstü Çizili Fiyat İsteğe bağlı Etkinlik biletinin/kartın orijinal fiyatı. Serbest metin
Fiyat Açıklama Metni İsteğe bağlı Promosyon, etkinlik veya üye indirimi (varsa) içeren fiyat açıklama metni.

Serbest metin

Önerilen metin boyutu: 45 karakterden kısa (Çok uzun metinlerde üç nokta gösterilebilir)

İçerik Kategorileri İsteğe bağlı Öğedeki içeriğin kategorisini açıklayın.

Uygun Sıralamaların Listesi

  • TYPE_MOVIES_AND_TV_SHOWS (Örnek: Sinema)
  • TYPE_DIGITAL_GAMES (Örnek: Espor)
  • TYPE_MUSIC (Örnek: Konser)
  • TYPE_TRAVEL_AND_LOCAL (Örnek: Tur, festival)
  • TYPE_HEALTH_AND_FITENESS (Örnek: Yoga dersi)
  • TYPE_EDUCATION (Örnek: Sınıf)
  • TYPE_SPORTS (Örnek: Futbol maçı)
  • TYPE_DATING (Örnek: buluşma)

Rehberlik için İçerik Kategorisi bölümüne bakın.

EventReservationEntity

Özellik Şartlar Açıklama Biçim
İşlem URI'sı Zorunlu

Sağlayıcı uygulamasındaki varlığa derin bağlantı.

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

URI
Başlık Zorunlu Varlığın başlığı.

Dize

Önerilen metin boyutu: En fazla 50 karakter

Başlangıç zamanı Zorunlu

Etkinliğin başlaması beklenen epoch zaman damgası.

Not: Bu değer milisaniye cinsinden gösterilir.

Milisaniye cinsinden Epoch zaman damgası
Etkinlik modu Zorunlu

Etkinliğin sanal, yüz yüze veya her ikisi olacağını belirten bir alan.

Liste: VIRTUAL, IN_PERSON veya HYBRID
Konum - Ülke Koşullu Zorunlu

Etkinliğin gerçekleştiği ülke.

Not: Bu, IN_PERSON veya HYBRID olan etkinlikler için gereklidir

Serbest metin

Önerilen metin boyutu: Maksimum ~20 karakter

Konum - Şehir Koşullu Zorunlu

Etkinliğin gerçekleştiği şehir.

Not: Bu, IN_PERSON veya HYBRID olan etkinlikler için gereklidir

Serbest metin

Önerilen metin boyutu: en fazla 20 karakter

Konum - Görünen Adres Koşullu Zorunlu

Etkinliğin gerçekleşeceği adres veya mekan adı. Bu ad kullanıcıya gösterilmelidir.

Not: Bu, IN_PERSON veya HYBRID olan etkinlikler için gereklidir.

Serbest metin

Önerilen metin boyutu: en fazla 20 karakter

Konum - Açık Adres İsteğe bağlı Etkinliğin düzenlendiği konumun sokak adresi (varsa).

Serbest metin

Önerilen metin boyutu: Maksimum ~20 karakter

Konum - Eyalet İsteğe bağlı Etkinliğin düzenlendiği eyalet veya il (varsa).

Serbest metin

Önerilen metin boyutu: en fazla 20 karakter

Konum - Posta kodu İsteğe bağlı Etkinliğin düzenlendiği konumun posta kodu (varsa).

Serbest metin

Önerilen metin boyutu: en fazla 20 karakter

Konum - Mahalle İsteğe bağlı Etkinliğin düzenlendiği mahalle (varsa).

Serbest metin

Önerilen metin boyutu: en fazla 20 karakter

Poster resimleri İsteğe bağlı

Birden fazla resim sağlandığında yalnızca 1 resim gösterilir. Önerilen en boy oranı 16:9'dur.

Not: Resim kesinlikle önerilir. Rozet sağlanırsa lütfen resmin hem üst hem de alt kısmında 24 d/sn güvenli bir alan bırakın

Yardım için Resim Özellikleri'ne bakın.
Bitiş zamanı İsteğe bağlı

Etkinliğin sona ermesinin beklendiği çağ zaman damgası.

Not: Bu değer, milisaniye cinsinden gösterilir.

Milisaniye cinsinden Unix sıfır zaman damgası
Servis Sağlayıcı - Ad İsteğe bağlı

Servis sağlayıcının adı.

Not: Servis sağlayıcı için metin veya resim gereklidir.

Serbest metin. Örneğin, etkinlik düzenleyenin/turun adı
Servis Sağlayıcı - Resim İsteğe bağlı

Servis sağlayıcının logosu/resmi.

Not: Servis sağlayıcı için metin veya resim gereklidir.

Yardım için Resim Özellikleri bölümüne bakın.
Açıklama İsteğe bağlı

Varlık için tek bir paragraflık metin.

Not: Kullanıcıya açıklama veya altyazı listesi gösterilir.

Serbest metin

Önerilen metin boyutu: 180 karakter

Altyazı listesi İsteğe bağlı

Her biri tek satırdan oluşan en fazla 3 altyazı.

Not: Kullanıcıya açıklama veya altyazı listesi gösterilir.

Serbest metin

Her altyazı için önerilen metin boyutu: en fazla 50 karakter

Rozetler İsteğe bağlı

Her rozet, serbest metin (maks. 15 karakter) veya küçük resimdir.

Rozet - Metin İsteğe bağlı

Rozetin başlığı

Not: Rozet için metin veya resim gereklidir

Serbest metin

Önerilen metin boyutu: en fazla 15 karakter

Rozet - Resim İsteğe bağlı

Küçük resim

Resim/video küçük resminde rozet yer paylaşımı gibi özel kullanıcı deneyimi işlemleri.

Not: Rozet için metin veya resim gereklidir.

Yardım için Resim Özellikleri'ne bakın.
Rezervasyon kimliği İsteğe bağlı Etkinlik rezervasyonunun rezervasyon kimliği. Serbest metin
Fiyat - CurrentPrice Koşullu olarak zorunlu

Etkinlik biletinin/geçişinin mevcut fiyatı.

Üstü çizili fiyat sağlanıyorsa belirtilmelidir.

Serbest metin
Fiyat - Üstü Çizili Fiyat İsteğe bağlı Etkinlik biletinin/kartın orijinal fiyatı. Serbest metin
Fiyat Açıklama Metni İsteğe bağlı Promosyon, etkinlik veya üye indirimi (varsa) içeren fiyat açıklama metni.

Serbest metin

Önerilen metin boyutu: 45 karakterden kısa (Çok uzun metinde üç nokta gösterilebilir)

Derecelendirme - Maksimum değer İsteğe bağlı

Derecelendirme ölçeğinin maksimum değeri.

Derecelendirmenin mevcut değeri de sağlanıyorsa sağlanmalıdır.

Sayı >= 0,0
Puan - Geçerli değer İsteğe bağlı

Derecelendirme ölçeğinin mevcut değeri.

Derecelendirmenin maksimum değeri de sağlanıyorsa sağlanmalıdır.

Sayı >= 0,0
Derecelendirme - Sayı İsteğe bağlı

Etkinliğin puanlarının sayısı.

Not: Uygulamanız bu öğenin kullanıcılara nasıl gösterileceğini kontrol etmek istiyorsa bu alanı sağlayın. Lütfen kullanıcıya gösterilebilecek kısa bir dize sağlayın. Örneğin, sayı 1.000.000 ise daha küçük ekran boyutlarında kısaltılmaması için 1M gibi kısaltmalar kullanabilirsiniz.

Dize
Derecelendirme - Sayı Değeri İsteğe bağlı

Etkinliğin puanlarının sayısı.

Not: Gösterim kısaltması mantığını kendiniz yönetmek istemiyorsanız bu alanı sağlayın. Hem Sayı hem de Sayı Değeri varsa kullanıcılara göstermek için Sayı değerini kullanırız

Uzun
İçerik Kategorileri İsteğe bağlı Öğedeki içeriğin kategorisini açıklayın.

Uygun Sıralamaların Listesi

  • TYPE_MOVIES_AND_TV_SHOWS (Örnek: Sinema)
  • TYPE_DIGITAL_GAMES (Örnek: Espor)
  • TYPE_MUSIC (Örnek: Konser)
  • TYPE_TRAVEL_AND_LOCAL (Örnek: Tur, festival)
  • TYPE_HEALTH_AND_FITENESS (Örnek: Yoga dersi)
  • TYPE_EDUCATION (Örnek: Sınıf)
  • TYPE_SPORTS (Örnek: Futbol maçı)
  • TYPE_DATING (Örnek: buluşma)

Yol gösterici bilgiler için İçerik Kategorisi bölümüne bakın.

Resim özellikleri

Resim öğeleri için gerekli özellikler bu tabloda listelenmiştir:

En boy oranı Minimum piksel sayısı Önerilen piksel sayısı

Kare (1x1)

Tercih edilen

300x300 1.200x1.200
Yatay (1,91x1) 600x314 1.200x628
Dikey (4x5) 480x600 960x1200

Google'ın resimlere erişebilmesi için resimlerin herkese açık CDN'lerde barındırılması gerekir.

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.
  • Resmin koyu ve açık tema ayarlarında düzgün şekilde gösterilmesi için şeffaf bir arka plan kullanın.

İçerik Kategorisi

İçerik kategorisi, uygulamaların birden fazla kategoriye ait içerik yayınlamasına olanak tanır. Bu işlem, içeriği önceden tanımlanmış kategorilerden bazılarıyla eşleştirir. Örneğin:

  • TYPE_EDUCATION
  • TYPE_SPORTS
  • TYPE_MOVIES_AND_TV_SHOWS
  • TYPE_BOOKS
  • TYPE_AUDIOBOOKS
  • TYPE_MUSIC
  • TYPE_DIGITAL_GAMES
  • TYPE_TRAVEL_AND_LOCAL
  • TYPE_HOME_AND_AUTO
  • TYPE_BUSINESS
  • TYPE_NEWS
  • TYPE_FOOD_AND_DRINK
  • TYPE_SHOPPING
  • TYPE_HEALTH_AND_FITENESS
  • TYPE_MEDICAL
  • TYPE_PARENTING
  • TYPE_DATING

Google'ın resimlere erişebilmesi için resimlerin herkese açık CDN'lerde barındırılması gerekir.

İçerik kategorilerini kullanmayla ilgili kurallar

  1. ArticleEntity ve GenericFeaturedEntity gibi bazı varlıklar, içerik kategorilerinin herhangi birini kullanmaya uygundur. EventEntity, EventReservationEntity, PersonEntity gibi diğer varlıklar için bu kategorilerin yalnızca bir alt kümesi uygundur. Listeyi doldurmadan önce bir varlık türü için uygun kategorilerin listesini kontrol edin.
  2. Bazı içerik kategorileri için genel öğeler ve ContentCategory öğesinin bir kombinasyonu yerine belirli öğe türünü kullanın:

  3. ContentCategory alanı isteğe bağlıdır ve içerik daha önce belirtilen kategorilerden hiçbirine ait değilse boş bırakılmalıdır.

  4. Birden fazla içerik kategorisi sağlanırsa bunları içerikle alaka düzeyine göre sıralayın. En alakalı içerik kategorisi listeye ilk sırada eklenir.

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

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

AppEngagePublishClient, kümeleri yayınlamaktan sorumludur.

İstemcide kümeleri yayınlamak için aşağıdaki API'ler vardır:

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

isServiceAvailable

Bu API, hizmetin entegrasyon için kullanılıp kullanılamadığı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, bir işlem içinde aşağıdaki işlemler gerçekleştirilir:

  • Geliştirici iş ortağının mevcut RecommendationCluster verileri kaldırılır.
  • İstekten gelen veriler ayrıştırılır ve güncellenmiş öneri kümesinde depolanır.

Hata olması 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ğının mevcut FeaturedCluster verileri kaldırılır.
  • İstekten gelen veriler ayrıştırılır ve güncellenen Öne Çıkan Küme'de depolanır.

Bir hata olması durumunda, isteğin tamamı reddedilir ve mevcut durum korunur.

publishContinuationCluster

Bu API, ContinuationCluster nesnesi 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ğının mevcut ContinuationCluster verileri kaldırılır.
  • İstekten gelen veriler ayrıştırılır ve güncellenen Devam Kümesi'nde depolanır.

Hata olması 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, uygulamanın içerik yayınlayabilmesi (veya daha kişiselleştirilmiş içerik sunabilmesi) için kullanıcıları uygulamanın oturum açma sayfasına yönlendirir.

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

Özellik Şartlar Açıklama
İşlem Uri Zorunlu İşleme derin bağlantı (ör. uygulamanın oturum açma sayfasına yönlendirme)
Resim İsteğe bağlı: Sağlanmazsa başlık sağlanmalıdır

Kartta gösterilen resim

1264x712 çözünürlüğe sahip 16x9 en boy oranına sahip resimler

Başlık İsteğe bağlı: Sağlanmazsa resim sağlanmalıdır Karttaki 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 isteğ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, bir işlem içinde aşağıdaki işlemler gerçekleştirilir:

  • Geliştirici iş ortağının mevcut UserAccountManagementCluster verileri kaldırılır.
  • İstekten elde edilen veriler ayrıştırılır ve güncellenmiş UserAccountManagementCluster Kümesinde depolanır.

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

updatePublishStatus

Dahili bir işletme nedeniyle kümelerin hiçbiri yayınlanmıyorsa updatePublishStatus API'sini kullanarak yayınlama durumunu güncellemenizi önemle tavsiye ederiz. Bu önemlidir, çünkü :

  • İçerik yayınlandığında bile tüm senaryolarda durumu belirtmek (STATUS == YAYINLANDI) entegrasyonunuzun durumunu ve diğer metriklerini iletmek için bu uygunsuz durumu kullanan kontrol panellerini doldurmak açısından çok önemlidir.
  • Hiçbir içerik yayınlanmamışsa ancak entegrasyon durumu bozulmamışsa (STATUS == NOT_PUBLISHED) Google, uygulama sağlığı kontrol panellerinde uyarı tetiklemekten kaçınabilir. Sağlayıcı açısından beklenen bir durum nedeniyle içeriğin yayınlanmadığını onaylar.
  • Geliştiricilerin verilerin ne zaman yayınlandığı ve ne zaman yayınlanmadığı hakkında analizler sunmasına yardımcı olur.
  • Google, kullanıcının uygulama içeriğini görebilmesi veya bu içeriğin üstesinden gelmesi için uygulamada belirli işlemleri yapmasına yönlendirmek amacıyla durum kodlarını kullanabilir.

Uygun yayınlama durumu kodlarının listesi şunlardır:

// 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, bir kullanıcı giriş yapmadığı için yayınlanmazsa 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 NOT_PUBLISHED_REQUIRES_SIGN_IN durum koduyla updatePublishStatus API'sini çağırmanızı öneririz.

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 kümelerinin içeriğini silmek için kullanılır.

Kotlin

client.deleteRecommendationClusters()

Java

client.deleteRecommendationClusters();

Hizmet, isteği aldığında mevcut verileri öneri kümelerinden kaldırır. Hata olması 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 olması durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

deleteContinuationCluster

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

Kotlin

client.deleteContinuationCluster()

Java

client.deleteContinuationCluster();

Hizmet, isteği aldığında mevcut verileri Devam Kümesi'nden kaldırır. Hata olması 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. Bir hata olması 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ünü iletmeyi seçebilir. Hata olması durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

Hata işleme

Yayınlama API'lerinden görev sonucunu dinlemeniz önemle tavsiye edilir. Böylece, başarılı bir görevi kurtarıp yeniden göndermek için takip işlemi yapabilirsiniz.

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, hata kodu olarak nedeni dahil edilerek 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, belirli bir 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 Görev yürütülemedi, ileti dizisi sorunları nedeniyle başarısız oldu. Bu durumda, işlem yeniden denenebilir.
4 SERVICE_CALL_PERMISSION_DENIED Arayan kullanıcının servis araması yapmasına izin verilmiyor.
5 SERVICE_CALL_INVALID_ARGUMENT İstek geçersiz veriler içeriyor (örneğin, izin verilenden daha fazla sayıda küme).
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ı ele alın

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

Yayın niyetinin amacı, temel olarak uygulamayı yeniden etkinleştirmek ve veri senkronizasyonunu zorlamaktır. Yayın niyeti, çok sık gönderilecek şekilde tasarlanmamıştır. Yalnızca Engage Hizmeti içeriğin güncel olmayabileceğini (ör. bir haftalık) belirlediğinde tetiklenir. Bu şekilde, uygulama uzun bir süredir çalıştırılmamış olsa bile kullanıcının yeni bir içerik deneyimine sahip olabileceğine dair güven artar.

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

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

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

// Register Featured Cluster Publish Intent
  context.registerReceiver(AppEngageBroadcastReceiver(),
                           IntentFilter(Intents.ACTION_PUBLISH_FEATURED))

// Register Continuation Cluster Publish Intent
  context.registerReceiver(AppEngageBroadcastReceiver(),
                           IntentFilter(Intents.ACTION_PUBLISH_CONTINUATION))
}

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

// Register Featured Cluster Publish Intent
context.registerReceiver(new AppEngageBroadcastReceiver(),
new IntentFilter(com.google.android.engage.service.Intents.ACTION_PUBLISH_FEATURED));

// Register Continuation Cluster Publish Intent
context.registerReceiver(new AppEngageBroadcastReceiver(),
new IntentFilter(com.google.android.engage.service.Intents.ACTION_PUBLISH_CONTINUATION));

}
  • AndroidManifest.xml dosyanızda <receiver> etiketiyle uygulamayı statik olarak beyan edin. Bu, uygulamanın çalışmadığı zamanlarda yayın istekleri almasına ve uygulamanın içeriği yayınlamasına olanak tanır.
<application>
   <receiver
      android:name=".AppEngageBroadcastReceiver"
      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 intent'ler gönderilir:

  • com.google.android.engage.action.PUBLISH_RECOMMENDATION Bu amacı aldığınızda publishRecommendationClusters çağrısı başlatmanız önerilir.
  • com.google.android.engage.action.PUBLISH_FEATURED Bu intent'i aldığınızda publishFeaturedCluster çağrısı başlatmanız önerilir.
  • com.google.android.engage.action.PUBLISH_CONTINUATION Bu intent'i aldığınızda publishContinuationCluster çağrısı başlatmanız önerilir.

Entegrasyon iş akışı

Entegrasyonunuz tamamlandıktan sonra doğrulamayla ilgili adım adım açıklamalı bir kılavuz için Engage geliştirici entegrasyon iş akışı başlıklı makaleyi inceleyin.

SSS

SSS için Engage SDK'sı hakkında sık sorulan sorular başlıklı makaleyi inceleyin.

İletişim

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

Sonraki adımlar

Bu entegrasyonu tamamladıktan sonra uygulayacağınız adımlar ş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 ve dahili inceleme gerçekleştirir. Değişiklik yapılması gerekiyorsa Google gerekli tüm bilgileri sizinle paylaşır.
  • Test tamamlandığında ve herhangi bir değişiklik gerekmediğinde Google, güncellenmiş ve entegre 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 Çıkan ve Devam kümeleriniz yayınlanabilir ve kullanıcılara gösterilebilir.