يمكنك زيادة التفاعل مع التطبيق من خلال الوصول إلى المستخدمين أينما كانوا. يمكنك دمج حزمة Engage SDK لتقديم اقتراحات مخصّصة ومحتوى متواصل إلى المستخدمين مباشرةً على مساحات عرض متعددة على الأجهزة، مثل المجموعات ومساحة الترفيه و"متجر Play". يضيف الدمج أقل من 50 كيلوبايت (مضغوط) إلى متوسط حجم حزمة APK، ويستغرق معظم التطبيقات حوالي أسبوع من وقت المطوّر. يمكنك الاطّلاع على مزيد من المعلومات على موقعنا الإلكتروني المخصّص للأنشطة التجارية.
يتضمّن هذا الدليل تعليمات للشركاء المطوّرين لعرض محتوى متعلّق بالصحة واللياقة البدنية في مساحات عرض المحتوى في ميزة "التفاعل".
تفاصيل الدمج
المصطلحات
يتضمّن هذا الدمج أنواع المجموعات الثلاث التالية: الاقتراحات، المنتجات المميّزة، والمنتجات التي تليها.
تعرض مجموعات الاقتراحات اقتراحات مخصّصة حول الصحة واللياقة البدنية من مطوّر فردي شريك. يمكن أن تكون هذه الاقتراحات مخصّصة للمستخدم أو عامة (على سبيل المثال، محتوى اللياقة البدنية والصحة الرائج). استخدِم هذه العلامات لعرض مقالات أو مستخدمين مرتبطين بالصحة واللياقة البدنية.
- يمكن إنشاء مجموعة اقتراحات من
ArticleEntity
أوPersonEntity
أو أوEventEntity
، ولكن ليس من خلال مزيج من أنواع الكيانات المختلفة.
تتّبع الاقتراحات البنية التالية:
مجموعة الاقتراحات: عرض واجهة مستخدم يحتوي على مجموعة من الاقتراحات من شريك المطوّر نفسه.
الكيان: هو عنصر يمثّل عنصرًا واحدًا في مجموعة. يوفّر هذا الدمج بعض الكيانات التي سيتم عرضها باستخدام مجموعة الاقتراحات:
ArticleEntity: يمثّل ArticleEntity اقتراحًا لمحتوى مستند إلى النص حول الصحة واللياقة البدنية. ويمكن استخدامه في المقالات ومشاركات المدونات والمحتوى التسويقي ومقتطفات الأخبار وما إلى ذلك.
الشكل 1: واجهة مستخدِم تعرض عنصر ArticleEntity واحدًا ضمن مجموعة الاقتراحات PersonEntity: يمثّل PersonEntity شخصًا. يمكن أن تشمل الاقتراحات تسليط الضوء على مدرب أو أي شخص مرتبط بالصحة واللياقة البدنية وما إلى ذلك.
الشكل 2: واجهة مستخدِم تعرض عنصرًا واحدًا من النوع PersonEntity ضمن مجموعة الاقتراحات EventEntity: يمثّل EventEntity حدثًا سيحدث في المستقبل. وقت بدء الحدث هو جزء مهم من المعلومات التي يجب إبلاغ المستخدمين بها. ويمكن استخدام هذا العنصر ل عرض الأحداث، مثل مخيم التبرع بالدم أو الجلسات التدريبية أو التمارين الرياضية أو صفوف اليوغا وما إلى ذلك من الأنشطة المرتبطة بالصحة واللياقة البدنية.
الشكل 3: واجهة مستخدِم تعرض عنصر حدث واحد ضمن مجموعة الاقتراحات
- يمكن إنشاء مجموعة اقتراحات من
تعرِض مجموعة المتابعة المحتوى الذي تفاعل معه المستخدمون مؤخرًا من شركاء مطوّرين متعدّدين في مجموعة واحدة لواجهة المستخدم. سيتم السماح لكل شريك مطوّر ببث 10 كيانات كحد أقصى في مجموعة "المتابعة".
يمكن أن يتّخذ محتوى المتابعة الهيكل التالي:
ArticleEntity: يمثّل ArticleEntity اقتراحًا لمحتوى مستند إلى النص يتعلّق بالصحة واللياقة البدنية. يمكن استخدام هذا العنصر لتمثيل مقالات إخبارية غير مكتملة أو محتوى آخر يريده المستخدم مواصلة استهلاكه من حيث توقّف. مثال: مقتطف أخبار أو مقتطف من مدونة عن مواضيع ذات صلة بالصحة أو اللياقة البدنية
الشكل 6. واجهة مستخدم تعرض عنصر ArticleEntity واحدًا ضمن مجموعة Continuation EventReservationEntity: يمثّل EventReservationEntity حجزًا لحدث ويساعد المستخدمين في تتبُّع الحجوزات القادمة أو الجارية لأحداث اللياقة البدنية والصحة. مثال: جلسات التدريب
الشكل 8. واجهة مستخدم تعرض عنصر EventReservationEntity واحدًا ضمن مجموعة Continuation
تعرض مجموعة التطبيقات المميّزة مجموعة من التطبيقات من عدة شركاء مطوّرين في مجموعة واحدة من واجهة المستخدم. ستكون هناك مجموعة واحدة مميّزة ، يتم عرضها بالقرب من أعلى واجهة المستخدم مع موضع أولوية فوق جميع مجموعات الاقتراحات. سيتم السماح لكل شريك مطوّر ببث ما يصل إلى 10 كيانات في المجموعة المميّزة.
GenericFeaturedEntity: يختلف GenericFeaturedEntity عن عنصر الاقتراح في أنّ العنصر المميّز يجب استخدامه لعرض محتوى واحد من أهم المحتوى الذي يقدّمه المطوّرون، ويجب أن يمثّل المحتوى الوحيد الأكثر أهمية والذي سيكون مثيرًا للاهتمام وذا صلة بالمستخدمين.
الشكل 12: واجهة مستخدِم تعرض عنصرًا رئيسيًا واحدًا بطاقة GenericFeaturedEntity ضمن مجموعة مميّزة
العمل التمهيدي
الحد الأدنى لمستوى واجهة برمجة التطبيقات: 19
أضِف مكتبة com.google.android.engage:engage-core
إلى تطبيقك باتّباع الخطوات التالية:
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'
}
ملخّص
يستند التصميم إلى تنفيذ خدمة مرتبطة.
تخضع البيانات التي يمكن للعميل نشرها للحدود التالية لأنواع المجموعات المختلفة:
نوع المجموعة | حدود المجموعات | الحد الأدنى لعدد العناصر في مجموعة | الحد الأقصى لعدد العناصر في مجموعة |
---|---|---|---|
مجموعات الاقتراحات | 7 بحد أقصى | 1 على الأقل | 50 علامة بحد أقصى (ArticleEntity أو PersonEntity أو
EventEntity ) |
مجموعة المتابعة | 1 بحد أقصى | 1 على الأقل | 20 عنصرًا بحد أقصى (ArticleEntity أو
EventReservationEntity ) |
مجموعة مميزة | 1 بحد أقصى | 1 على الأقل | 20 موقعًا كحد أقصى (GenericFeaturedEntity ) |
الخطوة 1: تقديم بيانات العنصر
حدّدت حزمة تطوير البرامج (SDK) كيانات مختلفة لتمثيل كل نوع من أنواع العناصر. نسمح باستخدام الكيانات التالية في فئة "الصحة واللياقة":
GenericFeaturedEntity
ArticleEntity
PersonEntity
EventEntity
EventReservationEntity
توضّح الرسوم البيانية أدناه السمات والمتطلبات المتاحة لكل نوع.
GenericFeaturedEntity
السمة | المتطلب | الوصف | التنسيق |
---|---|---|---|
معرّف الموارد المنتظم (URI) للإجراء | مطلوبة |
رابط لصفحة في التطبيق ينقل إلى الكيان ملاحظة: يمكنك استخدام الروابط لصفحات في التطبيق لتحديد المصدر. يُرجى الرجوع إلى هذه الأسئلة الشائعة |
معرّف موارد منتظم (URI) |
صور الملصقات | مطلوبة | سنعرض صورة واحدة فقط عند تقديم صور متعددة. نسبة العرض إلى الارتفاع المقترَحة هي 16:9 ملاحظة: في حال توفّر شارة، يُرجى التأكّد من توفير مساحة آمنة يبلغ ارتفاعها 24 بكسل في الثانية في أعلى وأسفل الصورة. |
اطّلِع على مواصفات الصور للحصول على إرشادات. |
العنوان | اختياري | عنوان الكيان | حقل التعبئة النصّية الحرّة حجم النص المقترَح: 50 حرفًا |
الوصف | اختياري | فقرة واحدة من النص لوصف الكيان ملاحظة: سيتم إما عرض الوصف أو قائمة الترجمة والشرح للمستخدم، وليس كليهما. |
حقل التعبئة النصّية الحرّة حجم النص المقترَح: 180 حرفًا |
قائمة الترجمة | اختياري | ما يصل إلى 3 ترجمات مصاحبة، يكون كلّ منها سطرًا واحدًا من النص ملاحظة: سيتم إما عرض الوصف أو قائمة الترجمة والشرح للمستخدم، وليس كليهما. |
حقل التعبئة النصّية الحرّة حجم النص المقترَح لكل ترجمة: 50 حرفًا بحدٍ أقصى |
الشارات | اختياري | كل شارة هي إما نص حر (15 حرفًا بحد أقصى) أو صورة صغيرة. معالجة خاصة لتجربة المستخدم على سطح الصورة أو الفيديو، مثل شارة فوق الصورة
|
|
الشارة - النص | اختياري | عنوان الشارة ملاحظة: يجب إدخال نص أو صورة للشارة. |
حقل التعبئة النصّية الحرّة حجم النص المقترَح: 15 حرفًا بحد أقصى |
الشارة - صورة | اختياري | صورة صغيرة معالجة خاصة لتجربة المستخدم، مثل تراكب الشارة على الصورة/فيديو الصورة المصغّرة ملاحظة: يجب إدخال نص أو صورة للشارة. |
اطّلِع على مواصفات الصور للحصول على إرشادات. |
فئات المحتوى | اختياري | يصف هذا الحقل فئة المحتوى في العنصر. | قائمة عمليات التعداد اطّلِع على قسم "فئة المحتوى" للحصول على إرشادات. |
ArticleEntity
السمة | المتطلب | الوصف | التنسيق |
---|---|---|---|
معرّف الموارد المنتظم (URI) للإجراء | مطلوبة |
رابط لصفحة في التطبيق ينقل إلى الكيان ملاحظة: يمكنك استخدام الروابط لصفحات في التطبيق لتحديد المصدر. يُرجى الرجوع إلى هذه الأسئلة الشائعة |
معرّف موارد منتظم (URI) |
العنوان | مطلوبة | عنوان الكيان | حقل التعبئة النصّية الحرّة حجم النص المقترَح: 50 حرفًا بحد أقصى |
صور الملصقات | اختياري | سنعرض صورة واحدة فقط عند تقديم صور متعددة. نسبة العرض إلى الارتفاع المقترَحة هي 16:9 ملاحظة: ننصح بشدة باستخدام صورة. إذا تم توفير شارة، يُرجى التأكّد من توفير مساحة آمنة تبلغ 24 نقطة في البوصة في أعلى وأسفل الصورة. |
اطّلِع على مواصفات الصور للحصول على إرشادات. |
المصدر - العنوان | اختياري | اسم المؤلف أو المؤسسة أو المُخبر | حقل التعبئة النصّية الحرّة حجم النص المقترَح: أقل من 25 حرفًا |
المصدر: صورة | اختياري | صورة للمصدر، مثل المؤلف أو المؤسسة أو المُخبر | اطّلِع على مواصفات الصور للحصول على إرشادات. |
الوصف | اختياري | فقرة واحدة من النص لوصف الكيان ملاحظة: سيتم إما عرض الوصف أو قائمة الترجمة والشرح للمستخدم، وليس كليهما. |
حقل التعبئة النصّية الحرّة حجم النص المقترَح: 180 حرفًا |
قائمة الترجمة | اختياري | ما يصل إلى 3 ترجمات مصاحبة، يكون كلّ منها سطرًا واحدًا من النص ملاحظة: سيتم إما عرض الوصف أو قائمة الترجمة والشرح للمستخدم، وليس كليهما. |
حقل التعبئة النصّية الحرّة حجم النص المقترَح لكل ترجمة: 50 حرفًا بحدٍ أقصى |
الشارات | اختياري | كل شارة هي إما نص حر (15 حرفًا بحد أقصى) أو صورة صغيرة. معالجة خاصة لتجربة المستخدم على سطح الصورة أو الفيديو، مثل شارة فوق الصورة
|
|
الشارة - النص | اختياري | عنوان الشارة ملاحظة: يجب إدخال نص أو صورة للشارة. |
حقل التعبئة النصّية الحرّة حجم النص المقترَح: 15 حرفًا بحد أقصى |
الشارة - صورة | اختياري | صورة صغيرة معالجة خاصة لتجربة المستخدم، مثل تراكب الشارة على الصورة/فيديو الصورة المصغّرة ملاحظة: يجب إدخال نص أو صورة للشارة. |
اطّلِع على مواصفات الصور للحصول على إرشادات. |
وقت نشر المحتوى | اختياري | هذا هو الطابع الزمني لبدء حساب الفترة بالملي ثانية لوقت نشر المحتوى أو تعديله في التطبيق. | الطابع الزمني لحقبة Unix بالملي ثانية |
آخر مدة تفاعل | مطلوبة بشروط | الطابع الزمني لبدء الحقبة بالمللي ثانية عندما تفاعل المستخدِم مع هذا الكيان للمرّة الأخيرة. ملاحظة: هذا الحقل مطلوب إذا كان هذا الكيان جزءًا من مجموعة المتابعة. |
الطابع الزمني لحقبة Unix بالملي ثانية |
النسبة المئوية للتقدّم | مطلوبة بشروط | النسبة المئوية للمحتوى الكامل الذي استهلكه المستخدم حتى اليوم ملاحظة: هذا الحقل مطلوب إذا كان هذا الكيان جزءًا من مجموعة المتابعة. |
قيمة عدد صحيح تتراوح بين 0 و100 بما في ذلك |
فئات المحتوى | اختياري | يصف هذا الحقل فئة المحتوى في العنصر. | قائمة عمليات التعداد اطّلِع على قسم "فئة المحتوى" للحصول على إرشادات. |
PersonEntity
السمة | المتطلب | الوصف | التنسيق |
---|---|---|---|
معرّف الموارد المنتظم (URI) للإجراء | مطلوبة |
رابط لصفحة في التطبيق ينقل إلى الكيان ملاحظة: يمكنك استخدام الروابط لصفحات في التطبيق لتحديد المصدر. يُرجى الرجوع إلى هذه الأسئلة الشائعة |
معرّف موارد منتظم (URI) |
الملف الشخصي - الاسم | مطلوبة | اسم الملف الشخصي أو رقم تعريفه أو الاسم المعرِّف، مثل "خالد كمال" أو "@TeamPixel" أو غير ذلك | سلسلة حجم النص المقترَح: 50 حرفًا بحد أقصى |
الملف الشخصي - الصورة الرمزية | مطلوبة |
صورة الملف الشخصي أو الصورة الرمزية للمستخدم ملاحظة: يجب أن تكون الصورة مربّعة بنسبة عرض إلى ارتفاع 1:1. |
اطّلِع على مواصفات الصور للحصول على إرشادات. |
الملف الشخصي - نص إضافي | اختياري | نص حر مثل الاسم المعرِّف للملف التجاري | حقل التعبئة النصّية الحرّة حجم النص المقترَح: 15 حرفًا بحد أقصى |
الملف الشخصي - صورة إضافية | اختياري | صورة صغيرة مثل شارة إثبات الملكية | اطّلِع على مواصفات الصور للحصول على إرشادات. |
صورة العنوان | اختياري | سنعرض صورة واحدة فقط عند تقديم صور متعددة. نسبة العرض إلى الارتفاع المقترَحة هي 16:9 ملاحظة: ننصح بشدة باستخدام صورة. إذا تم توفير شارة، يُرجى التأكّد من وجود مساحة آمنة تبلغ 24 نقطة في البوصة في أعلى وأسفل الصورة. |
اطّلِع على مواصفات الصور للحصول على إرشادات. |
مدى الرواج - العدد | اختياري |
حدِّد عدد المتابعين أو قيمة مدى الرواج، على سبيل المثال: "3.7 مليون". ملاحظة: في حال توفّر كلّ من "العدد" و"قيمة العدد"، سيتم استخدام "العدد". |
سلسلة حجم النص المقترَح: 20 حرفًا بحد أقصى للعدد + التصنيف معًا |
مدى الرواج - قيمة العدد | اختياري | عدد المتابعين أو قيمة مدى رواج المحتوى ملاحظة: قدِّم قيمة العدد إذا كان تطبيقك لا يريد التعامل مع المنطق الخاص بكيفية تحسين عدد كبير لتناسب أحجام الشاشة المختلفة. في حال توفير كلّ من "العدد" و"قيمة العدد"، سيتم استخدام "العدد". |
طويل |
مدى الرواج - التصنيف | اختياري | حدِّد تصنيف مدى الرواج. على سبيل المثال، "الإعجابات". | سلسلة حجم النص المُقترَح: 20 حرفًا بحد أقصى للعدد + التصنيف معًا |
مدى الرواج - المحتوى المرئي | اختياري |
حدِّد الغرض من التفاعل. على سبيل المثال، صورة تعرض رموز الإعجاب ورموز الإيموجي يمكن تقديم أكثر من صورة واحدة، ولكن قد لا يتم عرضها كلها على جميع أشكال الأجهزة. ملاحظة: يجب أن تكون الصورة مربّعة بنسبة عرض إلى ارتفاع 1:1. |
اطّلِع على مواصفات الصور للحصول على إرشادات. |
التقييم - الحد الأقصى للقيمة | مطلوب | الحد الأقصى لقيمة مقياس التقييم. يجب تقديمها إذا تم تقديم القيمة الحالية للتقييم أيضًا. |
يجب أن يكون الرقم أكبر من أو يساوي 0.0. |
التقييم - القيمة الحالية | مطلوب | القيمة الحالية لمقياس التقييم يجب تقديمها إذا تم تقديم الحد الأقصى لقيمة التقييم أيضًا. |
يجب أن يكون الرقم أكبر من أو يساوي 0.0. |
التقييم - العدد | اختياري | عدد تقييمات العنصر ملاحظة: قدِّم هذا الحقل إذا كان تطبيقك يتحكّم في طريقة عرض العدد للمستخدمين. استخدِم سلسلة موجزة. على سبيل المثال، إذا كان العدد 1,000,000، ننصحك باستخدام اختصار مثل 1M لكي لا يتم اقتطاع العدد على أحجام الشاشة الأصغر. |
سلسلة |
التقييم - قيمة العدد | اختياري | عدد تقييمات العنصر ملاحظة: قدِّم هذا الحقل إذا لم تكن تتعامل بنفسك مع منطق الاختصار المعروض. إذا كانت كلّ من السمتَين "العدد" و"قيمة العدد" متوفرتين، يتم عرض السمة "العدد" للمستخدمين. |
طويل |
الموقع الجغرافي - البلد | اختياري | البلد الذي يقيم فيه الشخص أو يخدم فيه | حقل التعبئة النصّية الحرّة حجم النص المقترَح: 20 حرفًا بحد أقصى |
الموقع الجغرافي - المدينة | اختياري | المدينة التي يقيم فيها الشخص أو يعمل فيها | حقل التعبئة النصّية الحرّة حجم النص المقترَح: 20 حرفًا بحد أقصى |
الموقع الجغرافي: عنوان العرض | اختياري | سيتم عرض العنوان الذي يقيم فيه الشخص أو يقدّم فيه الخدمة للمستخدم. | حقل التعبئة النصّية الحرّة حجم النص المقترَح: 20 حرفًا بحد أقصى |
الموقع الجغرافي: عنوان الشارع | اختياري | عنوان الشارع (إن وُجد) الذي يقيم فيه الشخص أو يعمل فيه | حقل التعبئة النصّية الحرّة حجم النص المقترَح: 20 حرفًا بحد أقصى |
الموقع الجغرافي - الولاية | اختياري | الولاية (إن أمكن) التي يقيم فيها الشخص أو يعمل فيها | حقل التعبئة النصّية الحرّة حجم النص المقترَح: 20 حرفًا بحد أقصى |
الموقع الجغرافي - الرمز البريدي | اختياري | الرمز البريدي (إن أمكن) للمكان الذي يقيم فيه الشخص أو يعمل فيه | حقل التعبئة النصّية الحرّة حجم النص المقترَح: 20 حرفًا بحد أقصى |
الموقع الجغرافي: الحي | اختياري | الحي (إن وُجد) الذي يقيم فيه الشخص أو يقدّم فيه الخدمة | حقل التعبئة النصّية الحرّة حجم النص المقترَح: 20 حرفًا بحد أقصى |
الشارات | اختياري |
كل شارة هي إما نص حر (15 حرفًا بحد أقصى) أو صورة صغيرة. |
|
الشارة - النص | اختياري | عنوان الشارة ملاحظة: يجب إدخال نص أو صورة للشارة. |
حقل التعبئة النصّية الحرّة حجم النص المقترَح: 15 حرفًا بحد أقصى |
الشارة - صورة | اختياري | صورة صغيرة معالجة خاصة لتجربة المستخدم، مثل تراكب الشارة على الصورة/فيديو الصورة المصغّرة ملاحظة: يجب إدخال نص أو صورة للشارة. |
اطّلِع على مواصفات الصور للحصول على إرشادات. |
الوصف | اختياري | فقرة واحدة من النص لوصف الكيان ملاحظة: سيتم إما عرض الوصف أو قائمة الترجمة والشرح للمستخدم، وليس كليهما. |
حقل التعبئة النصّية الحرّة حجم النص المقترَح: 180 حرفًا |
قائمة الترجمة | اختياري | ما يصل إلى 3 ترجمات مصاحبة، يكون كلّ منها سطرًا واحدًا من النص ملاحظة: سيتم إما عرض الوصف أو قائمة الترجمة والشرح للمستخدم، وليس كليهما. |
حقل التعبئة النصّية الحرّة حجم النص المقترَح لكل ترجمة: 50 حرفًا بحدٍ أقصى |
فئات المحتوى | اختياري | يصف هذا الحقل فئة المحتوى في العنصر. | قائمة التعدادات المؤهَّلة
اطّلِع على قسم "فئة المحتوى" للحصول على إرشادات. |
EventEntity
السمة | المتطلب | الوصف | التنسيق |
---|---|---|---|
معرّف الموارد المنتظم (URI) للإجراء | مطلوبة |
رابط لصفحة في التطبيق ينقل إلى الكيان ملاحظة: يمكنك استخدام الروابط لصفحات في التطبيق لتحديد المصدر. يُرجى الرجوع إلى هذه الأسئلة الشائعة |
معرّف موارد منتظم (URI) |
العنوان | مطلوبة | عنوان الكيان | سلسلة حجم النص المقترَح: 50 حرفًا بحد أقصى |
وقت البدء | مطلوبة |
الطابع الزمني لبدء الفترة الزمنية عندما يُتوقّع بدء الحدث ملاحظة: سيتم تمثيل ذلك بالملي ثانية. |
الطابع الزمني لحقبة Unix بالملي ثانية |
وضع الحدث | مطلوبة | حقل للإشارة إلى ما إذا كان الحدث سيكون افتراضيًا أو بالحضور الشخصي أو كلاهما |
نوع متغير معرّف: VIRTUAL أو IN_PERSON أو HYBRID |
صور الملصقات | مطلوبة | سنعرض صورة واحدة فقط عند تقديم صور متعددة. نسبة العرض إلى الارتفاع المقترَحة هي 16:9 ملاحظة: ننصح بشدة باستخدام صورة. إذا تم توفير شارة، يُرجى التأكّد من توفير مساحة آمنة تبلغ 24 نقطة في البوصة في أعلى وأسفل الصورة. |
اطّلِع على مواصفات الصور للحصول على إرشادات. |
الموقع الجغرافي - البلد | مطلوبة بشروط | البلد الذي يقع فيه الحدث ملاحظة: هذا الإجراء مطلوب للأحداث التي تكون من النوع IN_PERSON أو HYBRID. |
حقل التعبئة النصّية الحرّة حجم النص المقترَح: 20 حرفًا بحد أقصى |
الموقع الجغرافي - المدينة | مطلوبة بشروط | المدينة التي سيُقام فيها الحدث ملاحظة: هذا الإجراء مطلوب للأحداث التي تكون من النوع IN_PERSON أو HYBRID. |
حقل التعبئة النصّية الحرّة حجم النص المقترَح: 20 حرفًا بحد أقصى |
الموقع الجغرافي: عنوان العرض | مطلوبة بشروط | عنوان أو اسم المكان الذي سيُقام فيه الحدث والذي يجب عرضه للمستخدم ملاحظة: هذا الإجراء مطلوب للأحداث التي تكون من النوع IN_PERSON أو HYBRID. |
حقل التعبئة النصّية الحرّة حجم النص المقترَح: 20 حرفًا بحد أقصى |
الموقع الجغرافي: عنوان الشارع | اختياري | عنوان الشارع (إن أمكن) للموقع الجغرافي الذي يتم فيه استضافة الحدث | حقل التعبئة النصّية الحرّة حجم النص المقترَح: 20 حرفًا بحد أقصى |
الموقع الجغرافي - الولاية | اختياري | الولاية أو المقاطعة (إن أمكن) التي يتم فيها استضافة الفعالية | حقل التعبئة النصّية الحرّة حجم النص المقترَح: 20 حرفًا بحد أقصى |
الموقع الجغرافي - الرمز البريدي | اختياري | الرمز البريدي (إن أمكن) للموقع الجغرافي الذي يتم فيه استضافة الحدث | حقل التعبئة النصّية الحرّة حجم النص المقترَح: 20 حرفًا بحد أقصى |
الموقع الجغرافي: الحي | اختياري | الحي (إن أمكن) الذي يتم فيه استضافة الحدث. | حقل التعبئة النصّية الحرّة حجم النص المقترَح: 20 حرفًا بحد أقصى |
وقت الانتهاء | اختياري |
الطابع الزمني لبدء حساب الفترة الزمنية عندما يُتوقّع انتهاء الحدث ملاحظة: سيتم تمثيل ذلك بالملي ثانية. |
الطابع الزمني لحقبة Unix بالملي ثانية |
الوصف | اختياري | فقرة واحدة من النص لوصف الكيان ملاحظة: سيتم إما عرض الوصف أو قائمة الترجمة والشرح للمستخدم، وليس كليهما. |
حقل التعبئة النصّية الحرّة حجم النص المقترَح: 180 حرفًا |
قائمة الترجمة | اختياري | ما يصل إلى 3 ترجمات مصاحبة، يكون كلّ منها سطرًا واحدًا من النص ملاحظة: سيتم إما عرض الوصف أو قائمة الترجمة والشرح للمستخدم، وليس كليهما. |
حقل التعبئة النصّية الحرّة حجم النص المقترَح لكل ترجمة: 50 حرفًا بحدٍ أقصى |
الشارات | اختياري |
كل شارة هي إما نص حر (15 حرفًا بحد أقصى) أو صورة صغيرة. |
|
الشارة - النص | اختياري | عنوان الشارة ملاحظة: يجب إدخال نص أو صورة للشارة. |
حقل التعبئة النصّية الحرّة حجم النص المقترَح: 15 حرفًا بحد أقصى |
الشارة - صورة | اختياري | صورة صغيرة معالجة خاصة لتجربة المستخدم، مثل تراكب الشارة على الصورة/فيديو الصورة المصغّرة ملاحظة: يجب إدخال نص أو صورة للشارة. |
اطّلِع على مواصفات الصور للحصول على إرشادات. |
السعر - CurrentPrice | مطلوبة بشروط |
السعر الحالي للتذكرة أو البطاقة للحدث يجب تقديمه إذا تم تقديم سعر مشطوب. |
حقل التعبئة النصّية الحرّة |
السعر - السعر الأصلي المشطوب | اختياري | السعر الأصلي للتذكرة أو البطاقة للحدث. | حقل التعبئة النصّية الحرّة |
وسيلة شرح السعر | اختياري | عبارة توضيحية للسعر لعرض عرض ترويجي أو حدث أو خصم للمشتركين، إذا كان ذلك متاحًا | حقل التعبئة النصّية الحرّة حجم النص المقترَح: أقل من 45 حرفًا (قد تظهر علامات حذف إذا كان النص طويلاً جدًا) |
فئات المحتوى | اختياري | يصف هذا الحقل فئة المحتوى في العنصر. | قائمة التعدادات المؤهَّلة
اطّلِع على قسم "فئة المحتوى" للحصول على إرشادات. |
EventReservationEntity
السمة | المتطلب | الوصف | التنسيق |
---|---|---|---|
معرّف الموارد المنتظم (URI) للإجراء | مطلوبة |
رابط لصفحة في التطبيق ينقل إلى الكيان ملاحظة: يمكنك استخدام الروابط لصفحات في التطبيق لتحديد المصدر. يُرجى الرجوع إلى هذه الأسئلة الشائعة |
معرّف موارد منتظم (URI) |
العنوان | مطلوبة | عنوان الكيان | سلسلة حجم النص المقترَح: 50 حرفًا بحد أقصى |
وقت البدء | مطلوبة |
الطابع الزمني لبدء الفترة الزمنية عندما يُتوقّع بدء الحدث ملاحظة: سيتم تمثيل ذلك بالملي ثانية. |
الطابع الزمني لحقبة Unix بالملي ثانية |
وضع الحدث | مطلوبة | حقل للإشارة إلى ما إذا كان الحدث سيكون افتراضيًا أو بالحضور الشخصي أو كلاهما |
نوع متغير معرّف: VIRTUAL أو IN_PERSON أو HYBRID |
الموقع الجغرافي - البلد | مطلوبة بشروط | البلد الذي يقع فيه الحدث ملاحظة: هذا الإجراء مطلوب للأحداث التي تكون من النوع IN_PERSON أو HYBRID. |
حقل التعبئة النصّية الحرّة حجم النص المقترَح: 20 حرفًا بحد أقصى |
الموقع الجغرافي - المدينة | مطلوبة بشروط | المدينة التي سيُقام فيها الحدث ملاحظة: هذا الإجراء مطلوب للأحداث التي تكون من النوع IN_PERSON أو HYBRID. |
حقل التعبئة النصّية الحرّة حجم النص المقترَح: 20 حرفًا بحد أقصى |
الموقع الجغرافي: عنوان العرض | مطلوبة بشروط | عنوان أو اسم المكان الذي سيُقام فيه الحدث والذي يجب عرضه للمستخدم ملاحظة: هذا الإجراء مطلوب للأحداث التي تكون من النوع IN_PERSON أو HYBRID. |
حقل التعبئة النصّية الحرّة حجم النص المقترَح: 20 حرفًا بحد أقصى |
الموقع الجغرافي: عنوان الشارع | اختياري | عنوان الشارع (إن أمكن) للموقع الجغرافي الذي يتم فيه استضافة الحدث | حقل التعبئة النصّية الحرّة حجم النص المقترَح: 20 حرفًا بحد أقصى |
الموقع الجغرافي - الولاية | اختياري | الولاية أو المقاطعة (إن أمكن) التي يتم فيها استضافة الفعالية | حقل التعبئة النصّية الحرّة حجم النص المقترَح: 20 حرفًا بحد أقصى |
الموقع الجغرافي - الرمز البريدي | اختياري | الرمز البريدي (إن أمكن) للموقع الجغرافي الذي يتم فيه استضافة الحدث | حقل التعبئة النصّية الحرّة حجم النص المقترَح: 20 حرفًا بحد أقصى |
الموقع الجغرافي: الحي | اختياري | الحي (إن أمكن) الذي يتم فيه استضافة الحدث. | حقل التعبئة النصّية الحرّة حجم النص المقترَح: 20 حرفًا بحد أقصى |
صور الملصقات | اختياري | سنعرض صورة واحدة فقط عند تقديم صور متعددة. نسبة العرض إلى الارتفاع المقترَحة هي 16:9 ملاحظة: ننصح بشدة باستخدام صورة. إذا تم توفير شارة، يُرجى التأكّد من وجود مساحة آمنة تبلغ 24 نقطة في البوصة في أعلى وأسفل الصورة. |
اطّلِع على مواصفات الصور للحصول على إرشادات. |
وقت الانتهاء | اختياري |
الطابع الزمني لبدء حساب الفترة الزمنية عندما يُتوقّع انتهاء الحدث ملاحظة: سيتم تمثيل ذلك بالملي ثانية. |
الطابع الزمني لحقبة Unix بالملي ثانية |
مقدّم الخدمة - الاسم | اختياري |
اسم مقدّم الخدمة ملاحظة: يجب إدخال نص أو صورة لموفِّر الخدمة. |
نص حر على سبيل المثال، اسم منظِّم الحدث/الجولة |
مقدّم الخدمة - صورة | اختياري |
شعار/صورة مقدّم الخدمة ملاحظة: يجب إدخال نص أو صورة لموفِّر الخدمة |
اطّلِع على مواصفات الصور للحصول على إرشادات. |
الوصف | اختياري | فقرة واحدة من النص لوصف الكيان ملاحظة: سيتم إما عرض الوصف أو قائمة الترجمة والشرح للمستخدم، وليس كليهما. |
حقل التعبئة النصّية الحرّة حجم النص المقترَح: 180 حرفًا |
قائمة الترجمة | اختياري | ما يصل إلى 3 ترجمات مصاحبة، يكون كلّ منها سطرًا واحدًا من النص ملاحظة: سيتم إما عرض الوصف أو قائمة الترجمة والشرح للمستخدم، وليس كليهما. |
حقل التعبئة النصّية الحرّة حجم النص المقترَح لكل ترجمة: 50 حرفًا بحدٍ أقصى |
الشارات | اختياري |
كل شارة هي إما نص حر (15 حرفًا بحد أقصى) أو صورة صغيرة. |
|
الشارة - النص | اختياري | عنوان الشارة ملاحظة: يجب إدخال نص أو صورة للشارة. |
حقل التعبئة النصّية الحرّة حجم النص المقترَح: 15 حرفًا بحد أقصى |
الشارة - صورة | اختياري | صورة صغيرة معالجة خاصة لتجربة المستخدم، مثل تراكب الشارة على الصورة/فيديو الصورة المصغّرة ملاحظة: يجب إدخال نص أو صورة للشارة. |
اطّلِع على مواصفات الصور للحصول على إرشادات. |
رقم تعريف الحجز | اختياري | رقم تعريف حجز الحدث. | حقل التعبئة النصّية الحرّة |
السعر - CurrentPrice | مطلوبة بشروط |
السعر الحالي للتذكرة أو البطاقة للحدث يجب تقديمه إذا تم تقديم سعر مشطوب. |
حقل التعبئة النصّية الحرّة |
السعر - السعر الأصلي المشطوب | اختياري | السعر الأصلي للتذكرة أو البطاقة للحدث. | حقل التعبئة النصّية الحرّة |
وسيلة شرح السعر | اختياري | عبارة توضيحية للسعر لعرض عرض ترويجي أو حدث أو خصم للمشتركين، إذا كان ذلك متاحًا | حقل التعبئة النصّية الحرّة حجم النص المقترَح: أقل من 45 حرفًا (قد تظهر علامات حذف إذا كان النص طويلاً جدًا) |
التقييم - الحد الأقصى للقيمة | اختياري | الحد الأقصى لقيمة مقياس التقييم. يجب تقديمها إذا تم تقديم القيمة الحالية للتقييم أيضًا. |
يجب أن يكون الرقم أكبر من أو يساوي 0.0. |
التقييم - القيمة الحالية | اختياري | القيمة الحالية لمقياس التقييم يجب تقديمها إذا تم تقديم الحد الأقصى لقيمة التقييم أيضًا. |
يجب أن يكون الرقم أكبر من أو يساوي 0.0. |
التقييم - العدد | اختياري | عدد التقييمات للحدث ملاحظة: قدِّم هذا الحقل إذا كان تطبيقك يريد التحكّم في طريقة عرض هذا المحتوى للمستخدمين. يُرجى تقديم سلسلة مختصرة يمكن عرضها للمستخدم. على سبيل المثال، إذا كان العدد هو 1,000,000، ننصحك باستخدام اختصارات مثل 1M، لكي لا يتم اقتطاعه على أحجام الشاشة الأصغر. |
سلسلة |
التقييم - قيمة العدد | اختياري | عدد التقييمات للحدث ملاحظة: قدِّم هذا الحقل إذا كنت لا تريد التعامل مع منطق الاختصار المعروض بنفسك. إذا كانت كلّ من السمتَين Count وCount Value متوفرتين، سنستخدم السمة Count لعرضها للمستخدمين. |
طويل |
فئات المحتوى | اختياري | يصف هذا الحقل فئة المحتوى في العنصر. | قائمة التعدادات المؤهَّلة
اطّلِع على قسم "فئة المحتوى" للحصول على إرشادات. |
مواصفات الصور
في هذا الجدول، يتم إدراج المواصفات المطلوبة لمواد عرض الصور:
نسبة العرض إلى الارتفاع | الحدّ الأدنى لعدد وحدات البكسل | وحدات البكسل المقترَحة |
---|---|---|
مربّع (1×1) مفضّل |
300 × 300 | 1200 × 1200 |
أفقية (1.91x1) | 600 × 314 | 1200×628 |
عمودي (4×5) | 480×600 | 960x1200 |
يجب أن تكون الصور مستضافة على شبكات توصيل المحتوى (CDN) العامة حتى تتمكّن Google من الوصول إليها.
تنسيقات الملفات
PNG أو JPG أو GIF ثابت أو WebP
الحد الأقصى لحجم الملف
5,120 كيلوبايت
اقتراحات إضافية
- المساحة الآمنة للصور: ضَع المحتوى المهم في الوسط بحيث يشغل 80% من الصورة.
- استخدِم خلفية شفافة حتى تتمكّن من عرض الصورة بشكل صحيح في إعدادات المظهرَين الداكن والفاتح.
فئة المحتوى
تسمح فئة المحتوى للتطبيقات بنشر محتوى ينتمي إلى عدة فئات. يؤدي ذلك إلى ربط المحتوى ببعض الفئات المحدّدة مسبقًا، وهي:
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
يجب أن تكون الصور مستضافة على شبكات توصيل المحتوى (CDN) العامة حتى تتمكّن Google من الوصول إليها.
إرشادات لاستخدام فئات المحتوى
- إنّ بعض الكيانات، مثل ArticleEntity وGenericFeaturedEntity، مؤهَّلة لاستخدام أيّ من فئات المحتوى. بالنسبة إلى الكيانات الأخرى، مثل EventEntity وEventReservationEntity وPersonEntity، تكون مجموعة فرعية فقط من هذه الفئات مؤهّلة. راجِع قائمة الفئات المؤهَّلة لتحديد نوع ملفّ تعريف المنتج قبل تعبئة القائمة.
استخدِم نوع الكيان المحدّد لبعض فئات المحتوى بدلاً من تركيبة من الكيانات العامة وContentCategory:
- TYPE_MOVIES_AND_TV_SHOWS: اطّلِع على الكيانات من دليل دمج Watch قبل استخدام الكيانات العامة.
- TYPE_BOOKS: اطّلِع على EbookEntity قبل استخدام الكيانات العامة.
- TYPE_AUDIOBOOKS: اطّلِع على AudiobookEntity قبل استخدام الكيانات العامة.
- TYPE_SHOPPING: اطّلِع على ShoppingEntity قبل استخدام الكيانات العامة.
- TYPE_FOOD_AND_DRINK: اطّلِع على الكيانات من دليل دمج البيانات الغذائية قبل استخدام الكيانات العامة.
حقل ContentCategory اختياري ويجب تركه فارغًا إذا كان المحتوى لا ينتمي إلى أي من الفئات المذكورة سابقًا.
في حال تقديم فئات محتوى متعددة، يجب تقديمها بترتيب تصاعدي تبعًا لمدى صلة كل فئة بالمحتوى، مع وضع فئة المحتوى الأكثر صلة أولاً في القائمة.
الخطوة 2: تقديم بيانات المجموعة
ننصحك بتنفيذ مهمة نشر المحتوى في الخلفية (على سبيل المثال، باستخدام WorkManager) وتحديد موعد لها بانتظام أو استنادًا إلى حدث (على سبيل المثال، في كل مرة يفتح فيها المستخدم التطبيق أو عندما يضيف مستخدم عنصرًا إلى سلة التسوّق).
تتحمّل "AppEngagePublishClient
" مسؤولية نشر المجموعات.
في ما يلي واجهات برمجة التطبيقات التالية لنشر المجموعات في العميل:
isServiceAvailable
publishRecommendationClusters
publishFeaturedCluster
publishContinuationCluster
publishUserAccountManagementRequest
updatePublishStatus
deleteRecommendationsClusters
deleteFeaturedCluster
deleteContinuationCluster
deleteUserManagementCluster
deleteClusters
isServiceAvailable
تُستخدَم واجهة برمجة التطبيقات هذه للتحقّق مما إذا كانت الخدمة متاحة للدمج وما إذا كان يمكن عرض المحتوى على الجهاز.
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
تُستخدَم واجهة برمجة التطبيقات هذه لنشر قائمة بعناصر RecommendationCluster
.
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());
عندما تتلقّى الخدمة الطلب، يتم تنفيذ الإجراءات التالية في غضون معاملة واحدة:
- تتم إزالة بيانات
RecommendationCluster
الحالية من حساب شريك المطوّر. - يتم تحليل البيانات الواردة من الطلب وتخزينها في "مجموعة الاقتراحات" المعدَّلة.
في حال حدوث خطأ، يتم رفض الطلب بالكامل ويتم الحفاظ على الحالة الحالية.
publishFeaturedCluster
تُستخدَم واجهة برمجة التطبيقات هذه لنشر قائمة بعناصر FeaturedCluster
.
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());
عندما تتلقّى الخدمة الطلب، يتم تنفيذ الإجراءات التالية في غضون معاملة واحدة:
- تتم إزالة بيانات
FeaturedCluster
الحالية من حساب شريك المطوّر. - يتم تحليل البيانات الواردة من الطلب وتخزينها في "مجموعة الإعلانات المميّزة" المعدّلة.
في حال حدوث خطأ، يتم رفض الطلب بالكامل ويتم الحفاظ على الحالة الحالية.
publishContinuationCluster
تُستخدَم واجهة برمجة التطبيقات هذه لنشر عنصر ContinuationCluster
.
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());
عندما تتلقّى الخدمة الطلب، يتم تنفيذ الإجراءات التالية في غضون معاملة واحدة:
- تتم إزالة بيانات
ContinuationCluster
الحالية من حساب شريك المطوّر. - يتم تحليل البيانات الواردة من الطلب وتخزينها في ملف "مجموعة المتابعة" المعدَّل.
في حال حدوث خطأ، يتم رفض الطلب بالكامل ويتم الحفاظ على الحالة الحالية.
publishUserAccountManagementRequest
تُستخدَم واجهة برمجة التطبيقات هذه لنشر بطاقة تسجيل الدخول . يوجّه إجراء تسجيل الدخول المستخدمين إلى صفحة تسجيل الدخول في التطبيق حتى يتمكّن التطبيق من نشر المحتوى (أو تقديم محتوى أكثر تخصيصًا).
البيانات الوصفية التالية هي جزء من بطاقة تسجيل الدخول:
السمة | المتطلب | الوصف |
---|---|---|
معرّف الموارد المنتظم (URI) للإجراء | مطلوب | رابط لصفحة في التطبيق (أي ينقل إلى صفحة تسجيل الدخول إلى التطبيق) |
صورة | اختيارية - يجب تقديم العنوان في حال عدم تقديمه |
الصورة المعروضة على البطاقة صور بنسبة عرض إلى ارتفاع 16×9 بدرجة دقة 1264×712 |
العنوان | اختيارية - يجب تقديم صورة في حال عدم توفّرها | العنوان الظاهر على البطاقة |
نص الإجراء | اختياري | النص المعروض في عبارة الحثّ على اتّخاذ إجراء (مثل "تسجيل الدخول") |
العنوان الفرعي | اختياري | ترجمة اختيارية على البطاقة |
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());
عندما تتلقّى الخدمة الطلب، يتم تنفيذ الإجراءات التالية في غضون معاملة واحدة:
- تتم إزالة بيانات
UserAccountManagementCluster
الحالية من المطوّر الشريك. - يتم تحليل البيانات الواردة من الطلب وتخزينها في ملف تعريف clustered UserAccountManagementCluster المعدَّل.
في حال حدوث خطأ، يتم رفض الطلب بالكامل ويتم الحفاظ على الحالة الحالية.
updatePublishStatus
إذا لم يتم نشر أيّ من المجموعات لأيّ سبب داخلي متعلق بالنشاط التجاري، ننصح بشدة بتعديل حالة النشر باستخدام واجهة برمجة التطبيقات updatePublishStatus. وهذا أمر مهم للأسباب التالية :
- من المهم تقديم الحالة في جميع السيناريوهات، حتى عند نشر المحتوى (STATUS == PUBLISHED)، وذلك لملء لوحات البيانات التي تستخدِم هذه الحالة الواضحة للتعبير عن حالة الدمج والمقاييس الأخرى.
- إذا لم يتم نشر أي محتوى ولكن حالة الدمج ليست متعطّلة (STATUS == NOT_PUBLISHED)، يمكن أن تتجنب Google تنشيط التنبيهات في لوحات بيانات صحة التطبيق. يؤكد ذلك عدم نشر المحتوى بسبب حالة متوقّعة من وجهة نظر مقدّم الخدمة.
- ويساعد المطوّرين في تقديم إحصاءات عن الحالات التي يتم فيها نشر البيانات مقارنةً بحالات عدم نشرها.
- قد تستخدم Google رموز الحالة لحثّ المستخدم على اتّخاذ إجراءات معيّنة في التطبيق حتى يتمكّن من الاطّلاع على محتوى التطبيق أو حلّ المشكلة.
في ما يلي قائمة برموز حالة النشر المؤهَّلة :
// 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
إذا لم يتم نشر المحتوى بسبب عدم تسجيل دخول المستخدم، سينصح فريق Google بنشر بطاقة تسجيل الدخول. إذا لم يتمكّن مقدّمو الخدمة من نشر بطاقة تسجيل الدخول لأي سبب، ننصحك بالاتصال بواجهة برمجة التطبيقات updatePublishStatus باستخدام رمز الحالة NOT_PUBLISHED_REQUIRES_SIGN_IN.
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
تُستخدَم واجهة برمجة التطبيقات هذه لحذف محتوى مجموعات الاقتراحات.
Kotlin
client.deleteRecommendationClusters()
Java
client.deleteRecommendationClusters();
عندما تتلقّى الخدمة الطلب، تزيل البيانات الحالية من مجموعات الاقتراحات. في حال حدوث خطأ، يتم رفض الطلب بالكامل ويظلّ الإجراء الحالي ساريًا.
deleteFeaturedCluster
تُستخدَم واجهة برمجة التطبيقات هذه لحذف محتوى "المجموعات المميّزة".
Kotlin
client.deleteFeaturedCluster()
Java
client.deleteFeaturedCluster();
عندما تتلقّى الخدمة الطلب، تزيل البيانات الحالية من المجموعة المميّزة. في حال حدوث خطأ، يتم رفض الطلب بالكامل ويتم الاحتفاظ بالحالة الحالية.
deleteContinuationCluster
تُستخدَم واجهة برمجة التطبيقات هذه لحذف محتوى "مجموعة المتابعة".
Kotlin
client.deleteContinuationCluster()
Java
client.deleteContinuationCluster();
عندما تتلقّى الخدمة الطلب، تزيل البيانات الحالية من مجموعة المتابعة. في حال حدوث خطأ، يتم رفض الطلب بالكامل ويظلّ الإجراء الحالي ساريًا.
deleteUserManagementCluster
تُستخدَم واجهة برمجة التطبيقات هذه لحذف محتوى UserAccountManagement Cluster.
Kotlin
client.deleteUserManagementCluster()
Java
client.deleteUserManagementCluster();
عندما تتلقى الخدمة الطلب، تزيل البيانات الحالية من مجموعة UserAccountManagement. في حال حدوث خطأ، يتم رفض الطلب بالكامل ويبقى الوضع الحالي كما هو.
deleteClusters
تُستخدَم واجهة برمجة التطبيقات هذه لحذف محتوى نوع مجموعة معيّن.
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());
عندما تتلقّى الخدمة الطلب، تزيل البيانات الحالية من جميع المجموعات التي تتطابق مع أنواع المجموعات المحدّدة. يمكن للعملاء اختيار تمرير نوع واحد أو العديد من أنواع المجموعات. في حال حدوث خطأ، يتم رفض الطلب بالكامل ويتم الاحتفاظ بالحالة الحالية.
معالجة الأخطاء
ننصحك بشدة بالاستماع إلى نتيجة المهمة من واجهات برمجة التطبيقات للنشر، وذلك لاتخاذ إجراء متابعة لاسترداد مهمة ناجحة وإعادة إرسالها.
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 } } } });
يتم عرض الخطأ على أنّه AppEngageException
مع تضمين السبب على أنّه
رمز خطأ.
رمز الخطأ | اسم الخطأ | ملاحظة |
---|---|---|
1 |
SERVICE_NOT_FOUND |
الخدمة غير متاحة على الجهاز المحدّد. |
2 |
SERVICE_NOT_AVAILABLE |
الخدمة متاحة على الجهاز المحدّد، ولكنها غير متاحة في وقت المكالمة (على سبيل المثال، تم إيقافها صراحةً). |
3 |
SERVICE_CALL_EXECUTION_FAILURE |
تعذّر تنفيذ المهمة بسبب مشاكل في سلسلة المهام. في هذه الحالة، يمكن إعادة المحاولة. |
4 |
SERVICE_CALL_PERMISSION_DENIED |
لا يُسمح للمتصل بإجراء مكالمة الدعم. |
5 |
SERVICE_CALL_INVALID_ARGUMENT |
يحتوي الطلب على بيانات غير صالحة (على سبيل المثال، أكثر من عدد المجموعات المسموح به). |
6 |
SERVICE_CALL_INTERNAL |
حدث خطأ من جهة الخدمة. |
7 |
SERVICE_CALL_RESOURCE_EXHAUSTED |
يتم إجراء طلب الخدمة بشكل متكرّر جدًا. |
الخطوة 3: معالجة نوايا البث
بالإضافة إلى إجراء طلبات نشر المحتوى من واجهة برمجة التطبيقات من خلال مهمة، يجب أيضًا
إعداد
BroadcastReceiver
لتلقّي
طلب نشر المحتوى.
يتمثل الهدف الرئيسي من أذونات البث في إعادة تفعيل التطبيق وفرض مزامنة البيانات. لم يتم تصميم مكوّنات intent للبث لإرسالها بشكل متكرّر جدًا. ولا يتم تفعيله إلا عندما تحدّد "خدمة التفاعل" أنّ المحتوى قد يكون قديمًا (مثلاً، إذا مرّ عليه أسبوع). بهذه الطريقة، يمكن للمستخدم الاستفادة من تجربة محتوى جديدة، حتى إذا لم يتم تنفيذ التطبيق لعدة أشهر.
يجب إعداد BroadcastReceiver
بالطريقتَين التاليتَين:
- سجِّل مثيلًا من فئة
BroadcastReceiver
ديناميكيًا باستخدامContext.registerReceiver()
. يتيح ذلك التواصل من التطبيقات التي لا تزال نشطة في الذاكرة.
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)); }
- حدِّد التنفيذ بشكلٍ ثابت باستخدام علامة
<receiver>
في ملفAndroidManifest.xml
. يتيح ذلك للتطبيق تلقّي طلبات البث عندما لا يكون قيد التشغيل، كما يتيح للتطبيق نشر المحتوى.
<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>
تُرسِل ال خدمةالأهداف التالية:
com.google.android.engage.action.PUBLISH_RECOMMENDATION
يُنصح ببدء مكالمةpublishRecommendationClusters
عند تلقّي هذه النية.com.google.android.engage.action.PUBLISH_FEATURED
ننصح ببدء مكالمةpublishFeaturedCluster
عند تلقّي هذا الطلب.com.google.android.engage.action.PUBLISH_CONTINUATION
ننصح ببدء مكالمةpublishContinuationCluster
عند تلقّي هذا الطلب.
سير عمل الدمج
للحصول على دليل مفصّل حول التحقّق من عملية الدمج بعد اكتمالها، يُرجى الاطّلاع على Engage developer integration workflow (سير عمل دمج المطوّرين).
الأسئلة الشائعة
يمكنك الاطّلاع على الأسئلة الشائعة حول حزمة Engage SDK للحصول على الأسئلة الشائعة.
التواصل
يُرجى التواصل مع engage-developers@google.com إذا كانت لديك أي أسئلة أثناء عملية الدمج.
الخطوات التالية
بعد إكمال عملية الدمج هذه، اتّبِع الخطوات التالية:
- أرسِل رسالة إلكترونية إلى engage-developers@google.com وقم بإرفاق حزمة APK المدمجة الجاهزة لاختبارها من قِبل Google.
- تُجري Google عملية تحقّق ومراجعات داخلية للتأكّد من أنّ عملية دمج التطبيق تعمل على النحو المتوقّع. إذا كانت هناك حاجة إلى إجراء تغييرات، ستتواصل معك Google لإطلاعك على أي تفاصيل ضرورية.
- عند اكتمال الاختبار وعدم الحاجة إلى إجراء أي تغييرات، تتواصل معك Google لإعلامك بأنّه يمكنك بدء نشر حزمة APK المعدَّلة والمدمجة على "متجر Play".
- بعد أن تؤكد Google أنّه تم نشر حزمة APK المعدَّلة على متجر Play، قد يتم نشر مجموعات الاقتراحات والمحتوى المميّز والمحتوى الذي يتابعه المستخدمون وتصبح مرئية للمستخدمين.