Legacy Documentation: Version 5.6 (Go to current version)
LanguageEnglish
  • C#
  • JS

Script language

Select your preferred scripting language. All code snippets will be displayed in this language.

GameCenterPlatform

class in UnityEngine.SocialPlatforms.GameCenter


Implements interfaces:ISocialPlatform, ISocialPlatform

Suggest a change

Success!

Thank you for helping us improve the quality of Unity Documentation. Although we cannot accept all submissions, we do read each suggested change from our users and will make updates where applicable.

Close

Submission failed

For some reason your suggested change could not be submitted. Please <a>try again</a> in a few minutes. And thank you for taking the time to help us improve the quality of Unity Documentation.

Close

Cancel

Description

iOS GameCenter implementation for network services.

An application bundle ID must be registered on iTunes Connect before it can access GameCenter. This ID must be properly set in the iOS player properties in Unity. When debugging you can use the GameCenter sandbox (a text displaying this is shown when logging on). You must log on in the application to get into sandbox mode, logging on in the GameCenter application will always use the production version.

When using the GameCenterPlatform class in C# you need to include the UnityEngine.SocialPlatforms.GameCenter namespace.

Some things to be aware of when using the generic API:

Authenticate()
If the user is not logged in, a standard GameKit UI is shown where they can log on or create a new user. It is recommended this is done as early as possible.

Achievement descriptions and Leaderboards
The achivements descriptions and leaderboard configurations can be configured in the iTunes Connect portal. Achievements get unique identifiers and the leaderboards use category names as identifiers.

GameCenter Sandbox
Development applications use the GameCenter Sandbox. This is a seperate GameCenter than the live one, nothing is shared between them. It is recommended that you create a seperate user for testing with the GameCenter Sandbox, you should not use your real Apple ID for this. You can only log on to the sandbox through a development application, make sure you are not logged into GameCenter using the GameCenter app before testing begins. You should see *** Sandbox *** in the login dialog, if you don't see this then you are logging on to the real one. Sometime it happens that the OS forgets that the application is using the sandbox and you will be logged on to the real one. If the application has not be submitted to Apple already then this will probably result in an error. To fix this all that needs to be done is to delete the app and redeploy with Xcode. To make another apple ID a friend of a sandbox user it needs to be a sandbox user as well.

If you start getting errors when accessing GameCenter stating that the application is not recognized you'll need to delete the application complately and re-deploy. Make sure you are not logged on when starting the newly installed application again.

Static Functions

ResetAllAchievementsReset all the achievements for the local user.
ShowDefaultAchievementCompletionBannerShow the default iOS banner when achievements are completed.
ShowLeaderboardUIShow the leaderboard UI with a specific leaderboard shown initially with a specific time scope selected.