WuhuIslandTesting/Library/PackageCache/com.unity.xr.management@4.2.1/Editor/XRGeneralSettingsPerBuildTarget.cs
2025-01-07 02:06:59 +01:00

259 lines
11 KiB
C#

using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Runtime.CompilerServices;
using UnityEngine;
using UnityEngine.XR.Management;
using UnityEditor.XR.Management.Metadata;
namespace UnityEditor.XR.Management
{
#if UNITY_EDITOR
[InitializeOnLoad]
#endif
/// <summary>Container class that holds general settings for each build target group installed in Unity.</summary>
public class XRGeneralSettingsPerBuildTarget : ScriptableObject, ISerializationCallbackReceiver
{
[SerializeField]
List<BuildTargetGroup> Keys = new List<BuildTargetGroup>();
[SerializeField]
List<XRGeneralSettings> Values = new List<XRGeneralSettings>();
Dictionary<BuildTargetGroup, XRGeneralSettings> Settings = new Dictionary<BuildTargetGroup, XRGeneralSettings>();
#if UNITY_EDITOR
static XRGeneralSettingsPerBuildTarget()
{
EditorApplication.playModeStateChanged -= PlayModeStateChanged;
EditorApplication.playModeStateChanged += PlayModeStateChanged;
}
// Simple class to give us updates when the asset database changes.
class AssetCallbacks : AssetPostprocessor
{
static bool m_Upgrade = true;
static void OnPostprocessAllAssets(string[] importedAssets, string[] deletedAssets, string[] movedAssets, string[] movedFromAssetPaths)
{
if (m_Upgrade)
{
m_Upgrade = false;
BeginUpgradeSettings();
}
}
static void BeginUpgradeSettings()
{
string searchText = "t:XRGeneralSettings";
string[] assets = AssetDatabase.FindAssets(searchText);
if (assets.Length > 0)
{
string path = AssetDatabase.GUIDToAssetPath(assets[0]);
XRGeneralSettingsUpgrade.UpgradeSettingsToPerBuildTarget(path);
}
}
}
void OnEnable()
{
foreach (var setting in Settings.Values)
{
var assignedSettings = setting.AssignedSettings;
if (assignedSettings == null)
continue;
var filteredLoaders = from ldr in assignedSettings.activeLoaders where ldr != null select ldr;
assignedSettings.TrySetLoaders(filteredLoaders.ToList<XRLoader>());
}
XRGeneralSettings.Instance = XRGeneralSettingsForBuildTarget(BuildTargetGroup.Standalone);
}
static void PlayModeStateChanged(PlayModeStateChange state)
{
XRGeneralSettingsPerBuildTarget buildTargetSettings = null;
EditorBuildSettings.TryGetConfigObject(XRGeneralSettings.k_SettingsKey, out buildTargetSettings);
if (buildTargetSettings == null)
{
buildTargetSettings = GetOrCreate();
}
XRGeneralSettings instance = buildTargetSettings.SettingsForBuildTarget(BuildTargetGroup.Standalone);
if (instance == null || !instance.InitManagerOnStart)
return;
instance.InternalPlayModeStateChanged(state);
}
internal static bool ContainsLoaderForAnyBuildTarget(string loaderTypeName)
{
XRGeneralSettingsPerBuildTarget buildTargetSettings = null;
EditorBuildSettings.TryGetConfigObject(XRGeneralSettings.k_SettingsKey, out buildTargetSettings);
if (buildTargetSettings == null)
return false;
foreach (var settings in buildTargetSettings.Settings.Values)
{
if (XRPackageMetadataStore.IsLoaderAssigned(settings.Manager, loaderTypeName))
return true;
}
return false;
}
[MethodImpl(MethodImplOptions.Synchronized)]
internal static XRGeneralSettingsPerBuildTarget GetOrCreate()
{
EditorBuildSettings.TryGetConfigObject<XRGeneralSettingsPerBuildTarget>(XRGeneralSettings.k_SettingsKey, out var generalSettings);
if (generalSettings == null)
{
string searchText = "t:XRGeneralSettings";
string[] assets = AssetDatabase.FindAssets(searchText);
if (assets.Length > 0)
{
string path = AssetDatabase.GUIDToAssetPath(assets[0]);
generalSettings = AssetDatabase.LoadAssetAtPath(path, typeof(XRGeneralSettingsPerBuildTarget)) as XRGeneralSettingsPerBuildTarget;
}
}
if (generalSettings == null)
{
generalSettings = CreateInstance(typeof(XRGeneralSettingsPerBuildTarget)) as XRGeneralSettingsPerBuildTarget;
string assetPath = EditorUtilities.GetAssetPathForComponents(EditorUtilities.s_DefaultGeneralSettingsPath);
if (!string.IsNullOrEmpty(assetPath))
{
assetPath = Path.Combine(assetPath, "XRGeneralSettings.asset");
AssetDatabase.CreateAsset(generalSettings, assetPath);
}
}
EditorBuildSettings.AddConfigObject(XRGeneralSettings.k_SettingsKey, generalSettings, true);
return generalSettings;
}
#endif
/// <summary>
/// Query this settings store to see if there are settings for a specific <see cref="BuildTargetGroup"/>.
/// </summary>
/// <param name="buildTargetGroup">Build target to check</param>
/// <returns>True if there are settings, otherwise false.</returns>
public bool HasSettingsForBuildTarget(BuildTargetGroup buildTargetGroup)
{
return SettingsForBuildTarget(buildTargetGroup) != null;
}
/// <summary>
/// Create default settings for a given build target.
///
/// This <b>will overwrite</b> any current settings for that build target.
/// </summary>
/// <param name="buildTargetGroup">Build target to create default settings for.</param>
public void CreateDefaultSettingsForBuildTarget(BuildTargetGroup buildTargetGroup)
{
var settings = ScriptableObject.CreateInstance<XRGeneralSettings>() as XRGeneralSettings;
SetSettingsForBuildTarget(buildTargetGroup, settings);
settings.name = $"{buildTargetGroup.ToString()} Settings";
AssetDatabase.AddObjectToAsset(settings, AssetDatabase.GetAssetOrScenePath(this));
AssetDatabase.SaveAssets();
}
/// <summary>Set specific settings for a given build target.</summary>
///
/// <param name="targetGroup">An enum specifying which platform group this build is for.</param>
/// <param name="settings">An instance of <see cref="XRGeneralSettings"/> to assign for the given key.</param>
public void SetSettingsForBuildTarget(BuildTargetGroup targetGroup, XRGeneralSettings settings)
{
// Ensures the editor's "runtime instance" is the most current for standalone settings
if (targetGroup == BuildTargetGroup.Standalone)
XRGeneralSettings.Instance = settings;
Settings[targetGroup] = settings;
}
/// <summary>Get specific settings for a given build target.</summary>
/// <param name="targetGroup">An enum specifying which platform group this build is for.</param>
/// <returns>The instance of <see cref="XRGeneralSettings"/> assigned to the key, or null if not.</returns>
public XRGeneralSettings SettingsForBuildTarget(BuildTargetGroup targetGroup)
{
XRGeneralSettings ret = null;
Settings.TryGetValue(targetGroup, out ret);
return ret;
}
/// <summary>
/// Check if current settings instance has an instance of <see cref="XRManagerSettings"/>.
/// </summary>
/// <param name="targetGroup">An enum specifying which platform group this build is for.</param>
/// <returns>True if it exists, false otherwise.</returns>
public bool HasManagerSettingsForBuildTarget(BuildTargetGroup targetGroup)
{
return (SettingsForBuildTarget(targetGroup)?.Manager ?? null) != null;
}
/// <summary>
/// Create a new default instance of <see cref="XRManagerSettings"/> for a build target. Requires
/// that the there exists a settings instance for the build target. If there isn't, then one is created.
///
/// This <b>will overwrite</b> any current settings for that build target.
/// </summary>
/// <param name="targetGroup">An enum specifying which platform group this build is for.</param>
public void CreateDefaultManagerSettingsForBuildTarget(BuildTargetGroup targetGroup)
{
if (!HasSettingsForBuildTarget(targetGroup))
CreateDefaultSettingsForBuildTarget(targetGroup);
var xrManagerSettings = ScriptableObject.CreateInstance<XRManagerSettings>() as XRManagerSettings;
xrManagerSettings.name = $"{targetGroup.ToString()} Providers";
SettingsForBuildTarget(targetGroup).Manager = xrManagerSettings;
AssetDatabase.AddObjectToAsset(xrManagerSettings, AssetDatabase.GetAssetOrScenePath(this));
AssetDatabase.SaveAssets();
}
/// <summary>
/// Return the current instance of <see cref="XRManagerSettings"/> for a build target.
/// </summary>
/// <param name="targetGroup">An enum specifying which platform group this build is for.</param>
/// <returns></returns>
public XRManagerSettings ManagerSettingsForBuildTarget(BuildTargetGroup targetGroup)
{
return SettingsForBuildTarget(targetGroup)?.Manager ?? null;
}
/// <summary>Serialization override.</summary>
public void OnBeforeSerialize()
{
Keys.Clear();
Values.Clear();
foreach (var kv in Settings)
{
Keys.Add(kv.Key);
Values.Add(kv.Value);
}
}
/// <summary>Serialization override.</summary>
public void OnAfterDeserialize()
{
Settings = new Dictionary<BuildTargetGroup, XRGeneralSettings>();
for (int i = 0; i < Math.Min(Keys.Count, Values.Count); i++)
{
Settings.Add(Keys[i], Values[i]);
}
}
/// <summary>Given a build target, get the general settings container assigned to it.</summary>
/// <param name="targetGroup">An enum specifying which platform group this build is for.</param>
/// <returns>The instance of <see cref="XRGeneralSettings"/> assigned to the key, or null if not.</returns>
public static XRGeneralSettings XRGeneralSettingsForBuildTarget(BuildTargetGroup targetGroup)
{
XRGeneralSettingsPerBuildTarget buildTargetSettings = null;
EditorBuildSettings.TryGetConfigObject(XRGeneralSettings.k_SettingsKey, out buildTargetSettings);
if (buildTargetSettings == null)
return null;
return buildTargetSettings.SettingsForBuildTarget(targetGroup);
}
}
}