Provides access to your remote settings.
At the start of a new session of your application, Unity makes a network request for the latest remote settings configuration from the Analytics Service. Unity requests the Release configuration when running regular, non-development builds of your application, and requests the Development configuration when running development builds. Play mode in the Unity Editor counts as a development build.
Note: For Unity to request the Development configuration, you must build the application with Unity version 5.6.0p4+, 5.6.1p1+, 2017.1+, or Unity 5.5.3p4+, and tick the Development Build checkbox on the Build Settings window. If you build the game with an older version of Unity, Unity always requests the Release configuration.
The RemoteSettings
object dispatches a BeforeFetchFromServer:: event before it makes the network request for settings.
The Remote Settings
object then dispatches an Updated event if a configuration file is available. Note that if the network request fails and a remote configuration file is not available, the RemoteSettings
object checks whether a local, cached configuration file is present. If so, it uses these cached values and still dispatches Updated. Updated is only not dispatched when the remote request fails and no cached version is present.
Whether or not the remote request succeeds, the RemoteSettings
object dispatches the Completed event. The parameters passed to the Completed
event provide the HTTP response code and whether a remote configuration file was received.
When the RemoteSettings
object receives a remote configuration it caches the file for use when the current computer or device is offline. However, if your game instance has not saved the settings yet (such as when a player has no network connection the first time they run your game), then the RemoteSettings object does not dispatch an Updated event, and so does not update your game variables. Requesting the Remote Settings configuration over the network is an asynchronous process that might not complete before your initial Scene has finished loading, or might not complete successfully at all, so you should always initialize your game variables to reasonable defaults.
Note: The web service from which Unity downloads the Remote Settings configuration is read-only, but is not secured. This means that the configuration could be read by third-parties. You should not put sensitive or secret information into your Remote Settings. Similarly, the saved settings file could be read and modified by end-users (although any modifications are overwritten the next time a session starts with an available Internet connection).
Create remote settings as key-value pairs on your Analytics dashboard.
You can only store basic types in the Remote Settings (int, float,
string and boolean).
See Also: Remote Settings (Manual).
using UnityEngine;
public class HandleRemoteSettings : MonoBehaviour { private void Start() { // Add this class's updated settings handler to the RemoteSettings.Updated event. RemoteSettings.Updated += RemoteSettingsUpdated; }
private static void RemoteSettingsUpdated() { Debug.Log("***** GOT NEW REMOTE SETTINGS ******"); Debug.Log(RemoteSettings.GetInt("testInt")); Debug.Log(RemoteSettings.GetString("testString")); Debug.Log(RemoteSettings.GetFloat("testFloat")); Debug.Log(RemoteSettings.GetBool("testBool")); Debug.Log(RemoteSettings.GetBool("testFakeKey")); Debug.Log(RemoteSettings.GetBool("testFakeKey", true)); Debug.Log(RemoteSettings.HasKey("qqq")); Debug.Log(RemoteSettings.HasKey("testInt")); Debug.Log(RemoteSettings.GetBool("unity.heatmaps")); } }
ForceUpdate | Forces the game to download the newest settings from the server and update its values. |
GetBool | Gets the value corresponding to remote setting identified by key, if it exists. |
GetCount | Gets the number of keys in the remote settings configuration. |
GetDictionary | Gets a dictionary corresponding to the remote setting identified by key, if it exists. |
GetFloat | Gets the value corresponding to remote setting identified by key, if it exists. |
GetInt | Gets the value corresponding to remote setting identified by key, if it exists. |
GetKeys | Gets an array containing all the keys in the remote settings configuration. |
GetLong | Gets the value corresponding to remote setting identified by key, if it exists. |
GetObject | Gets the object corresponding to the remote setting identified by key, if it exists. |
GetString | Gets the value corresponding to remote setting identified by key, if it exists. |
HasKey | Reports whether the specified key exists in the remote settings configuration. |
WasLastUpdatedFromServer | Reports whether or not the settings available from the RemoteSettings object were received from the Analytics Service during the current session. |
BeforeFetchFromServer | Dispatched before the RemoteSettings object makes the network request for the latest settings. |
Completed | Dispatched when the network request made by the RemoteSettings object to fetch the remote configuration file is complete. |
Updated | Dispatched when a remote settings configuration is fetched and successfully parsed from the server or from local cache. |
UpdatedEventHandler | Defines the delegate signature for handling RemoteSettings.Updated events. |
Did you find this page useful? Please give it a rating:
Thanks for rating this page!
What kind of problem would you like to report?
Thanks for letting us know! This page has been marked for review based on your feedback.
If you have time, you can provide more information to help us fix the problem faster.
Provide more information
You've told us this page needs code samples. If you'd like to help us further, you could provide a code sample, or tell us about what kind of code sample you'd like to see:
You've told us there are code samples on this page which don't work. If you know how to fix it, or have something better we could use instead, please let us know:
You've told us there is information missing from this page. Please tell us more about what's missing:
You've told us there is incorrect information on this page. If you know what we should change to make it correct, please tell us:
You've told us this page has unclear or confusing information. Please tell us more about what you found unclear or confusing, or let us know how we could make it clearer:
You've told us there is a spelling or grammar error on this page. Please tell us what's wrong:
You've told us this page has a problem. Please tell us more about what's wrong:
Thank you for helping to make the Unity documentation better!
Your feedback has been submitted as a ticket for our documentation team to review.
We are not able to reply to every ticket submitted.