1. مقدمه
بیایید فرض کنیم که پس از انتشار برنامه خود در فروشگاه Play، باید مقادیر برخی از پارامترها را در برنامه خود تنظیم کنید. به طور معمول، شما باید نسخه جدیدی از برنامه خود را مجدداً منتشر کنید و کاربران نیز باید برنامه را در تلفن خود به روز کنند.
به طور کلی، اگر بخواهید تغییرات طولانی مدت در برنامه خود ایجاد کنید، به روز رسانی برنامه کار خواهد کرد. با این حال، اگر بخواهید مقدار برخی از پارامترها را در برنامه خود مرتباً تنظیم کنید، چه؟ یا، اگر بخواهید چند آزمایش را برای یافتن پیکربندی برنامه بهینه اجرا کنید، چه؟
در این موارد، به روز رسانی برنامه به خوبی کار نخواهد کرد. زیرا تا زمانی که آپدیت به طور کامل برای کاربران منتشر شود مدتی زمان نیاز دارد. همچنین، اجرای آزمایش ها در چندین نسخه برنامه بسیار چالش برانگیز است.
همچنین، چگونه میتوانید تعیین کنید که آیا سفر کاربر برنامه طبق برنامه کار میکند یا خیر؟ ممکن است به نظرات کاربران در کنسول Play تکیه کنید. با این حال، ممکن است به اندازه کافی دقیق نباشد تا بتوان تصمیم روشنی گرفت.
چیزی که یاد خواهید گرفت
- چگونه یک قیف در Google Analytics برای Firebase ایجاد کنیم
- نحوه استفاده از Firebase Remote Config
- نحوه اجرای تست Firebase A/B
آنچه شما نیاز دارید
- Unity 2018.4.4f1 یا بالاتر
- Xcode 10 یا بالاتر (برای ساختن هدف برای iOS)
- یک اکانت گوگل
- یک دستگاه آزمایشی با Android نسخه 5.0 و بالاتر با کابل USB برای اتصال دستگاه شما، یا شبیهساز Android دارای AVD (دستگاه مجازی Android) با تصویر سیستمی که از Play Store/Google API پشتیبانی میکند.
- یک دستگاه iOS یا یک شبیه ساز دارای iOS 8.0 یا بالاتر
سطح تجربه خود را با AdMob چگونه ارزیابی می کنید؟
سطح تجربه خود را با Firebase چگونه ارزیابی می کنید؟
2. راه اندازی محیط توسعه
کد را دانلود کنید
برای دانلود تمام کدهای این کد لبه روی دکمه زیر کلیک کنید:
فایل فشرده دانلود شده را باز کنید. با این کار یک پوشه ریشه به نام admob-firebase-codelabs-unity-master
باز می شود.
... یا مخزن GitHub را از خط فرمان کلون کنید.
$ git clone https://github.com/googlecodelabs/admob-firebase-codelabs-unity
مخزن شامل چهار پوشه به شرح زیر است:
- 101-base - کد شروعی که در این Codelab خواهید ساخت.
- 101-complete_and_102-base — کد تکمیل شده برای این Codelab و شروع کننده برای Codelab 102.
- 102-complete - کد تکمیل شده برای کد 102.
فایل های مورد نیاز را آماده کنید
مسابقه طراحی عالی از چندین کد منبع باز استفاده می کند که برای کامپایل و اجرای پروژه مورد نیاز است.
ترمینال را باز کنید و به دایرکتوری ریشه مخزن بروید. سپس، ./gradlew :prepareThirdPartyFiles
( gradlew.bat :prepareThirdPartyFiles
در ویندوز) را از ترمینال اجرا کنید تا فایل های مورد نیاز را در پروژه کپی کنید.
برنامه شروع را وارد کنید
Unity را راه اندازی کنید، "Open" را در صفحه خوش آمد انتخاب کنید. سپس دایرکتوری 101-complete_and_102-base را از کدی که دانلود کرده اید انتخاب کنید.
اکنون باید پروژه را در Unity باز کنید.
افزونه Google Mobile Ads Unity را اضافه کنید
برای ارائه تبلیغات AdMob در برنامه Unity، باید افزونه Google Mobile Ads Unity را به پروژه اضافه کنید.
- بسته Google Mobile Ads Unity Plugin 3.18.1 را دانلود کنید. (توجه داشته باشید که این Codelab ممکن است با نسخه دیگر افزونه سازگار نباشد)
- در پروژه Awesome Drawing Quiz Unity. در پروژه، به Assets > Import Package > Custom Package بروید.
- GoogleMobileAds.unitypackage را به پروژه ای که دانلود کرده اید وارد کنید.
باید شناسه برنامه AdMob را نیز تنظیم کنید. در ویرایشگر Unity، Assets > Google Mobile Ads > Settings را از منو انتخاب کنید.
AdMob را با کلیک کردن بر روی گزینه Enabled در قسمت Google AdMob فعال کنید. سپس شناسه برنامه AdMob را به صورت زیر وارد کنید:
- اندروید:
ca-app-pub-3940256099942544~3048611032
- iOS:
ca-app-pub-3940256099942544~2753522596
فایل های پیکربندی Firebase را به پروژه Unity اضافه کنید
- از صفحه نمای کلی پروژه مسابقه طراحی عالی ، روی نماد تنظیمات کلیک کنید.
- در زبانه عمومی ، هر برنامه Android و iOS را انتخاب کنید تا فایل google-service.json (برای اندروید) و GoogleService-Info.plist (برای iOS) را دانلود کنید.
- هر دو فایل پیکربندی را به داخل منتقل کنید پوشه Assets در پروژه Unity.
Firebase Analytics SDK را اضافه کنید
- Firebase Unity SDK 5.5.0 را دانلود کنید و آن را در جایی مناسب از حالت فشرده خارج کنید. (اگر قبلاً SDK را دانلود کرده اید از این مرحله رد شوید)
- پروژه Awesome Drawing Quiz Unity را باز کنید، به Assets > Import Package > Custom Package بروید.
- از SDK خارجشده، Firebase Analytics SDK (
dotnet4/FirebaseAnalytics.unitypackage
) را وارد کنید. - در پنجره بسته Import Unity، روی Import کلیک کنید.
3. پروژه Firebase را از کنسول باز کنید
قبل از رفتن به مرحله بعدی، پروژه را از کنسول Firebase که در مرحله «Setup Firebase Project» در AdMob+Firebase 101 Codelab ایجاد کردهاید، باز کنید.
4. یک قیف از رویدادهای برنامه ایجاد کنید
ممکن است چند رویداد برنامه وجود داشته باشد که برای ردیابی فعالیت کاربر در داخل برنامه اضافه کرده اید. با خواندن گزارش هر یک از رویدادهای برنامه، می توانید جزئیات مرتبط با رویداد مانند تعداد کل، تعداد میانگین به ازای هر کاربر، جمعیت شناسی و غیره را دریافت کنید.
با این حال، اگر بخواهید به جای تمرکز روی یک رویداد خاص، میزان تکمیل یک سری از رویدادها را ببینید، چه؟ در Google Analytics برای Firebase، میتوانید از Funnel برای تجسم و بهینهسازی نرخ تکمیل مجموعهای از رویدادهای برنامه استفاده کنید.
یک قیف ایجاد کنید
برای ایجاد یک قیف:
- به کنسول Firebase بروید و پروژه Awesome Drawing Quiz را که قبلا ایجاد کردید انتخاب کنید.
- روی Funnels کلیک کنید.
- روی NEW FUNNEL کلیک کنید.
- یک نام و توضیحات برای قیف وارد کنید.
- دو رویداد اولی را که می خواهید به عنوان مراحل در قیف استفاده کنید انتخاب کنید.
- برای هر مرحله اضافی، روی افزودن یک رویداد دیگر کلیک کنید و یک رویداد را انتخاب کنید.
- روی CREATE کلیک کنید.
با انجام مراحل بالا، قیف های زیر را ایجاد کنید:
شماره 1 نام قیف: میزان موفقیت سطح رویدادها: level_start
، level_success
شماره 2 نام قیف: نرخ تکمیل آگهی با پاداش رویدادها: ad_reward_prompt
, ad_reward_impression
, ad_reward
شماره 3 نام قیف: نرخ اتمام بازی رویدادها: game_start
، game_complete
مشاهده تجزیه و تحلیل قیف
هنگامی که تعدادی قیف ایجاد کردید، می توانید در منوی Funnels در کنسول Firebase به آن دسترسی داشته باشید. با کلیک بر روی نام قیف در لیست، می توانید تجزیه و تحلیل دقیق هر قیف را مشاهده کنید.
به عنوان مثال، روی نرخ موفقیت سطح کلیک کنید. جزئیات قیف را به صورت زیر نشان می دهد:
از اسکرین شات بالا، میتوانید درصد کاربرانی را که پس از شروع یک سطح (رویداد level_success
) یک سطح را پاک کردهاند (رویداد level_start
راهاندازی کردهاند) مشاهده کنید. در اینجا، می توانید ببینید که 46.2٪ از کاربران سطح را پاک کرده اند.
هنگامی که روی تعداد رویداد کلیک کنید، معیارهای بر اساس تعداد رویدادها را به صورت زیر نشان می دهد:
بر اساس معیارهای موجود در اسکرین شات بالا، 116 تلاش (رویداد level_start را راه اندازی کرد) و 57 پاکسازی (رویداد level_success را شروع کرد) در طول دوره انجام شد.
از آنجایی که میزان تکمیل بر اساس رویدادها (49.1%) کمی بیشتر از نرخ بر اساس کاربر (46.2%) است، می توان گفت که تعداد کمی از افراد هستند که عملکرد بهتری نسبت به بقیه دارند.
5. Remote Config را در برنامه ادغام کنید
از آنجایی که می توانید بر اساس رویدادهای برنامه و قیف اطلاعاتی در مورد برنامه خود دریافت کنید، ممکن است بخواهید برنامه خود را بهینه کنید. معمولاً شامل تنظیم دقیق مقدار پارامتر در برنامه است. برای تغییر مقدار آن پارامترها، باید برنامه را بهروزرسانی کنید تا بتوان تغییرات را برای کاربران اعمال کرد.
با استفاده از Remote Config در Firebase، میتوانید این مقادیر را بدون بهروزرسانی برنامه تنظیم کنید، به این معنی که میتوانید رفتار برنامه را بدون ایجاد مزاحمت برای کاربران خود با مجبور کردن آنها به دانلود بهروزرسانی تغییر دهید.
در این Codelab، یاد میگیرید که چگونه با استفاده از Remote Config، مقدار پاداش (تعداد حروفی که باید پس از تماشای یک تبلیغ ویدیویی با پاداش افشا شود) را بدون بهروزرسانی برنامه قابل تنظیم کنید.
Firebase Remote Config SDK را اضافه کنید
- Firebase Unity SDK 5.5.0 را دانلود کنید و آن را در جایی مناسب از حالت فشرده خارج کنید.
- پروژه Awesome Drawing Quiz Unity را باز کنید، به Assets > Import Package > Custom Package بروید.
- از SDK خارج شده، Remote Config SDK (
dotnet4/FirebaseRemoteConfig.unitypackage
) را وارد کنید. - در پنجره بسته Import Unity، روی Import کلیک کنید.
وارد کردن Firebase.RemoteConfig
Main.cs را تغییر دهید تا به شما امکان دهد بدون نیاز به استفاده از نام کاملاً واجد شرایط، از نوع Firebase.RemoteConfig استفاده کنید.
صحنهها/Main.cs
...
using AwesomeDrawingQuiz.Game;
// TODO: Import Firebase.RemoteConfig (102)
using Firebase.RemoteConfig;
namespace AwesomeDrawingQuiz.Scene {
...
}
مقدارهای Remote Config را مقداردهی و واکشی کنید
متد InitAndFetchRemoteConfig()
را در Main.cs
تغییر دهید تا نمونه Remote Config را به صورت زیر مقداردهی اولیه کند. توجه داشته باشید که GameSettings.KEY_REWARD_AMOUNT
نام پارامتر را در Remote Config نگه می دارد. (این فیلد را به زودی در این Codelab اعلام خواهید کرد)
صحنهها/Main.cs
private Task InitAndFetchRemoteConfig() {
// TODO: Initialize and Fetch values from the Remote Config (102)
Dictionary<string, object> defaults = new Dictionary<string, object>();
defaults.Add(GameSettings.KEY_REWARD_AMOUNT, 1);
FirebaseRemoteConfig.SetDefaults(defaults);
if (Debug.isDebugBuild) {
ConfigSettings config = new ConfigSettings();
config.IsDeveloperMode = true;
FirebaseRemoteConfig.Settings = config;
return FirebaseRemoteConfig.FetchAsync(System.TimeSpan.Zero);
} else {
return FirebaseRemoteConfig.FetchAsync();
}
}
خواهید دید که نمونه FirebaseRemoteConfig
پیکربندی شده است تا آخرین مقادیر را از سرور در حالت اشکال زدایی واکشی کند تا به فرآیند توسعه کمک کند. ( IsDeveloperMode = true
و FetchAsync(System.TimeSpan.Zero)
)
مقادیر Remote Config واکشی شده را فعال کنید
هنگامی که مقادیر Remote Config را با موفقیت واکشی کردید، باید آن مقادیر را فعال کنید تا در برنامه در دسترس قرار گیرند. متد ActivateRemoteConfigValues()
را به صورت زیر تغییر دهید.
صحنهها/Main.cs
private void ActivateRemoteConfigValues() {
// TODO: Activate fetched Remote Config values (102)
FirebaseRemoteConfig.ActivateFetched();
}
متد Start() را تغییر دهید
برای اینکه برنامه مقدار Remote Config را در زمان راه اندازی برنامه واکشی و فعال کند، متد Start()
در فایل Main.cs
به صورت زیر تغییر دهید.
صحنهها/Main.cs
void Start () {
...
Firebase.FirebaseApp.CheckAndFixDependenciesAsync().ContinueWith(task => {
...
}).ContinueWith(task => {
// TODO: Call InitAndFetchRemoteConfig() (102)
InitAndFetchRemoteConfig();
}).ContinueWith(task => {
// TODO: Call ActivateRemoteConfigValues() (102)
ActivateRemoteConfigValues();
// Enable 'Start a game' button
UnityMainThreadDispatcher.Instance()
.Enqueue(() => buttonStartGame.interactable = true);
});
#else
QuizAnalytics.SetScreenName(QuizAnalytics.SCREEN_MAIN);
// TODO: Call InitAndFetchRemoteConfig() (102)
InitAndFetchRemoteConfig().ContinueWith(task => {
// TODO: Call ActivateRemoteConfigValues() (102)
ActivateRemoteConfigValues();
});
#endif
}
مقدار پاداش را از Remote Config دریافت کنید
کلاس GameSettings
را تغییر دهید تا مبلغ پاداش را از Remote Config دریافت کنید.
Game/GameSettings.cs
// TODO: Import Firebase.RemoteConfig (102)
using Firebase.RemoteConfig;
namespace AwesomeDrawingQuiz.Game {
public class GameSettings {
...
// TODO: Apply reward amount from the Remote Config (102)
public const string KEY_REWARD_AMOUNT = "reward_amount";
public static GameSettings Instance {
get {
return instance;
}
}
...
public int RewardAmount {
get {
// TODO: Apply reward amount from the Remote Config (102)
return (int) FirebaseRemoteConfig.GetValue(KEY_REWARD_AMOUNT).LongValue;
}
private set { }
}
}
}
یک پارامتر Remote Config از کنسول ایجاد کنید
در مرحله بعد، یک پارامتر Remote Config جدید برای مقدار پاداش ایجاد می کنید تا بتوانید مقدار آن را در لحظه تنظیم کنید.
برای ایجاد یک پارامتر جدید، به کنسول Firebase بروید، سپس پروژه Awesome Drawing Quiz را که قبلا ایجاد کردهاید انتخاب کنید. روی دکمه Remote Config -> ADD YOUR FIRST PARAMETER کلیک کنید.
پارامتر را به عنوان reward_amount
نامگذاری کنید و مقدار پیش فرض آن را 1
قرار دهید. سپس روی دکمه Add Parameter کلیک کنید.
روی دکمه Publish Changes کلیک کنید تا تغییر برای کاربران زنده شود.
6. رفتار برنامه را با Remote Config تغییر دهید
اکنون میتوان مقدار پاداش موجود در مسابقه طراحی شگفتانگیز را در کنسول Firebase بدون نیاز به بهروزرسانی کد برنامه پیکربندی کرد.
در این بخش، شما قصد دارید مقدار پاداش را از 1 به 2 تغییر دهید تا این برنامه پس از تماشای یک تبلیغ پاداش، دو کاراکتر دیگر را به عنوان یک اشاره نشان دهد.
مقدار پیش فرض پارامتر reward_amount را به روز کنید
به کنسول Firebase بروید، سپس پروژه Awesome Drawing Quiz را که قبلا ایجاد کردید انتخاب کنید. روی Remote Config کلیک کنید و روی reward_amount
از لیست کلیک کنید. در مرحله بعد، مقدار پیش فرض را به 2 تغییر دهید و روی دکمه Update کلیک کنید.
روی دکمه انتشار تغییرات کلیک کنید تا تغییرات به صورت زنده در اختیار کاربران قرار گیرد.
تغییر رفتار برنامه را تأیید کنید
برای تأیید تغییر رفتار برنامه، پروژه را دوباره اجرا کنید. پس از اتمام تماشای یک تبلیغ پاداش، متوجه خواهید شد که برنامه اکنون دو حرف را به عنوان جایزه نشان می دهد، همانطور که ما در کنسول Remote Config پیکربندی کردیم.
قبل از تماشای یک آگهی با پاداش | دو حرف اضافی را به عنوان پاداش نشان داد |
7. آزمایش را برای بهینه سازی مقدار پاداش ایجاد کنید
اکنون میتوانید مقدار پاداش را بدون نیاز به انتشار بهروزرسانی برنامه تغییر دهید. با این حال، چگونه می توانید تعیین کنید که مقداری که تغییر داده اید برای برنامه خوب است؟
با Firebase A/B Testing ، میتوانید آزمایشها را برای بهینهسازی تجربه کاربری کلی برنامه بدون نیاز به بهروزرسانی یک برنامه یا ساخت ابزار جداگانه برای اجرا و پیگیری عملکرد هر آزمایش اجرا کنید.
آزمایش را طراحی کنید
قبل از ایجاد یک آزمایش جدید، باید یک هدف یا هدف واضح از آزمایش تعیین کنید. قبل از ایجاد یک آزمایش جدید، حتماً چک لیست زیر را مرور کنید.
- چه: چه چیزی را می خواهید بهینه کنید؟ (به عنوان مثال، دشواری بازی، زمان بندی/قابلیت مشاهده آگهی و غیره)
- چرا: هدف تجاری شما از اجرای آزمایش چیست؟ (به عنوان مثال، برای به حداکثر رساندن درآمد تبلیغات، افزایش حفظ و غیره)
- چه کسی: چه کسی باید در آزمایش شرکت کند؟ (به عنوان مثال، همه کاربران، مخاطبان کاربر خاص، و غیره)
در این Codelab، میخواهید آزمایشی برای بهینهسازی مقدار پاداش ایجاد کنید تا تعامل روزانه کاربر در مسابقه طراحی عالی را به حداکثر برسانید.
آزمایش را ایجاد کنید
پروژه Awesome Drawing Quiz را از کنسول Firebase باز کنید. منوی A/B Testing را انتخاب کنید، سپس روی دکمه ایجاد آزمایش کلیک کنید.
Remote Config را برای ایجاد آزمایش Remote Config انتخاب کنید.
همانطور که در تصویر زیر نشان داده شده است، آزمایش را به عنوان "میزان پاداش" نامگذاری کنید.
گزینه های هدف گذاری را پیکربندی کنید. در این Codelab، شما 100٪ از کاربران مسابقه طراحی عالی را هدف قرار خواهید داد.
از آنجایی که هدف اصلی آزمایش یافتن یک مقدار بهینه است که تعامل روزانه کاربر را به حداکثر برساند، تعامل روزانه کاربر را به عنوان معیار اصلی برای ردیابی انتخاب کنید.
در نهایت، گروه کنترل و نوع را تنظیم کنید تا بتوانید بفهمید کدام گروه عملکرد بهتری دارد. reward_amount
از گروه کنترل انتخاب کنید و مقدار آن را بدون تغییر بگذارید. برای گروه متغیر، آن را به عنوان "پاداش کمتر" نامگذاری کنید، سپس مقدار reward_amount
را به 1 تغییر دهید.
با این پیکربندی، افراد گروه "پاداش کمتر" یک حرف به عنوان پاداش دریافت می کنند، در حالی که افراد گروه کنترل دو حرف به عنوان پاداش دریافت می کنند. در نتیجه، خواهید دید که میزان پاداش چگونه بر کاربران تأثیر می گذارد.
پس از کلیک بر روی دکمه Review ، نمای کلی آزمایش را به صورت زیر مشاهده خواهید کرد.
آزمایش را اجرا کنید
برای اجرای آزمایش روی دکمه شروع آزمایش کلیک کنید. توجه داشته باشید که پس از شروع نمیتوانید پیکربندی آزمایش را تغییر دهید.
8. آزمایش را مدیریت کنید
مشاهده پیشرفت آزمایش
میتوانید پیشرفت آزمایش را از منوی A/B Testing در کنسول Firebase بررسی کنید، که شبیه تصویر زیر است. توجه داشته باشید که تعداد کاربرانی که در 30 دقیقه آخر در آزمایش شرکت کرده اند را نیز می توانید در کارت مشاهده کنید.
پس از کلیک بر روی آزمایش از لیست، می توانید جزئیات آزمایش را مشاهده کنید. تا زمانی که آزمایش نتواند یک رهبر را اعلام کند (یعنی بهترین نوع عملکرد)، پیام "برای اعلام رهبر خیلی زود است" را خواهید دید.
زمانی که آزمایش برای مدتی اجرا شد، شروع به نمایش دادههای جمعآوریشده در طول آزمایش تا کنون در بخش نمای کلی بهبود میکند. می توانید عملکرد هر یک از انواع را مقایسه کنید تا ببینید کدام یک عملکرد بهتری دارد. اسکرین شات زیر نمونه ای از بخش نمای کلی Improvement را نشان می دهد.
از جدول زیر بخش نمای کلی بهبود ، میتوانید جزئیات معیارهای هدف آزمایش و همچنین معیارهای دیگری را که در آزمایش دنبال میشوند بررسی کنید. تصویر زیر نمونه ای از بخش جزئیات معیارها را نشان می دهد.
رهبر را برای همه کاربران معرفی کنید
بعد از اینکه آزمایش طولانی شد و شما یک رهبر یا نوع برنده دارید، می توانید آزمایش را برای 100٪ از کاربران اجرا کنید. هنگامی که تست A/B یک رهبر واضح پیدا کرد، شما را تشویق میکند تا نسخه اصلی را برای همه کاربران عرضه کنید.
با این حال، حتی اگر آزمایش یک رهبر واضح را اعلام نکرده باشد، همچنان میتوانید انتخاب کنید که یک نسخه را برای همه کاربران عرضه کنید.
در صفحه جزئیات آزمایش، روی منوی زمینه کلیک کنید ( )، و سپس روی Roll out variant کلیک کنید.
یک نوع را برای ارائه برای همه کاربران انتخاب کنید، سپس روی دکمه Review in Remote Config کلیک کنید تا تغییرات را قبل از ایجاد تغییر در Remote Config بررسی کنید.
پس از اینکه تأیید کردید که پیشنویس مشکلی ندارد، روی دکمه انتشار تغییرات کلیک کنید تا تغییر برای همه کاربران زنده شود.
9. همه چیز تمام شد!
شما AdMob+Firebase 102 Unity Codelab را تکمیل کرده اید. شما می توانید کد تکمیل شده برای این Codelab را در اینجا پیدا کنید پوشه 102 کامل .