Bu doküman, Unity projenizi Unity için Google Play Games eklentisini kullanacak şekilde ayarlama konusunda size yol gösterir. Eklentiyi nasıl yükleyeceğinizi ve Unity projenizi nasıl yapılandıracağınızı öğrenirsiniz. Dokümanda, oturum açma hizmetinin nasıl doğrulanacağı da ele alınmaktadır.
Başlamadan önce
Yazılım koşullarını inceleyin. Play Console'u kurun ve Unity Hub'ı yükleyin.
Oyununuz için Play Console'u ayarlayın.
Unity Hub'ı yükleyin ve oyununuzu Unity'de derleyin.
Eklenti Yükleme
Unity için Google Play Games eklentisini indirip yüklemek üzere Unity Hub'da aşağıdaki adımları uygulayın:
GitHub kod deposunu indirin.
current-build
dizinindeunitypackage
dosyasını bulun. Bu dosya, eklentiyi temsil eder. Örneğin, aşağıdakine benzer olmalıdır:current-build/GooglePlayGamesPluginForUnity-X.YY.ZZ.unitypackage
Unity projesi oluşturma
Oynatıcı ayarlarında Unity projesi oluşturmak için aşağıdaki adımları uygulayın:
Oyun projenizi açın.
unitypackage
dosyasını projenizin öğelerine aktarmak için Unity Hub'da Öğeler > Paket İçe Aktar > Özel Paket'i tıklayın.Mevcut derleme platformunuzun Android olarak ayarlandığından emin olun.
Ana menüde Dosya > Derleme Ayarları'nı tıklayın.
Android'i seçin ve Platform Değiştir'i tıklayın.
Pencere > Google Play Games bölümünde yeni bir menü öğesi olmalıdır. Öğe yoksa Öğeler > Yenile'yi tıklayarak öğeleri yenileyin ve ardından derleme platformunu tekrar ayarlamayı deneyin.
Unity Hub'da Dosya > Derleme Ayarları > Oynatıcı Ayarları > Diğer Ayarlar'ı tıklayın.
Hedef API düzeyi kutusunda bir sürüm seçin.
Arka uç komut dosyası kutusuna
IL2CPP
yazın.Hedef mimariler kutusunda bir değer seçin.
package_name paket adını not edin.Bu bilgileri daha sonra kullanabilirsiniz.
Yeni bir anahtar deposu oluşturma
Kimlik bilgilerinizi doğrulamak için bir anahtara ihtiyacınız vardır. Şu adımları uygulayın:
- Unity Hub'da Dosya > Derleme ayarları > Oynatıcı ayarları'nı tıklayın.
- Yayınlama ayarları bölümünde Anahtar mağazası yöneticisi'ni tıklayın.
- Anahtar mağazası yöneticisi penceresinde Anahtar mağazası > Yeni oluştur > Herhangi bir yer'i tıklayın.
- Bir klasör seçin ve anahtar arşivi için bir ad girin.
- Şifre kutusuna bir şifre girip onaylayın.
- Anahtar ekle'yi tıklayın.
Klasör adını not edin. Google Cloud'da kimlik bilgisi oluşturmak için bu adı kullanabilirsiniz.
Play Console'dan Android kaynaklarını kopyalama
Play Console'da oluşturduğunuz her başarı, skor tablosu ve etkinlik, Unity projenizi ayarlarken kullanacağınız bir Android kaynağı içerir.
Oyununuzun Android kaynaklarını almak için aşağıdaki adımları uygulayın:
Google Play Console'da oyunu açın.
Play Games Hizmetleri - Yapılandırma sayfasında (Büyüme > Play Games Hizmetleri > Kurulum ve yönetim > Yapılandırma) Kaynak al'ı tıklayın.
Kaynaklar penceresinde Android(XML) sekmesini tıklayın.
Android kaynakları (
AndroidManifest.xml
) içeriğini seçip kopyalayın.
Android kaynaklarını Unity projenize ekleme
Unity projenize aşağıdaki Android kaynaklarını ekleyin:
Unity Hub'da Pencere > Google Play Games > Kurulum > Android Kurulumu'nu tıklayın.
- Sabit değerlerin kaydedileceği dizin alanına sabit değerler dosyasının klasör adını girin.
Sabitler sınıf adı alanına, oluşturulacak C# sınıfının adını (alanı adı dahil) girin.
Örneğin, C# sınıfı
id.cs
ise ve Öğeler > projem > komut dosyaları > kimlik.cs altındaysa. Sabitler sınıf adımyproject.scripts.id
olabilir.Kaynak tanımı alanına, Google Play Console'dan kopyaladığınız Android kaynak verilerini (
AndroidManifest.xml
dosyası) yapıştırın.İsteğe bağlı: İstemci Kimliği alanına, bağlı web uygulamasının istemci kimliğini girin.
Oyununuzun istemci kimliğini Google Cloud'dan almak için İstemci kimlikleri oluşturma başlıklı makaleyi inceleyin.
Bu yalnızca oyununuz için web tabanlı bir arka uç kullanıyorsanız ve arka uç sunucusunun erişim jetonuyla takas etmesi için bir sunucu kimlik doğrulama koduna ihtiyacınız varsa veya oyuncunun oyun dışı API çağrıları yapması için bir kimlik jetonuna ihtiyacınız varsa gereklidir.
Kurulum'u tıklayın. Bu işlem, oyununuzu istemci kimliğiyle yapılandırır ve her Android kaynağınız için sabitler içeren bir C# sınıfı oluşturur.
Unity Hub'da Pencere > Google Play Games > Kurulum > Yakındaki Bağlantılar Kurulumu'nu tıklayın.
Yakındaki bağlantı hizmeti kimliği alanına package_name değerini girin.
Unity projesini oluştururken kullandığınız package_name değerini kullanın.
Kurulum'u tıklayın.
Sosyal medya platformu seçme
Google Play Games Hizmetleri eklentisi, Unity'nin sosyal arayüzünü uygular. Bu sayede, diğer platformlarla entegrasyon sırasında bu arayüzü zaten kullanan oyunlarla uyumluluk sağlanır. Ancak bazı özellikler Play Games'e özgüdür ve Unity tarafından sağlanan standart sosyal arayüzün uzantıları olarak sunulur.
Standart API çağrılarına, ISocialPlatform arayüzüne referans veren Social.Active nesnesi üzerinden erişilebilir. Standart olmayan Google Play Oyun Hizmetleri uzantılarına, Social.Active nesnesini ek yöntemlerin kullanılabildiği PlayGamesPlatform sınıfına yayınlayarak erişilebilir.
Varsayılan sosyal medya platformunu geçersiz kılmaksızın eklentiyi kullanma
PlayGamesPlatform.Activate
çağrısı yaptığınızda Google Play Oyun Hizmetleri varsayılan sosyal platform uygulamanız olur. Bu, Social
ve Social.Active
'deki yöntemlere yönelik statik çağrıların Google Play Oyun Hizmetleri eklentisi tarafından gerçekleştirileceği anlamına gelir. Bu, eklentiyi kullanan çoğu oyunda geçerli bir davranıştır.
Ancak, varsayılan uygulamaya erişmeye devam etmek isterseniz (örneğin, farklı bir sosyal platforma başarı ve liderlik tabloları göndermek için) varsayılan uygulamayı geçersiz kılmadan Google Play Games Hizmetleri eklentisini kullanabilirsiniz. Bunu yapmak için:
PlayGamesPlatform.Activate
numarayı aramaXyz
,Social
sınıfında çağırmanız gereken bir yöntemin adıysaSocial.Xyz
'yi çağırmayın. Bunun yerinePlayGamesPlatform.Instance.Xyz
numaralı telefonu arayın.- Google Play Games Hizmetleri ile etkileşimde bulunurken
Social.Active
kullanmayın. Bunun yerinePlayGamesPlatform.Instance
kullanın.
Böylece puanları ve başarıları iki veya daha fazla sosyal platforma aynı anda gönderebilirsiniz:
// Submit achievement to original default social platform
Social.ReportProgress("MyAchievementIdHere", 100.0f, callback);
// Submit achievement to Google Play
PlayGamesPlatform.Instance.ReportProgress("MyGooglePlayAchievementIdHere", 100.0f, callback);
Oturum açma hizmetini doğrulama
Oyununuz açıldığında Oturum açma hizmeti kullanılarak Play Oyun Hizmetleri'ne otomatik olarak bağlanmaya çalışılır. Bağlantı başarılı olursa oyununuzda oturum açma istemi gösterilir ve Unity için Google Play Games Hizmetleri eklentisi kullanıma hazır olur.
Cihazında hiç Google Play Games Hizmetleri kullanmamış olan kullanıcılar, Play Games hesabı oluşturmak için otomatik olarak tek seferlik kurulum ekranına yönlendirilir.
Komut dosyanızın Start
yönteminde, otomatik oturum açma denemesinin sonucunu dinleyin, kimlik doğrulama durumunu alın ve kullanıcı oturum açmadıysa Play Games Hizmetleri özelliklerini devre dışı bırakın.
Unity eklentisi sürümü v11
'ten eskiyse oturum açma özelliğini kullanamazsınız.
using GooglePlayGames;
public void Start() {
PlayGamesPlatform.Instance.Authenticate(ProcessAuthentication);
}
internal void ProcessAuthentication(SignInStatus status) {
if (status == SignInStatus.Success) {
// Continue with Play Games Services
} else {
// Disable your integration with Play Games Services or show a login button
// to ask users to sign-in. Clicking it should call
// PlayGamesPlatform.Instance.ManuallyAuthenticate(ProcessAuthentication).
}
}
Sonuç kodu, oturum açma hatasının nedenini belirlemek için kullanabileceğiniz bir enum'dur.
Unity'nin Sosyal platformunu kullanmayı tercih ediyorsanız alternatif olarak aşağıdaki kodu kullanabilirsiniz:
using GooglePlayGames;
public void Start() {
PlayGamesPlatform.Activate();
Social.localUser.Authenticate(ProcessAuthentication);
}
Authenticate
'ten başarılı bir değer döndürülene kadar Google Play Games Hizmetleri API çağrısı yapamazsınız. Bu nedenle, kimlik doğrulama tamamlanana kadar kullanıcıların oyunu oynamaya başlayamamasını sağlamak için oyunlarda geri çağırma çağrısı yapılana kadar bekleme ekranı gösterilmesini öneririz.
Play Uygulama İmzalama özelliğini kullanma
Google, Play Uygulama İmzalama'yı kullanarak uygulamanızın imzalama anahtarını yönetir ve korur. Android App Bundle(AAB) dosyalarının optimize edilmiş dağıtım sürümlerini imzalamak için Play Uygulama İmzalama'yı kullanabilirsiniz. Play Uygulama İmzalama, uygulama imzalama anahtarınızı Google'ın güvenli altyapısında saklar. Play Uygulama İmzalama'yı kullanmak için öncelikle Unity Hub'dan bir AAB dosyası oluşturup indirmeniz gerekir. Ardından AAB dosyasını Play Console'a yükleyebilir ve dahili test sürümü oluşturabilirsiniz.
AAB dosyası oluşturma
Unity Hub'da AAB dosyası oluşturmak için aşağıdaki adımları uygulayın:
- Unity Hub'da Dosya > Derleme ayarları'nı tıklayın.
Uygulama Paketi Oluştur ( Google Play )'u seçin.
Daha fazla bilgi için Android Derleme Ayarları referansı başlıklı makaleyi inceleyin.
Derle'yi tıklayın.
AAB dosyasını Unity Hub'dan indirin.
Dahili test sürümü oluşturma
Play Console'da dahili test sürümü oluşturmak ve test kullanıcıları eklemek için aşağıdaki adımları uygulayın:
- Google Play Console'da bir oyun seçin.
- Test ve sürüm sayfasına (Test > Dahili test) gidin.
- Yükle'yi tıklayın ve AAB dosyasını seçin.
- Sürüm ayrıntıları alanına bir ad girin.
- İleri'yi tıklayın ve sürüm ayrıntılarını inceleyin.
- Kaydet ve yayınla'yı tıklayın.
100'e kadar test kullanıcısı eklemek için Test kullanıcıları sekmesinde E-posta listesi oluştur'u tıklayın.
Daha fazla bilgi için Dahili test: 100 kişiye kadar test kullanıcısını yönetme başlıklı makaleyi inceleyin.
Geri bildirimde bulunmak için Geri bildirim URL'si veya e-posta adresi alanına bir geri bildirim URL'si veya e-posta adresi girin.
Kaydet'i tıklayın.
Uygulama imzalama kimlik bilgilerinizi doğrulama
- Google Play Console'da bir oyun seçin.
- Test ve yayınla sayfasına (Kurulum > Uygulama imzalama) gidin.
- Uygulama imzalama kimlik bilgilerinizi doğrulayın.
Projeyi derleyip çalıştırma
Bu noktada oyun projesini derleyip çalıştırabilirsiniz. Oyun başladığında otomatik oturum açma girişimini görürsünüz.
USB hata ayıklama özelliğinin etkinleştirildiği fiziksel bir Android cihaza veya geliştirilen projeyi çalıştırabilecek bir emülatöre ihtiyacınız vardır.
Sunucu kimlik doğrulama kodlarını alma
Mevcut oynatıcı adına arka uç web sunucusunda Google API'lerine erişmek için istemci uygulamasından bir kimlik doğrulama kodu almanız ve bunu web sunucu uygulamanıza iletmeniz gerekir. Ardından kod, çeşitli API'lere çağrı yapmak için bir erişim jetonuyla değiştirilebilir. İş akışı hakkında bilgi edinmek için web için Google ile oturum açma başlıklı makaleyi inceleyin.
Sunucu tarafı erişim kodunu almak için:
Oyununuza bağlı web uygulamasının web istemci kimliğini Play Console'da yapılandırın.
Oyuncu kimliğini doğruladıktan sonra sunucu tarafı erişim kodunu almak için
PlayGamesPlatform.Instance.RequestServerSideAccess
'ü arayın.Bu kodu sunucu uygulamanıza iletin.
PlayGamesPlatform.Instance.RequestServerSideAccess(
/* forceRefreshToken= */ false,
code -> {
// send code to server
});
Özellik ayarlama ve ekleme
Play Oyun Hizmetleri özelliklerini etkinleştirin.
Play Games Hizmetleri API'lerini kullanarak oyununuza özellikler ekleyin:
Unity için Recall API (yalnızca Unity eklentisi v11 ve sonraki sürümlerde desteklenir)