با دسترسی به کاربران خود در هر کجا که هستند، تعامل با برنامه را افزایش دهید. Engage SDK را ادغام کنید تا توصیههای شخصیسازیشده و محتوای مداوم را مستقیماً به کاربران در سطوح مختلف روی دستگاه، مانند Collections ، Entertainment Space و Play Store ارائه دهید. این ادغام کمتر از ۵۰ کیلوبایت (فشردهشده) به میانگین APK اضافه میکند و برای اکثر برنامهها حدود یک هفته از زمان توسعهدهنده را میگیرد. برای اطلاعات بیشتر به سایت تجاری ما مراجعه کنید.
این راهنما شامل دستورالعملهایی برای شرکای توسعهدهنده است تا محتوای خرید را به سطوح محتوای Engage ارسال کنند.
جزئیات ادغام
اصطلاحات
این ادغام شامل پنج نوع خوشه زیر است: توصیه ، ویژه ، سبد خرید ، لیست خرید ، سفارش مجدد و پیگیری سفارش خرید .
خوشههای توصیه، پیشنهادهای خرید شخصیسازیشده از یک شریک توسعهدهنده را نشان میدهند. این توصیهها میتوانند برای کاربر شخصیسازی شده یا عمومی شوند (برای مثال، اقلام پرطرفدار). از این موارد برای نمایش محصولات، رویدادها، فروشها، تبلیغات و اشتراکها، به دلخواه خود استفاده کنید.
توصیههای شما ساختار زیر را دارند:
خوشه توصیه: یک نمای رابط کاربری که شامل گروهی از توصیهها از یک شریک توسعهدهنده است.
ShoppingEntity: یک شیء که نشاندهنده یک آیتم واحد در یک خوشه است.
خوشه ویژه ، مجموعهای از موجودیتها را از چندین شریک توسعهدهنده در یک گروهبندی رابط کاربری نمایش میدهد. یک خوشه ویژه وجود خواهد داشت که در نزدیکی بالای رابط کاربری با اولویت بالاتر از همه خوشههای توصیه نمایش داده میشود. هر شریک توسعهدهنده مجاز به پخش حداکثر 10 موجودیت در خوشه ویژه خواهد بود.
خوشه سبد خرید، نگاهی اجمالی به سبدهای خرید بسیاری از شرکای توسعهدهنده در یک گروهبندی رابط کاربری نشان میدهد و کاربران را به تکمیل سبدهای خرید معوقهشان ترغیب میکند. یک خوشه سبد خرید واحد وجود دارد که در نزدیکی بالای رابط کاربری ظاهر میشود و دارای اولویت قرار گرفتن بالاتر از همه خوشههای توصیه است. هر شریک توسعهدهنده مجاز است تا حداکثر ۳ نمونه
ShoppingCartدر خوشه سبد خرید منتشر کند.سبد خرید شما ساختار زیر را دارد:
خوشه سبد خرید: یک نمای رابط کاربری که شامل گروهی از پیشنمایشهای سبد خرید از بسیاری از شرکای توسعهدهنده است.
ShoppingCart: یک شیء که پیشنمایش سبد خرید را برای یک شریک توسعهدهندهی واحد نشان میدهد و در خوشهی Shopping Cart نمایش داده میشود.
ShoppingCartباید تعداد کل اقلام موجود در سبد خرید را نشان دهد و همچنین میتواند شامل تصاویری برای برخی از اقلام موجود در سبد خرید کاربر باشد.
خوشه فهرست خرید ، نگاهی اجمالی به فهرستهای خرید چندین شریک توسعهدهنده در یک گروهبندی رابط کاربری نشان میدهد و کاربران را ترغیب میکند تا برای بهروزرسانی و تکمیل فهرستهای خود به برنامه مربوطه برگردند. یک خوشه فهرست خرید واحد وجود دارد.
خوشه Reorder نگاهی اجمالی به سفارشهای قبلی چندین شریک توسعهدهنده در یک گروهبندی رابط کاربری نشان میدهد و کاربران را به سفارش مجدد ترغیب میکند. یک خوشه Reorder واحد وجود دارد.
خوشه مرتبسازی مجدد باید تعداد کل اقلام سفارش قبلی کاربر را نشان دهد و همچنین باید شامل یکی از موارد زیر باشد:
- تصاویر مربوط به X مورد از سفارش قبلی کاربر.
- برچسبهایی برای X مورد در سفارش قبلی کاربر.
خوشه پیگیری سفارش خرید ، نگاهی اجمالی به سفارشهای خرید در حال انتظار یا اخیراً تکمیلشده از بسیاری از شرکای توسعهدهنده در یک گروهبندی رابط کاربری نشان میدهد و به کاربران امکان میدهد سفارشهای خود را پیگیری کنند.
یک خوشه ShoppingOrderTracking واحد وجود دارد که در نزدیکی بالای رابط کاربری ظاهر میشود و اولویت آن بالاتر از همه خوشههای توصیه (Recommendation) است. هر شریک توسعهدهنده مجاز است چندین مورد ShoppingOrderTrackingEntity را در خوشه Shopping Order Tracking پخش کند.
کلاستر ShoppingOrderTrackingCluster شما ساختار زیر را میگیرد:
- خوشه ردیابی سفارش خرید : یک نمای رابط کاربری که شامل گروهی از پیشنمایشهای ردیابی سفارش از بسیاری از شرکای توسعهدهنده است.
- ShoppingOrderTrackingEntity : یک شیء که پیشنمایش ردیابی سفارش خرید را برای یک شریک توسعهدهنده واحد نشان میدهد و در خوشه Shopping Order Tracking نمایش داده میشود. ShoppingOrderTrackingEntity باید وضعیت سفارش و زمان سفارش را نشان دهد. اکیداً توصیه میکنیم زمان تحویل مورد انتظار را برای ShoppingOrderTrackingEntity وارد کنید، زیرا در صورت ارائه به کاربران نمایش داده میشود.
پیش کار
حداقل سطح API: ۱۹
کتابخانه 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.11'
}
برای اطلاعات بیشتر، به بخش «قابلیت مشاهده بستهها در اندروید ۱۱» مراجعه کنید.
خلاصه
طراحی بر اساس پیادهسازی یک سرویس محدود (bound service) است.
دادههایی که یک کلاینت میتواند منتشر کند، برای انواع مختلف خوشهها مشمول محدودیتهای زیر است:
| نوع خوشه | محدودیتهای خوشه | حداکثر محدودیتهای موجودیت در یک خوشه |
|---|---|---|
| خوشه(های) پیشنهادی | حداکثر ۷ عدد | حداکثر ۵۰ واحد ShoppingEntity |
| خوشه ویژه | حداکثر ۱ | حداکثر 20 ShoppingEntity |
| خوشه سبد خرید | حداکثر ۱ | حداکثر ۳ ShoppingCartسبد خرید چندگانه فقط برای برنامههایی که سبد خرید جداگانه برای هر فروشنده دارند، قابل انتظار است. |
| خوشه لیست خرید | حداکثر ۱ | حداکثر ۳ ShoppingList |
| خوشه سفارش مجدد خرید | حداکثر ۱ | حداکثر ۱ ReorderEntity |
| خوشه پیگیری سفارش خرید | حداکثر ۳ عدد | حداکثر ۳ ShoppingOrderTrackingEntity |
مرحله ۱: ارائه دادههای موجودیت
SDK برای نمایش هر نوع کالا، موجودیتهای مختلفی تعریف کرده است. موجودیتهای زیر برای دستهبندی خرید پشتیبانی میشوند:
-
ShoppingEntity -
ShoppingCart -
ShoppingList -
Reorder -
ShoppingOrderTracking
نمودارهای زیر ویژگیها و الزامات موجود برای هر نوع را شرح میدهند.
ShoppingEntity
شیء ShoppingEntity نشاندهنده یک محصول، تبلیغ، معامله، اشتراک یا رویدادی است که شرکای توسعهدهنده میخواهند منتشر کنند.
ShoppingEntity
| ویژگی | مورد نیاز | توضیحات | قالب |
|---|---|---|---|
| تصاویر پوستر | مورد نیاز | حداقل یک تصویر باید ارائه شود. | برای راهنمایی به مشخصات تصویر مراجعه کنید. |
| اکشن اوری | مورد نیاز | لینک عمیق به صفحهای در برنامه که جزئیات مربوط به موجودیت را نمایش میدهد. توجه: میتوانید از لینکهای عمیق برای ارجاع استفاده کنید. به این سوالات متداول مراجعه کنید. | اوری |
| عنوان | اختیاری | نام نهاد. | متن رایگان اندازه متن پیشنهادی: کمتر از ۹۰ کاراکتر (متن خیلی طولانی ممکن است بیضی نشان دهد) |
| قیمت - فعلی | مشروط مورد نیاز | قیمت فعلی نهاد. در صورت ارائه قیمت خط خورده، باید ارائه شود. | متن رایگان |
| قیمت - خط خورده | اختیاری | قیمت اصلی کالا که در رابط کاربری خط خورده است. | متن رایگان |
| فراخوان | اختیاری | در صورت امکان، برای ارائه یک تبلیغ، رویداد یا بهروزرسانی برای نهاد، فراخوان دهید. | متن رایگان اندازه متن پیشنهادی: کمتر از ۴۵ کاراکتر (متن خیلی طولانی ممکن است بیضی نشان دهد) |
| چاپ خوب را بنویسید | اختیاری | متن چاپی زیبا برای توضیحات. | متن رایگان اندازه متن پیشنهادی: کمتر از ۴۵ کاراکتر (متن خیلی طولانی ممکن است بیضی نشان دهد) |
| امتیاز (اختیاری) - توجه: همه امتیازها با استفاده از سیستم امتیازدهی ستارهای استاندارد ما نمایش داده میشوند. | |||
| رتبهبندی - حداکثر مقدار | اختیاری | حداکثر مقدار مقیاس رتبهبندی. اگر مقدار فعلی رتبهبندی نیز ارائه شده باشد، باید ارائه شود. | عدد >= 0.0 |
| رتبهبندی - ارزش فعلی | اختیاری | مقدار فعلی مقیاس رتبهبندی. اگر حداکثر مقدار رتبهبندی نیز ارائه شده باشد، باید ارائه شود. | عدد >= 0.0 |
| رتبهبندی - تعداد | اختیاری | تعداد رتبهبندیها برای نهاد. نکته: اگر برنامه شما نحوه نمایش تعداد به کاربران را کنترل میکند، این فیلد را ارائه دهید. از یک رشته مختصر استفاده کنید. برای مثال، اگر تعداد ۱,۰۰۰,۰۰۰ است، استفاده از مخففی مانند ۱M را در نظر بگیرید تا تعداد در اندازههای کوچکتر صفحه نمایش کوتاه نشود. | رشته |
| رتبهبندی - مقدار شمارش | اختیاری | تعداد رتبهبندیها برای نهاد. نکته: اگر خودتان منطق نمایش اختصارات را مدیریت نمیکنید، این فیلد را وارد کنید. اگر هم تعداد و هم مقدار تعداد وجود داشته باشند، تعداد به کاربران نمایش داده میشود. | طولانی |
| DisplayTimeWindow (اختیاری) - یک پنجره زمانی برای نمایش محتوا روی سطح تنظیم کنید | |||
| شروع مهر زمانی | اختیاری | مهر زمانیِ دورهای که پس از آن محتوا باید روی سطح نمایش داده شود. اگر تنظیم نشده باشد، محتوا واجد شرایط نمایش روی سطح است. | مهر زمانی عصر بر حسب میلی ثانیه |
| مهر زمان پایان | اختیاری | مهر زمانیِ دورهای که پس از آن محتوا دیگر روی سطح نمایش داده نمیشود. اگر تنظیم نشده باشد، محتوا واجد شرایط نمایش روی سطح است. | مهر زمانی عصر بر حسب میلی ثانیه |
ShoppingCart
| ویژگی | مورد نیاز | توضیحات | قالب |
|---|---|---|---|
| اکشن اوری | مورد نیاز | لینک عمیق به سبد خرید در اپلیکیشن همکار. توجه: میتوانید از لینکهای عمیق برای ارجاع استفاده کنید. به این سوالات متداول مراجعه کنید. | اوری |
| تعداد اقلام | مورد نیاز | تعداد اقلام (نه فقط تعداد محصولات) در سبد خرید. برای مثال: اگر ۳ پیراهن یکسان و ۱ کلاه در سبد خرید وجود دارد، این عدد باید ۴ باشد. | عدد صحیح >= 1 |
| متن اکشن | اختیاری | متن فراخوان برای اقدام (Call to action) دکمهی روی سبد خرید (برای مثال، «کیف خرید شما »). اگر هیچ متن عملیاتی توسط توسعهدهنده ارائه نشده باشد، مشاهده سبد خرید پیشفرض است. این ویژگی در نسخه ۱.۱.۰ به بعد پشتیبانی میشود. | رشته |
| عنوان | اختیاری | عنوان سبد خرید (برای مثال، کیف خرید شما ). اگر هیچ عنوانی توسط توسعهدهنده ارائه نشده باشد، سبد خرید شما پیشفرض است. اگر شریک توسعهدهنده برای هر فروشنده سبد خرید جداگانهای منتشر میکند، لطفاً نام فروشنده را در عنوان ذکر کنید. | متن رایگان اندازه متن پیشنهادی: کمتر از ۲۵ کاراکتر (متن خیلی طولانی ممکن است بیضی نشان دهد) |
| تصاویر سبد خرید | اختیاری | تصاویر هر محصول در سبد خرید حداکثر 10 تصویر را میتوان به ترتیب اولویت ارائه داد؛ تعداد واقعی تصاویر نمایش داده شده به شکل دستگاه بستگی دارد. | برای راهنمایی به مشخصات تصویر مراجعه کنید. |
| برچسبهای کالا | اختیاری | فهرست برچسبهای اقلام موجود در فهرست خرید. تعداد واقعی برچسبهای نمایش داده شده به فاکتور فرم دستگاه بستگی دارد. | فهرست برچسبهای متنی رایگان اندازه متن پیشنهادی: کمتر از ۲۰ کاراکتر (متن خیلی طولانی ممکن است بیضی نشان دهد) |
| آخرین زمان تعامل کاربر | اختیاری | تعداد میلیثانیههای سپریشده از دوره، که آخرین باری که کاربر با سبد خرید تعامل داشته است را مشخص میکند. این به عنوان ورودی توسط شرکای توسعهدهنده ارسال میشود و سبد خرید جداگانهای را برای هر فروشنده منتشر میکند و شاید برای رتبهبندی استفاده شود. | مهر زمانی عصر بر حسب میلی ثانیه |
| DisplayTimeWindow (اختیاری) - یک پنجره زمانی برای نمایش محتوا روی سطح تنظیم کنید | |||
| شروع مهر زمانی | اختیاری | مهر زمانیِ دورهای که پس از آن محتوا باید روی سطح نمایش داده شود. اگر تنظیم نشده باشد، محتوا واجد شرایط نمایش روی سطح است. | مهر زمانی عصر بر حسب میلی ثانیه |
| مهر زمان پایان | اختیاری | مهر زمانیِ دورهای که پس از آن محتوا دیگر روی سطح نمایش داده نمیشود. اگر تنظیم نشده باشد، محتوا واجد شرایط نمایش روی سطح است. | مهر زمانی عصر بر حسب میلی ثانیه |
ShoppingList
| ویژگی | مورد نیاز | توضیحات | قالب |
|---|---|---|---|
| اکشن اوری | مورد نیاز | لینک عمیق به لیست خرید در اپلیکیشن همکار. توجه: میتوانید از لینکهای عمیق برای ارجاع استفاده کنید. به این سوالات متداول مراجعه کنید. | اوری |
| تعداد اقلام | مورد نیاز | تعداد اقلام موجود در لیست خرید. | عدد صحیح >= 1 |
| عنوان | اختیاری | عنوان لیست (برای مثال، لیست خرید شما ). اگر هیچ عنوانی توسط توسعهدهنده ارائه نشده باشد، فهرست خرید پیشفرض است. | متن رایگان اندازه متن پیشنهادی: کمتر از ۲۵ کاراکتر (متن خیلی طولانی ممکن است بیضی نشان دهد) |
| برچسبهای کالا | مورد نیاز | فهرست برچسبهای اقلام موجود در فهرست خرید. حداقل ۱ برچسب باید ارائه شود و تا ۱۰ برچسب میتواند به ترتیب اولویت ارائه شود؛ تعداد واقعی برچسبهای نمایش داده شده به شکل دستگاه بستگی دارد. | فهرست برچسبهای متنی رایگان اندازه متن پیشنهادی: کمتر از ۲۰ کاراکتر (متن خیلی طولانی ممکن است بیضی نشان دهد) |
| آخرین زمان تعامل کاربر | مورد نیاز | تعداد میلیثانیههای سپریشده از هر دوره (epoch)، که آخرین باری را که کاربر با لیست خرید تعامل داشته است، مشخص میکند. | مهر زمانی عصر بر حسب میلی ثانیه |
ShoppingReorderCluster
| ویژگی | مورد نیاز | توضیحات | قالب |
|---|---|---|---|
| اکشن اوری | مورد نیاز | لینک عمیق برای مرتبسازی مجدد در برنامهی شریک. توجه: میتوانید از لینکهای عمیق برای ارجاع استفاده کنید. به این سوالات متداول مراجعه کنید. | اوری |
| متن اکشن | اختیاری | متن فراخوان برای اقدام (call to action) دکمهی «سفارش مجدد» (برای مثال، «دوباره سفارش دهید »). اگر هیچ متن عملیاتی توسط توسعهدهنده ارائه نشده باشد، «ترتیببندی مجدد» پیشفرض است. این ویژگی در نسخه ۱.۱.۰ به بعد پشتیبانی میشود. | رشته |
| تعداد اقلام | مورد نیاز | تعداد اقلام (نه فقط تعداد محصولات) در سفارش قبلی. برای مثال: اگر در سفارش قبلی ۳ قهوه کوچک و ۱ کروسان وجود داشته، این عدد باید ۴ باشد. | عدد صحیح >= 1 |
| عنوان | مورد نیاز | عنوان کالای سفارش مجدد. | متن رایگان اندازه متن پیشنهادی: کمتر از ۴۰ کاراکتر (متن خیلی طولانی ممکن است بیضی نشان دهد) |
| برچسبهای کالا | اختیاری (در صورت عدم ارائه، تصاویر پوستر باید ارائه شوند) | لیست برچسبهای کالا برای سفارش قبلی. حداکثر 10 برچسب را میتوان به ترتیب اولویت ارائه داد؛ تعداد واقعی برچسبهای نمایش داده شده به شکل دستگاه بستگی دارد. | فهرست متنهای رایگان اندازه متن پیشنهادی برای هر برچسب: کمتر از ۲۰ کاراکتر (متن خیلی طولانی ممکن است بیضی نشان دهد) |
| تصاویر پوستر | اختیاری (در صورت عدم ارائه، برچسب کالا باید ارائه شود) | تصاویر اقلام سفارش قبلی. حداکثر 10 تصویر را میتوان به ترتیب اولویت ارائه داد؛ تعداد واقعی تصاویر نمایش داده شده به شکل دستگاه بستگی دارد. | برای راهنمایی به مشخصات تصویر مراجعه کنید. |
ShoppingOrderTrackingCluster
| ویژگی | مورد نیاز | توضیحات | قالب |
|---|---|---|---|
| عنوان | مورد نیاز | عنوان کوتاهی از بسته/اقلام مورد پیگیری یا شماره پیگیری. | متن رایگان اندازه متن پیشنهادی: ۵۰ کاراکتر (متن خیلی طولانی بیضی نشان میدهد) |
| نوع سفارش | مورد نیاز | عنوان کوتاهی از بسته/اقلام مورد پیگیری یا شماره پیگیری. | شمارشی: تحویل در فروشگاه، تحویل در همان روز، تحویل چند روزه |
| وضعیت | مورد نیاز | وضعیت فعلی سفارش. برای مثال: «دیر رسید»، «در حال حمل»، «تأخیر»، «ارسال شده»، «تحویل داده شده»، «ناموجود»، «سفارش آماده است» | متن رایگان اندازه متن پیشنهادی: ۲۵ کاراکتر (متن خیلی طولانی بیضی نشان میدهد) |
| زمان سفارش | مورد نیاز | مهر زمانی دوره زمانی (epoch) که سفارش در آن ثبت شده است (به میلیثانیه). اگر بازه زمانی تحویل مورد انتظار وجود نداشته باشد، زمان سفارش نمایش داده خواهد شد. | مهر زمانی عصر بر حسب میلی ثانیه |
| اکشن اوری | مورد نیاز | لینک عمیق به پیگیری سفارش در اپلیکیشن همکار. | اوری |
| پنجره زمان تحویل سفارش (اختیاری) - یک بازه زمانی برای سفارشی که از زمان ثبت سفارش تا زمان تحویل مورد انتظار/واقعی پیگیری میشود، تنظیم کنید. | |||
| پنجره زمان تحویل سفارش - زمان شروع | اختیاری | مهر زمانی دوره زمانی (برحسب میلیثانیه) که در آن/پس از آن سفارش تحویل داده میشود یا آماده دریافت است. | مهر زمانی عصر بر حسب میلی ثانیه |
| پنجره زمان تحویل سفارش - زمان پایان | اختیاری | مهر زمانی دوره زمانی (برحسب میلیثانیه) که سفارش در آن/قبل از آن تحویل داده میشود یا آماده دریافت است. | مهر زمانی عصر بر حسب میلی ثانیه |
| تصاویر پوستر | اختیاری | تصویر یک کالا/محصول که بخشی از سفارش است. نسبت ابعاد توصیه شده ۱:۱ است | برای راهنمایی به مشخصات تصویر مراجعه کنید. |
| تعداد اقلام | اختیاری | تعداد اقلام موجود در سفارش. | عدد صحیح >= 1 |
| توضیحات | اختیاری | یک پاراگراف متن برای توصیف موارد موجود در سفارش. توجه: یا توضیحات یا فهرست زیرنویسها به کاربر نمایش داده میشود، نه هر دو. | متن رایگان اندازه متن پیشنهادی: ۱۸۰ کاراکتر |
| فهرست زیرنویسها | اختیاری | حداکثر ۳ زیرنویس، که هر زیرنویس شامل یک خط متن است. توجه: یا توضیحات یا فهرست زیرنویسها به کاربر نمایش داده میشود، نه هر دو. | متن رایگان اندازه متن پیشنهادی برای هر زیرنویس: حداکثر ۵۰ کاراکتر |
| مقدار سفارش - قیمت فعلی | اختیاری | ارزش فعلی سفارش. | متن رایگان |
| شماره سفارش | اختیاری | شماره/شناسه سفارش که میتواند برای شناسایی منحصر به فرد سفارش استفاده شود. | متن رایگان اندازه متن پیشنهادی: حداکثر ۲۵ کاراکتر |
| شماره پیگیری | اختیاری | شماره پیگیری برای تحویل سفارش/بسته در صورتی که سفارش نیاز به تحویل داشته باشد. | متن رایگان اندازه متن پیشنهادی: حداکثر ۲۵ کاراکتر |
مشخصات تصویر
مشخصات مورد نیاز برای تصاویر در زیر فهرست شده است:
| نسبت ابعاد | حداقل پیکسلها | پیکسلهای توصیهشده |
|---|---|---|
مربع (۱x۱) برای خوشههای غیرویژه ترجیح داده میشود | ۳۰۰x۳۰۰ | ۱۲۰۰x۱۲۰۰ |
منظره (۱.۹۱x۱) برای خوشههای ویژه ترجیح داده میشود | ۶۰۰x۳۱۴ | ۱۲۰۰x۶۲۸ |
| پرتره (۴x۵) | ۴۸۰x۶۰۰ | ۹۶۰x۱۲۰۰ |
فرمتهای فایل
PNG، JPG، GIF ثابت، WebP
حداکثر اندازه فایل
۵۱۲۰ کیلوبایت
توصیههای اضافی
- ناحیه امن تصویر: محتوای مهم خود را در مرکز ۸۰٪ تصویر قرار دهید.
- از یک پسزمینه شفاف استفاده کنید تا تصویر در تنظیمات تم تیره و روشن به درستی نمایش داده شود.
مرحله ۲: ارائه دادههای خوشهای
توصیه میشود که کار انتشار محتوا در پسزمینه اجرا شود (برای مثال، با استفاده از WorkManager ) و به صورت منظم یا بر اساس یک رویداد (مثلاً هر بار که کاربر برنامه را باز میکند یا وقتی کاربر چیزی را به سبد خرید خود اضافه میکند) برنامهریزی شود.
AppEngageShoppingClient مسئول انتشار خوشههای خرید است.
API های زیر برای انتشار خوشه ها در کلاینت در دسترس هستند:
-
isServiceAvailable -
publishRecommendationClusters -
publishFeaturedCluster -
publishShoppingCarts -
publishShoppingLists -
publishShoppingReorderCluster -
publishShoppingOrderTrackingCluster -
publishUserAccountManagementRequest -
updatePublishStatus -
deleteRecommendationsClusters -
deleteFeaturedCluster -
deleteShoppingCartCluster -
deleteShoppingListCluster -
deleteShoppingReorderCluster -
deleteShoppingOrderTrackingCluster -
deleteUserManagementCluster -
deleteClusters
isServiceAvailable
این API برای بررسی اینکه آیا سرویس برای ادغام در دسترس است و آیا محتوا میتواند روی دستگاه ارائه شود، استفاده میشود.
کاتلین
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.
}
}
جاوا
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
این API برای انتشار فهرستی از اشیاء RecommendationCluster استفاده میشود.
یک شیء RecommendationCluster میتواند ویژگیهای زیر را داشته باشد:
| ویژگی | مورد نیاز | توضیحات |
|---|---|---|
| فهرست واحدهای خرید | مورد نیاز | فهرستی از اشیاء ShoppingEntity که توصیههای این خوشه توصیه را تشکیل میدهند. |
| عنوان | مورد نیاز | عنوان خوشه توصیهها. اندازه متن پیشنهادی: کمتر از ۲۵ کاراکتر (متن خیلی طولانی ممکن است بیضی نشان دهد) |
| زیرنویس | اختیاری | عنوان فرعی برای خوشه توصیهها. |
| اکشن اوری | اختیاری | لینک عمیق به صفحهای در برنامهی همکار که کاربران میتوانند لیست کامل توصیهها را در آن مشاهده کنند. توجه: میتوانید از لینکهای عمیق برای ارجاع استفاده کنید. به این سوالات متداول مراجعه کنید. |
کاتلین
client.publishRecommendationClusters(
PublishRecommendationClustersRequest.Builder()
.addRecommendationCluster(
RecommendationCluster.Builder()
.addEntity(entity1)
.addEntity(entity2)
.setTitle("Black Friday Deals")
.build())
.build())
جاوا
client.publishRecommendationClusters(
new PublishRecommendationClustersRequest.Builder()
.addRecommendationCluster(
new RecommendationCluster.Builder()
.addEntity(entity1)
.addEntity(entity2)
.setTitle("Black Friday Deals")
.build())
.build());
وقتی سرویس درخواست را دریافت میکند، اقدامات زیر در یک تراکنش انجام میشود:
- تمام دادههای موجود در خوشه توصیه حذف میشوند.
- دادههای درخواست تجزیه و تحلیل شده و در خوشههای توصیه جدید ذخیره میشوند.
در صورت بروز خطا، کل درخواست رد میشود و وضعیت موجود حفظ میشود.
publishFeaturedCluster
این API برای انتشار یک شیء FeaturedCluster استفاده میشود.
کاتلین
client.publishFeaturedCluster(
PublishFeaturedClusterRequest.Builder()
.setFeaturedCluster(
FeaturedCluster.Builder()
...
.build())
.build())
جاوا
client.publishFeaturedCluster(
new PublishFeaturedClusterRequest.Builder()
.setFeaturedCluster(
new FeaturedCluster.Builder()
...
.build())
.build());
وقتی سرویس درخواست را دریافت میکند، اقدامات زیر در یک تراکنش انجام میشود:
- دادههای
FeaturedClusterموجود از شریک توسعهدهنده حذف میشوند. - دادههای حاصل از درخواست، تجزیه و تحلیل شده و در Featured Cluster بهروزرسانیشده ذخیره میشوند.
در صورت بروز خطا، کل درخواست رد میشود و وضعیت موجود حفظ میشود.
publishShoppingCarts
این API برای انتشار فهرستی از اشیاء ShoppingCart استفاده میشود. این قابلیت برای شرکای توسعهدهنده که سبدهای خرید جداگانهای را برای هر فروشنده منتشر میکنند، قابل استفاده است. هنگام استفاده از این API، نام فروشنده را در عنوان ذکر کنید.
کاتلین
client.publishShoppingCarts(
PublishShoppingCartClustersRequest.Builder()
.addShoppingCart(
ShoppingCart.Builder()
...
.build())
.build())
جاوا
client.publishShoppingCarts(
new PublishShoppingCartClustersRequest.Builder()
.addShoppingCart(
new ShoppingCart.Builder()
...
.build())
.build())
وقتی سرویس درخواست را دریافت میکند، اقدامات زیر در یک تراکنش انجام میشود:
- دادههای
ShoppingCartموجود از شریک توسعهدهنده حذف میشود. - دادههای درخواست تجزیه و تحلیل شده و در خوشه سبد خرید بهروزرسانیشده ذخیره میشوند.
در صورت بروز خطا، کل درخواست رد میشود و وضعیت موجود حفظ میشود.
publishShoppingLists
این API برای انتشار لیستی از اشیاء ShoppingList استفاده میشود.
کاتلین
client.publishShoppingLists(
PublishShoppingListsRequest.Builder()
.addShoppingList(
ShoppingList.Builder()
...
.build())
.build())
جاوا
client.publishShoppingLists(
new PublishShoppingListsRequest.Builder()
.addShoppingList(
new ShoppingListEntity.Builder()
...
.build())
.build());
وقتی سرویس درخواست را دریافت میکند، اقدامات زیر در یک تراکنش انجام میشود:
- دادههای
ShoppingListموجود از شریک توسعهدهنده حذف میشوند. - دادههای درخواست تجزیه و تحلیل شده و در خوشه فهرست خرید بهروزرسانیشده ذخیره میشوند.
در صورت بروز خطا، کل درخواست رد میشود و وضعیت موجود حفظ میشود.
publishShoppingReorderCluster
این API برای انتشار یک شیء ShoppingReorderCluster استفاده میشود.
کاتلین
client.publishShoppingReorderCluster(
PublishShoppingReorderClusterRequest.Builder()
.setReorderCluster(
ShoppingReorderCluster.Builder()
...
.build())
.build())
جاوا
client.publishShoppingReorderCluster(
new PublishShoppingReorderClusterRequest.Builder()
.setReorderCluster(
new ShoppingReorderCluster.Builder()
...
.build())
.build());
وقتی سرویس درخواست را دریافت میکند، اقدامات زیر در یک تراکنش انجام میشود:
- دادههای
ShoppingReorderClusterموجود از شریک توسعهدهنده حذف میشوند. - دادههای حاصل از درخواست، تجزیه و تحلیل شده و در خوشهی بهروزرسانیشدهی Reorder ذخیره میشوند.
در صورت بروز خطا، کل درخواست رد میشود و وضعیت موجود حفظ میشود.
publishShoppingOrderTrackingCluster
این API برای انتشار یک شیء ShoppingOrderTrackingCluster استفاده میشود.
کاتلین
client.publishShoppingOrderTrackingCluster(
PublishShoppingOrderTrackingClusterRequest.Builder()
.setShoppingOrderTrackingCluster(
ShoppingOrderTrackingCluster.Builder()
...
.build())
.build())
جاوا
client.publishShoppingOrderTrackingCluster(
new PublishShoppingOrderTrackingClusterRequest.Builder()
.setShoppingOrderTrackingCluster(
new ShoppingOrderTrackingCluster.Builder()
...
.build())
.build());
وقتی سرویس درخواست را دریافت میکند، اقدامات زیر در یک تراکنش انجام میشود:
- دادههای
ShoppingOrderTrackingClusterموجود از شریک توسعهدهنده حذف شده است. - دادههای درخواست تجزیه و تحلیل شده و در خوشهی بهروزرسانیشدهی ردیابی سفارش خرید ذخیره میشوند.
در صورت بروز خطا، کل درخواست رد میشود و وضعیت موجود حفظ میشود.
publishUserAccountManagementRequest
این API برای انتشار کارت ورود به سیستم استفاده میشود. عمل ورود به سیستم، کاربران را به صفحه ورود به سیستم برنامه هدایت میکند تا برنامه بتواند محتوا را منتشر کند (یا محتوای شخصیسازیشدهتری ارائه دهد).
فرادادههای زیر بخشی از کارت ورود به سیستم هستند -
| ویژگی | مورد نیاز | توضیحات |
|---|---|---|
| اکشن اوری | مورد نیاز | پیوند عمیق به اقدام (یعنی به صفحه ورود به برنامه هدایت میشود) |
| تصویر | اختیاری - در صورت عدم ارائه، عنوان باید ارائه شود | تصویر نشان داده شده روی کارت تصاویر با نسبت تصویر ۱۶x۹ و وضوح تصویر ۱۲۶۴x۷۱۲ |
| عنوان | اختیاری - در صورت عدم ارائه، تصویر باید ارائه شود | عنوان روی کارت |
| متن اکشن | اختیاری | متن نمایش داده شده در فراخوان عمل (مثلاً ورود) |
| زیرنویس | اختیاری | زیرنویس اختیاری روی کارت |
کاتلین
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());
جاوا
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از شریک توسعهدهنده حذف شده است. - دادههای حاصل از درخواست، تجزیه و تحلیل شده و در کلاستر بهروز شدهی UserAccountManagementCluster ذخیره میشوند.
در صورت بروز خطا، کل درخواست رد میشود و وضعیت موجود حفظ میشود.
updatePublishStatus
اگر به هر دلیل داخلی تجاری، هیچ یک از کلاسترها منتشر نشدهاند، اکیداً توصیه میکنیم وضعیت انتشار را با استفاده از API مربوط به updatePublishStatus بهروزرسانی کنید. این مهم است زیرا:
- ارائه وضعیت در همه سناریوها، حتی زمانی که محتوا منتشر شده است (وضعیت == منتشر شده)، برای پر کردن داشبوردهایی که از این وضعیت صریح برای انتقال سلامت و سایر معیارهای ادغام شما استفاده میکنند، بسیار مهم است.
- اگر هیچ محتوایی منتشر نشده باشد اما وضعیت ادغام خراب نباشد (STATUS == NOT_PUBLISHED)، گوگل میتواند از نمایش هشدارها در داشبوردهای سلامت برنامه جلوگیری کند. این تأیید میکند که محتوا به دلیل وضعیت مورد انتظار از دیدگاه ارائهدهنده منتشر نشده است.
- این به توسعهدهندگان کمک میکند تا بینشی در مورد زمان انتشار دادهها در مقابل عدم انتشار آنها ارائه دهند.
- گوگل ممکن است از کدهای وضعیت برای ترغیب کاربر به انجام اقدامات خاص در برنامه استفاده کند تا بتواند محتوای برنامه را ببیند یا از آن عبور کند.
لیست کدهای وضعیت انتشار واجد شرایط عبارتند از:
// 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
اگر محتوا به دلیل عدم ورود کاربر منتشر نشود، گوگل انتشار کارت ورود به سیستم را توصیه میکند. اگر به هر دلیلی ارائه دهندگان خدمات قادر به انتشار کارت ورود به سیستم نیستند، توصیه میکنیم API مربوط به updatePublishStatus را با کد وضعیت NOT_PUBLISHED_REQUIRES_SIGN_IN فراخوانی کنید.
کاتلین
client.updatePublishStatus(
PublishStatusRequest.Builder()
.setStatusCode(AppEngagePublishStatusCode.NOT_PUBLISHED_REQUIRES_SIGN_IN)
.build())
جاوا
client.updatePublishStatus(
new PublishStatusRequest.Builder()
.setStatusCode(AppEngagePublishStatusCode.NOT_PUBLISHED_REQUIRES_SIGN_IN)
.build());
deleteRecommendationClusters
این API برای حذف محتوای خوشههای توصیه استفاده میشود.
کاتلین
client.deleteRecommendationClusters()
جاوا
client.deleteRecommendationClusters();
وقتی سرویس درخواست را دریافت میکند، دادههای موجود را از خوشههای توصیه حذف میکند. در صورت بروز خطا، کل درخواست رد میشود و وضعیت موجود حفظ میشود.
deleteFeaturedCluster
این API برای حذف محتوای Featured Cluster استفاده میشود.
کاتلین
client.deleteFeaturedCluster()
جاوا
client.deleteFeaturedCluster();
وقتی سرویس درخواست را دریافت میکند، دادههای موجود را از Featured Cluster حذف میکند. در صورت بروز خطا، کل درخواست رد شده و وضعیت موجود حفظ میشود.
deleteShoppingCartCluster
این API برای حذف محتوای سبد خرید (Shopping Cart Cluster) استفاده میشود.
کاتلین
client.deleteShoppingCartCluster()
جاوا
client.deleteShoppingCartCluster();
وقتی سرویس درخواست را دریافت میکند، دادههای موجود را از خوشه سبد خرید حذف میکند. در صورت بروز خطا، کل درخواست رد میشود و وضعیت موجود حفظ میشود.
deleteShoppingListCluster
این API برای حذف محتوای خوشه لیست خرید استفاده میشود.
کاتلین
client.deleteShoppingListCluster()
جاوا
client.deleteShoppingListCluster();
وقتی سرویس درخواست را دریافت میکند، دادههای موجود را از خوشه لیست خرید حذف میکند. در صورت بروز خطا، کل درخواست رد میشود و وضعیت موجود حفظ میشود.
deleteShoppingReorderCluster
این API برای حذف محتوای Shopping Reorder Cluster استفاده میشود.
کاتلین
client.deleteShoppingReorderCluster()
جاوا
client.deleteShoppingReorderCluster();
وقتی سرویس درخواست را دریافت میکند، دادههای موجود را از خوشهی سفارش مجدد خرید حذف میکند. در صورت بروز خطا، کل درخواست رد میشود و وضعیت موجود حفظ میشود.
deleteShoppingOrderTrackingCluster
این API برای حذف محتوای خوشه پیگیری سفارش خرید استفاده میشود.
کاتلین
client.deleteShoppingOrderTrackingCluster()
جاوا
client.deleteShoppingOrderTrackingCluster();
وقتی سرویس درخواست را دریافت میکند، دادههای موجود را از خوشه پیگیری سفارش خرید حذف میکند. در صورت بروز خطا، کل درخواست رد میشود و وضعیت موجود حفظ میشود.
deleteUserManagementCluster
این API برای حذف محتوای کلاستر UserAccountManagement استفاده میشود.
کاتلین
client.deleteUserManagementCluster()
جاوا
client.deleteUserManagementCluster();
وقتی سرویس درخواست را دریافت میکند، دادههای موجود را از کلاستر UserAccountManagement حذف میکند. در صورت بروز خطا، کل درخواست رد شده و وضعیت موجود حفظ میشود.
deleteClusters
این API برای حذف محتوای یک نوع خوشه داده شده استفاده میشود.
کاتلین
client.deleteClusters(
DeleteClustersRequest.Builder()
.addClusterType(ClusterType.TYPE_FEATURED)
.addClusterType(ClusterType.TYPE_RECOMMENDATION)
...
.build())
جاوا
client.deleteClusters(
new DeleteClustersRequest.Builder()
.addClusterType(ClusterType.TYPE_FEATURED)
.addClusterType(ClusterType.TYPE_RECOMMENDATION)
...
.build());
وقتی سرویس درخواست را دریافت میکند، دادههای موجود را از تمام خوشههایی که با انواع خوشههای مشخصشده مطابقت دارند، حذف میکند. کلاینتها میتوانند یک یا چند نوع خوشه را ارسال کنند. در صورت بروز خطا، کل درخواست رد میشود و وضعیت موجود حفظ میشود.
مدیریت خطا
اکیداً توصیه میشود که به نتیجهی وظیفه از APIهای انتشار گوش دهید تا بتوان اقدامات بعدی را برای بازیابی و ارسال مجدد یک وظیفهی موفق انجام داد.
کاتلین
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
}
}
}
}
جاوا
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 | اجرای وظیفه به دلیل مشکلات نخبندی (threading) با شکست مواجه شد. در این صورت، میتوان آن را دوباره امتحان کرد. |
4 | SERVICE_CALL_PERMISSION_DENIED | تماس گیرنده مجاز به برقراری تماس خدماتی نیست. |
5 | SERVICE_CALL_INVALID_ARGUMENT | درخواست شامل دادههای نامعتبر است (برای مثال، بیش از تعداد مجاز خوشهها). |
6 | SERVICE_CALL_INTERNAL | در سمت سرویس خطایی رخ داده است. |
7 | SERVICE_CALL_RESOURCE_EXHAUSTED | تماس با سرویس خیلی زیاد انجام میشود. |
مرحله ۳: مدیریت اهداف پخش
علاوه بر فراخوانیهای API مربوط به انتشار محتوا از طریق یک job، لازم است یک BroadcastReceiver نیز راهاندازی شود تا درخواست انتشار محتوا را دریافت کند.
هدف از اعلانهای هدف عمدتاً فعالسازی مجدد برنامه و همگامسازی اجباری دادهها است. اعلانهای هدف برای ارسال مکرر طراحی نشدهاند. این اعلانها فقط زمانی فعال میشوند که سرویس Engage تشخیص دهد محتوا ممکن است قدیمی باشد (مثلاً یک هفته قدیمی). به این ترتیب، حتی اگر برنامه برای مدت طولانی اجرا نشده باشد، اطمینان بیشتری وجود دارد که کاربر میتواند تجربه محتوای جدیدی داشته باشد.
BroadcastReceiver باید به دو روش زیر تنظیم شود:
با استفاده از
Context.registerReceiver()یک نمونه از کلاسBroadcastReceiverرا به صورت پویا ثبت کنید. این کار امکان ارتباط از برنامههایی را که هنوز در حافظه فعال هستند، فراهم میکند.
کاتلین
class AppEngageBroadcastReceiver : BroadcastReceiver(){
// Trigger recommendation cluster publish when PUBLISH_RECOMMENDATION
// broadcast is received
// Trigger featured cluster publish when PUBLISH_FEATURED broadcast is
// received
// Trigger shopping cart cluster publish when PUBLISH_SHOPPING_CART broadcast
// is received
// Trigger shopping list cluster publish when PUBLISH_SHOPPING_LIST broadcast
// is received
// Trigger reorder cluster publish when PUBLISH_REORDER_CLUSTER broadcast is
// received
// Trigger shopping order tracking cluster publish when
// PUBLISH_SHOPPING_ORDER_TRACKING_CLUSTER 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 Shopping Cart Cluster Publish Intent
context.registerReceiver(AppEngageBroadcastReceiver(),
IntentFilter(Intents.ACTION_PUBLISH_SHOPPING_CART),
com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
/*scheduler=*/null)
// Register Shopping List Cluster Publish Intent
context.registerReceiver(AppEngageBroadcastReceiver(),
IntentFilter(Intents.ACTION_PUBLISH_SHOPPING_LIST),
com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
/*scheduler=*/null)
// Register Reorder Cluster Publish Intent
context.registerReceiver(AppEngageBroadcastReceiver(),
IntentFilter(Intents.ACTION_PUBLISH_REORDER_CLUSTER),
com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
/*scheduler=*/null)
// Register Shopping Order Tracking Cluster Publish Intent
context.registerReceiver(AppEngageBroadcastReceiver(),
IntentFilter(Intents.ACTION_PUBLISH_SHOPPING_ORDER_TRACKING_CLUSTER),
com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
/*scheduler=*/null)
}
جاوا
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 shopping cart cluster publish when PUBLISH_SHOPPING_CART broadcast is
// received
// Trigger shopping list cluster publish when PUBLISH_SHOPPING_LIST broadcast is
// received
// Trigger reorder cluster publish when PUBLISH_REORDER_CLUSTER broadcast is
// received
// Trigger reorder cluster publish when PUBLISH_SHOPPING_ORDER_TRACKING_CLUSTER
// 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 Shopping Cart Cluster Publish Intent
context.registerReceiver(new AppEngageBroadcastReceiver(),
new IntentFilter(com.google.android.engage.shopping.service.Intents.ACTION_PUBLISH_SHOPPING_CART),
com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
/*scheduler=*/null);
// Register Shopping List Cluster Publish Intent
context.registerReceiver(new AppEngageBroadcastReceiver(),
new IntentFilter(com.google.android.engage.shopping.service.Intents.ACTION_PUBLISH_SHOPPING_LIST),
com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
/*scheduler=*/null);
// Register Reorder Cluster Publish Intent
context.registerReceiver(new AppEngageBroadcastReceiver(),
new IntentFilter(com.google.android.engage.shopping.service.Intents.ACTION_PUBLISH_REORDER_CLUSTER),
com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
/*scheduler=*/null);
// Register Shopping Order Tracking Cluster Publish Intent
context.registerReceiver(new AppEngageBroadcastReceiver(),
new IntentFilter(com.google.android.engage.shopping.service.Intents.ACTION_PUBLISH_SHOPPING_ORDER_TRACKING_CLUSTER),
com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
/*scheduler=*/null);
}
یک پیادهسازی را به صورت ایستا با تگ
<receiver>در فایلAndroidManifest.xmlخود تعریف کنید. این به برنامه اجازه میدهد تا در زمانی که در حال اجرا نیست، اهداف پخش (broadcast intents) را دریافت کند و همچنین به برنامه اجازه میدهد تا محتوا را منتشر کند.
<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.shopping.PUBLISH_SHOPPING_CART" />
</intent-filter>
<intent-filter>
<action android:name="com.google.android.engage.action.shopping.PUBLISH_SHOPPING_LIST" />
</intent-filter>
<intent-filter>
<action android:name="com.google.android.engage.action.shopping.PUBLISH_REORDER_CLUSTER" />
</intent-filter>
<intent-filter>
<action android:name="com.google.android.engage.action.shopping.PUBLISH_SHOPPING_ORDER_TRACKING_CLUSTER" />
</intent-filter>
</receiver>
</application>
اینتنتهای زیر توسط سرویس ارسال میشوند:
-
com.google.android.engage.action.PUBLISH_RECOMMENDATIONتوصیه میشود هنگام دریافت این intent، یک فراخوانیpublishRecommendationClustersآغاز شود. -
com.google.android.engage.action.PUBLISH_FEATUREDتوصیه میشود هنگام دریافت این intent، یک فراخوانیpublishFeaturedClusterآغاز شود. -
com.google.android.engage.action.shopping.PUBLISH_SHOPPING_CARTتوصیه میشود هنگام دریافت این intent، یک فراخوانیpublishShoppingCartsآغاز شود. -
com.google.android.engage.action.shopping.PUBLISH_SHOPPING_LISTتوصیه میشود هنگام دریافت این intent، فراخوانیpublishShoppingListsآغاز شود. -
com.google.android.engage.action.shopping.PUBLISH_REORDER_CLUSTERتوصیه میشود هنگام دریافت این intent، یک فراخوانیpublishReorderClusterآغاز شود. -
com.google.android.engage.action.shopping.PUBLISH_SHOPPING_ORDER_TRACKING_CLUSTERتوصیه میشود هنگام دریافت این intent، فراخوانیpublishShoppingOrderTrackingClusterآغاز شود.
گردش کار یکپارچهسازی
برای راهنمای گام به گام تأیید ادغام پس از تکمیل، به گردش کار ادغام توسعهدهنده مراجعه کنید.
سوالات متداول
برای سوالات متداول به بخش سوالات متداول Engage SDK مراجعه کنید.
تماس
در صورت وجود هرگونه سوال در طول فرآیند ادغام، engage-developers@google.com تماس بگیرید. تیم ما در اسرع وقت پاسخ میدهد.
مراحل بعدی
پس از تکمیل این ادغام، مراحل بعدی به شرح زیر است:
- یک ایمیل به
engage-developers@google.comارسال کنید و APK یکپارچه خود را که آماده آزمایش توسط گوگل است، پیوست کنید. - گوگل یک بررسی داخلی انجام میدهد تا مطمئن شود که ادغام طبق انتظار کار میکند. در صورت نیاز به تغییرات، گوگل با شما تماس میگیرد و جزئیات لازم را ارائه میدهد.
- وقتی آزمایش کامل شد و نیازی به تغییر نبود، گوگل با شما تماس میگیرد تا به شما اطلاع دهد که میتوانید APK بهروزرسانیشده و یکپارچهشده را در فروشگاه Play منتشر کنید.
- پس از اینکه گوگل تأیید کرد که APK بهروزرسانیشده شما در فروشگاه Play منتشر شده است، خوشههای توصیه ، ویژه ، سبد خرید ، لیست خرید ، خوشه سفارش مجدد و خوشه پیگیری سفارش خرید شما ممکن است منتشر شده و برای کاربران قابل مشاهده باشند.