123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974 |
- using System;
- using System.Diagnostics;
- using System.Collections;
- using System.Collections.Generic;
- using UnityEngine.SceneManagement;
- namespace YooAsset
- {
- public class ResourcePackage
- {
- private bool _isInitialize = false;
- private string _initializeError = string.Empty;
- private EOperationStatus _initializeStatus = EOperationStatus.None;
- private EPlayMode _playMode;
- private IBundleServices _bundleServices;
- private IPlayModeServices _playModeServices;
- internal IPlayModeServices PlayModeServices { get { return _playModeServices; } }
- private AssetSystemImpl _assetSystemImpl;
- /// <summary>
- /// 包裹名
- /// </summary>
- public string PackageName { private set; get; }
- /// <summary>
- /// 初始化状态
- /// </summary>
- public EOperationStatus InitializeStatus
- {
- get { return _initializeStatus; }
- }
- private ResourcePackage()
- {
- }
- internal ResourcePackage(string packageName)
- {
- PackageName = packageName;
- }
- /// <summary>
- /// 更新资源包裹
- /// </summary>
- internal void UpdatePackage()
- {
- if (_assetSystemImpl != null)
- _assetSystemImpl.Update();
- }
- /// <summary>
- /// 销毁资源包裹
- /// </summary>
- internal void DestroyPackage()
- {
- if (_isInitialize)
- {
- _isInitialize = false;
- _initializeError = string.Empty;
- _initializeStatus = EOperationStatus.None;
- _bundleServices = null;
- _playModeServices = null;
- if (_assetSystemImpl != null)
- {
- _assetSystemImpl.ForceUnloadAllAssets();
- _assetSystemImpl = null;
- }
- }
- }
- /// <summary>
- /// 异步初始化
- /// </summary>
- public InitializationOperation InitializeAsync(InitializeParameters parameters)
- {
- // 注意:WebGL平台因为网络原因可能会初始化失败!
- ResetInitializeAfterFailed();
- // 检测初始化参数合法性
- CheckInitializeParameters(parameters);
- // 重写持久化根目录
- var persistent = PersistentTools.GetOrCreatePersistent(PackageName);
- persistent.OverwriteRootDirectory(parameters.BuildinRootDirectory, parameters.SandboxRootDirectory);
- // 初始化资源系统
- InitializationOperation initializeOperation;
- _assetSystemImpl = new AssetSystemImpl();
- if (_playMode == EPlayMode.EditorSimulateMode)
- {
- var editorSimulateModeImpl = new EditorSimulateModeImpl();
- _bundleServices = editorSimulateModeImpl;
- _playModeServices = editorSimulateModeImpl;
- _assetSystemImpl.Initialize(PackageName, true,
- parameters.LoadingMaxTimeSlice, parameters.DownloadFailedTryAgain,
- parameters.DecryptionServices, _bundleServices);
- var initializeParameters = parameters as EditorSimulateModeParameters;
- initializeOperation = editorSimulateModeImpl.InitializeAsync(initializeParameters.SimulateManifestFilePath);
- }
- else if (_playMode == EPlayMode.OfflinePlayMode)
- {
- var offlinePlayModeImpl = new OfflinePlayModeImpl();
- _bundleServices = offlinePlayModeImpl;
- _playModeServices = offlinePlayModeImpl;
- _assetSystemImpl.Initialize(PackageName, false,
- parameters.LoadingMaxTimeSlice, parameters.DownloadFailedTryAgain,
- parameters.DecryptionServices, _bundleServices);
- var initializeParameters = parameters as OfflinePlayModeParameters;
- initializeOperation = offlinePlayModeImpl.InitializeAsync(PackageName);
- }
- else if (_playMode == EPlayMode.HostPlayMode)
- {
- var hostPlayModeImpl = new HostPlayModeImpl();
- _bundleServices = hostPlayModeImpl;
- _playModeServices = hostPlayModeImpl;
- _assetSystemImpl.Initialize(PackageName, false,
- parameters.LoadingMaxTimeSlice, parameters.DownloadFailedTryAgain,
- parameters.DecryptionServices, _bundleServices);
- var initializeParameters = parameters as HostPlayModeParameters;
- initializeOperation = hostPlayModeImpl.InitializeAsync(
- PackageName,
- initializeParameters.QueryServices,
- initializeParameters.RemoteServices
- );
- }
- else
- {
- throw new NotImplementedException();
- }
- // 监听初始化结果
- _isInitialize = true;
- initializeOperation.Completed += InitializeOperation_Completed;
- return initializeOperation;
- }
- private void ResetInitializeAfterFailed()
- {
- if (_isInitialize && _initializeStatus == EOperationStatus.Failed)
- {
- _isInitialize = false;
- _initializeStatus = EOperationStatus.None;
- _initializeError = string.Empty;
- _bundleServices = null;
- _playModeServices = null;
- _assetSystemImpl = null;
- }
- }
- private void CheckInitializeParameters(InitializeParameters parameters)
- {
- if (_isInitialize)
- throw new Exception($"{nameof(ResourcePackage)} is initialized yet.");
- if (parameters == null)
- throw new Exception($"{nameof(ResourcePackage)} create parameters is null.");
- #if !UNITY_EDITOR
- if (parameters is EditorSimulateModeParameters)
- throw new Exception($"Editor simulate mode only support unity editor.");
- #endif
- if (parameters is EditorSimulateModeParameters)
- {
- var editorSimulateModeParameters = parameters as EditorSimulateModeParameters;
- if (string.IsNullOrEmpty(editorSimulateModeParameters.SimulateManifestFilePath))
- throw new Exception($"{nameof(editorSimulateModeParameters.SimulateManifestFilePath)} is null or empty.");
- }
- if (parameters is HostPlayModeParameters)
- {
- var hostPlayModeParameters = parameters as HostPlayModeParameters;
- if (hostPlayModeParameters.QueryServices == null)
- throw new Exception($"{nameof(IQueryServices)} is null.");
- if (hostPlayModeParameters.RemoteServices == null)
- throw new Exception($"{nameof(IRemoteServices)} is null.");
- }
- // 鉴定运行模式
- if (parameters is EditorSimulateModeParameters)
- _playMode = EPlayMode.EditorSimulateMode;
- else if (parameters is OfflinePlayModeParameters)
- _playMode = EPlayMode.OfflinePlayMode;
- else if (parameters is HostPlayModeParameters)
- _playMode = EPlayMode.HostPlayMode;
- else
- throw new NotImplementedException();
- // 检测参数范围
- if (parameters.LoadingMaxTimeSlice < 10)
- {
- parameters.LoadingMaxTimeSlice = 10;
- YooLogger.Warning($"{nameof(parameters.LoadingMaxTimeSlice)} minimum value is 10 milliseconds.");
- }
- if (parameters.DownloadFailedTryAgain < 1)
- {
- parameters.DownloadFailedTryAgain = 1;
- YooLogger.Warning($"{nameof(parameters.DownloadFailedTryAgain)} minimum value is 1");
- }
- }
- private void InitializeOperation_Completed(AsyncOperationBase op)
- {
- _initializeStatus = op.Status;
- _initializeError = op.Error;
- }
- /// <summary>
- /// 向网络端请求最新的资源版本
- /// </summary>
- /// <param name="appendTimeTicks">在URL末尾添加时间戳</param>
- /// <param name="timeout">超时时间(默认值:60秒)</param>
- public UpdatePackageVersionOperation UpdatePackageVersionAsync(bool appendTimeTicks = true, int timeout = 60)
- {
- DebugCheckInitialize();
- return _playModeServices.UpdatePackageVersionAsync(appendTimeTicks, timeout);
- }
- /// <summary>
- /// 向网络端请求并更新清单
- /// </summary>
- /// <param name="packageVersion">更新的包裹版本</param>
- /// <param name="autoSaveVersion">更新成功后自动保存版本号,作为下次初始化的版本。</param>
- /// <param name="timeout">超时时间(默认值:60秒)</param>
- public UpdatePackageManifestOperation UpdatePackageManifestAsync(string packageVersion, bool autoSaveVersion = true, int timeout = 60)
- {
- DebugCheckInitialize();
- DebugCheckUpdateManifest();
- return _playModeServices.UpdatePackageManifestAsync(packageVersion, autoSaveVersion, timeout);
- }
- /// <summary>
- /// 预下载指定版本的包裹资源
- /// </summary>
- /// <param name="packageVersion">下载的包裹版本</param>
- /// <param name="timeout">超时时间(默认值:60秒)</param>
- public PreDownloadContentOperation PreDownloadContentAsync(string packageVersion, int timeout = 60)
- {
- DebugCheckInitialize();
- return _playModeServices.PreDownloadContentAsync(packageVersion, timeout);
- }
- /// <summary>
- /// 清理包裹未使用的缓存文件
- /// </summary>
- public ClearUnusedCacheFilesOperation ClearUnusedCacheFilesAsync()
- {
- DebugCheckInitialize();
- var operation = new ClearUnusedCacheFilesOperation(this);
- OperationSystem.StartOperation(operation);
- return operation;
- }
- /// <summary>
- /// 清理包裹本地所有的缓存文件
- /// </summary>
- public ClearAllCacheFilesOperation ClearAllCacheFilesAsync()
- {
- DebugCheckInitialize();
- var operation = new ClearAllCacheFilesOperation(this);
- OperationSystem.StartOperation(operation);
- return operation;
- }
- /// <summary>
- /// 获取本地包裹的版本信息
- /// </summary>
- public string GetPackageVersion()
- {
- DebugCheckInitialize();
- if (_playModeServices.ActiveManifest == null)
- return string.Empty;
- return _playModeServices.ActiveManifest.PackageVersion;
- }
- /// <summary>
- /// 资源回收(卸载引用计数为零的资源)
- /// </summary>
- public void UnloadUnusedAssets()
- {
- DebugCheckInitialize();
- _assetSystemImpl.Update();
- _assetSystemImpl.UnloadUnusedAssets();
- }
- /// <summary>
- /// 强制回收所有资源
- /// </summary>
- public void ForceUnloadAllAssets()
- {
- DebugCheckInitialize();
- _assetSystemImpl.ForceUnloadAllAssets();
- }
- #region 沙盒相关
- /// <summary>
- /// 获取包裹的内置文件根路径
- /// </summary>
- public string GetPackageBuildinRootDirectory()
- {
- DebugCheckInitialize();
- var persistent = PersistentTools.GetPersistent(PackageName);
- return persistent.BuildinRoot;
- }
- /// <summary>
- /// 获取包裹的沙盒文件根路径
- /// </summary>
- public string GetPackageSandboxRootDirectory()
- {
- DebugCheckInitialize();
- var persistent = PersistentTools.GetPersistent(PackageName);
- return persistent.SandboxRoot;
- }
- /// <summary>
- /// 清空包裹的沙盒目录
- /// </summary>
- public void ClearPackageSandbox()
- {
- DebugCheckInitialize();
- var persistent = PersistentTools.GetPersistent(PackageName);
- persistent.DeleteSandboxPackageFolder();
- }
- #endregion
- #region 资源信息
- /// <summary>
- /// 是否需要从远端更新下载
- /// </summary>
- /// <param name="location">资源的定位地址</param>
- public bool IsNeedDownloadFromRemote(string location)
- {
- DebugCheckInitialize();
- AssetInfo assetInfo = ConvertLocationToAssetInfo(location, null);
- if (assetInfo.IsInvalid)
- {
- YooLogger.Warning(assetInfo.Error);
- return false;
- }
- BundleInfo bundleInfo = _bundleServices.GetBundleInfo(assetInfo);
- if (bundleInfo.LoadMode == BundleInfo.ELoadMode.LoadFromRemote)
- return true;
- else
- return false;
- }
- /// <summary>
- /// 是否需要从远端更新下载
- /// </summary>
- /// <param name="location">资源的定位地址</param>
- public bool IsNeedDownloadFromRemote(AssetInfo assetInfo)
- {
- DebugCheckInitialize();
- if (assetInfo.IsInvalid)
- {
- YooLogger.Warning(assetInfo.Error);
- return false;
- }
- BundleInfo bundleInfo = _bundleServices.GetBundleInfo(assetInfo);
- if (bundleInfo.LoadMode == BundleInfo.ELoadMode.LoadFromRemote)
- return true;
- else
- return false;
- }
- /// <summary>
- /// 获取资源信息列表
- /// </summary>
- /// <param name="tag">资源标签</param>
- public AssetInfo[] GetAssetInfos(string tag)
- {
- DebugCheckInitialize();
- string[] tags = new string[] { tag };
- return _playModeServices.ActiveManifest.GetAssetsInfoByTags(tags);
- }
- /// <summary>
- /// 获取资源信息列表
- /// </summary>
- /// <param name="tags">资源标签列表</param>
- public AssetInfo[] GetAssetInfos(string[] tags)
- {
- DebugCheckInitialize();
- return _playModeServices.ActiveManifest.GetAssetsInfoByTags(tags);
- }
- /// <summary>
- /// 获取资源信息
- /// </summary>
- /// <param name="location">资源的定位地址</param>
- public AssetInfo GetAssetInfo(string location)
- {
- DebugCheckInitialize();
- return ConvertLocationToAssetInfo(location, null);
- }
- /// <summary>
- /// 获取资源信息
- /// </summary>
- /// <param name="assetGUID">资源GUID</param>
- public AssetInfo GetAssetInfoByGUID(string assetGUID)
- {
- DebugCheckInitialize();
- return ConvertAssetGUIDToAssetInfo(assetGUID, null);
- }
- /// <summary>
- /// 检查资源定位地址是否有效
- /// </summary>
- /// <param name="location">资源的定位地址</param>
- public bool CheckLocationValid(string location)
- {
- DebugCheckInitialize();
- string assetPath = _playModeServices.ActiveManifest.TryMappingToAssetPath(location);
- return string.IsNullOrEmpty(assetPath) == false;
- }
- #endregion
- #region 原生文件
- /// <summary>
- /// 同步加载原生文件
- /// </summary>
- /// <param name="assetInfo">资源信息</param>
- public RawFileOperationHandle LoadRawFileSync(AssetInfo assetInfo)
- {
- DebugCheckInitialize();
- return LoadRawFileInternal(assetInfo, true);
- }
- /// <summary>
- /// 同步加载原生文件
- /// </summary>
- /// <param name="location">资源的定位地址</param>
- public RawFileOperationHandle LoadRawFileSync(string location)
- {
- DebugCheckInitialize();
- AssetInfo assetInfo = ConvertLocationToAssetInfo(location, null);
- return LoadRawFileInternal(assetInfo, true);
- }
- /// <summary>
- /// 异步加载原生文件
- /// </summary>
- /// <param name="assetInfo">资源信息</param>
- public RawFileOperationHandle LoadRawFileAsync(AssetInfo assetInfo)
- {
- DebugCheckInitialize();
- return LoadRawFileInternal(assetInfo, false);
- }
- /// <summary>
- /// 异步加载原生文件
- /// </summary>
- /// <param name="location">资源的定位地址</param>
- public RawFileOperationHandle LoadRawFileAsync(string location)
- {
- DebugCheckInitialize();
- AssetInfo assetInfo = ConvertLocationToAssetInfo(location, null);
- return LoadRawFileInternal(assetInfo, false);
- }
- private RawFileOperationHandle LoadRawFileInternal(AssetInfo assetInfo, bool waitForAsyncComplete)
- {
- #if UNITY_EDITOR
- if (assetInfo.IsInvalid == false)
- {
- BundleInfo bundleInfo = _bundleServices.GetBundleInfo(assetInfo);
- if (bundleInfo.Bundle.IsRawFile == false)
- throw new Exception($"Cannot load asset bundle file using {nameof(LoadRawFileAsync)} method !");
- }
- #endif
- var handle = _assetSystemImpl.LoadRawFileAsync(assetInfo);
- if (waitForAsyncComplete)
- handle.WaitForAsyncComplete();
- return handle;
- }
- #endregion
- #region 场景加载
- /// <summary>
- /// 异步加载场景
- /// </summary>
- /// <param name="location">场景的定位地址</param>
- /// <param name="sceneMode">场景加载模式</param>
- /// <param name="suspendLoad">场景加载到90%自动挂起</param>
- /// <param name="priority">优先级</param>
- public SceneOperationHandle LoadSceneAsync(string location, LoadSceneMode sceneMode = LoadSceneMode.Single, bool suspendLoad = false, int priority = 100)
- {
- DebugCheckInitialize();
- AssetInfo assetInfo = ConvertLocationToAssetInfo(location, null);
- var handle = _assetSystemImpl.LoadSceneAsync(assetInfo, sceneMode, suspendLoad, priority);
- return handle;
- }
- /// <summary>
- /// 异步加载场景
- /// </summary>
- /// <param name="assetInfo">场景的资源信息</param>
- /// <param name="sceneMode">场景加载模式</param>
- /// <param name="suspendLoad">场景加载到90%自动挂起</param>
- /// <param name="priority">优先级</param>
- public SceneOperationHandle LoadSceneAsync(AssetInfo assetInfo, LoadSceneMode sceneMode = LoadSceneMode.Single, bool suspendLoad = false, int priority = 100)
- {
- DebugCheckInitialize();
- var handle = _assetSystemImpl.LoadSceneAsync(assetInfo, sceneMode, suspendLoad, priority);
- return handle;
- }
- #endregion
- #region 资源加载
- /// <summary>
- /// 同步加载资源对象
- /// </summary>
- /// <param name="assetInfo">资源信息</param>
- public AssetOperationHandle LoadAssetSync(AssetInfo assetInfo)
- {
- DebugCheckInitialize();
- return LoadAssetInternal(assetInfo, true);
- }
- /// <summary>
- /// 同步加载资源对象
- /// </summary>
- /// <typeparam name="TObject">资源类型</typeparam>
- /// <param name="location">资源的定位地址</param>
- public AssetOperationHandle LoadAssetSync<TObject>(string location) where TObject : UnityEngine.Object
- {
- DebugCheckInitialize();
- AssetInfo assetInfo = ConvertLocationToAssetInfo(location, typeof(TObject));
- return LoadAssetInternal(assetInfo, true);
- }
- /// <summary>
- /// 同步加载资源对象
- /// </summary>
- /// <param name="location">资源的定位地址</param>
- /// <param name="type">资源类型</param>
- public AssetOperationHandle LoadAssetSync(string location, System.Type type)
- {
- DebugCheckInitialize();
- AssetInfo assetInfo = ConvertLocationToAssetInfo(location, type);
- return LoadAssetInternal(assetInfo, true);
- }
- /// <summary>
- /// 异步加载资源对象
- /// </summary>
- /// <param name="assetInfo">资源信息</param>
- public AssetOperationHandle LoadAssetAsync(AssetInfo assetInfo)
- {
- DebugCheckInitialize();
- return LoadAssetInternal(assetInfo, false);
- }
- /// <summary>
- /// 异步加载资源对象
- /// </summary>
- /// <typeparam name="TObject">资源类型</typeparam>
- /// <param name="location">资源的定位地址</param>
- public AssetOperationHandle LoadAssetAsync<TObject>(string location) where TObject : UnityEngine.Object
- {
- DebugCheckInitialize();
- AssetInfo assetInfo = ConvertLocationToAssetInfo(location, typeof(TObject));
- return LoadAssetInternal(assetInfo, false);
- }
- /// <summary>
- /// 异步加载资源对象
- /// </summary>
- /// <param name="location">资源的定位地址</param>
- /// <param name="type">资源类型</param>
- public AssetOperationHandle LoadAssetAsync(string location, System.Type type)
- {
- DebugCheckInitialize();
- AssetInfo assetInfo = ConvertLocationToAssetInfo(location, type);
- return LoadAssetInternal(assetInfo, false);
- }
- private AssetOperationHandle LoadAssetInternal(AssetInfo assetInfo, bool waitForAsyncComplete)
- {
- #if UNITY_EDITOR
- if (assetInfo.IsInvalid == false)
- {
- BundleInfo bundleInfo = _bundleServices.GetBundleInfo(assetInfo);
- if (bundleInfo.Bundle.IsRawFile)
- throw new Exception($"Cannot load raw file using {nameof(LoadAssetAsync)} method !");
- }
- #endif
- var handle = _assetSystemImpl.LoadAssetAsync(assetInfo);
- if (waitForAsyncComplete)
- handle.WaitForAsyncComplete();
- return handle;
- }
- #endregion
- #region 资源加载
- /// <summary>
- /// 同步加载子资源对象
- /// </summary>
- /// <param name="assetInfo">资源信息</param>
- public SubAssetsOperationHandle LoadSubAssetsSync(AssetInfo assetInfo)
- {
- DebugCheckInitialize();
- return LoadSubAssetsInternal(assetInfo, true);
- }
- /// <summary>
- /// 同步加载子资源对象
- /// </summary>
- /// <typeparam name="TObject">资源类型</typeparam>
- /// <param name="location">资源的定位地址</param>
- public SubAssetsOperationHandle LoadSubAssetsSync<TObject>(string location) where TObject : UnityEngine.Object
- {
- DebugCheckInitialize();
- AssetInfo assetInfo = ConvertLocationToAssetInfo(location, typeof(TObject));
- return LoadSubAssetsInternal(assetInfo, true);
- }
- /// <summary>
- /// 同步加载子资源对象
- /// </summary>
- /// <param name="location">资源的定位地址</param>
- /// <param name="type">子对象类型</param>
- public SubAssetsOperationHandle LoadSubAssetsSync(string location, System.Type type)
- {
- DebugCheckInitialize();
- AssetInfo assetInfo = ConvertLocationToAssetInfo(location, type);
- return LoadSubAssetsInternal(assetInfo, true);
- }
- /// <summary>
- /// 异步加载子资源对象
- /// </summary>
- /// <param name="assetInfo">资源信息</param>
- public SubAssetsOperationHandle LoadSubAssetsAsync(AssetInfo assetInfo)
- {
- DebugCheckInitialize();
- return LoadSubAssetsInternal(assetInfo, false);
- }
- /// <summary>
- /// 异步加载子资源对象
- /// </summary>
- /// <typeparam name="TObject">资源类型</typeparam>
- /// <param name="location">资源的定位地址</param>
- public SubAssetsOperationHandle LoadSubAssetsAsync<TObject>(string location) where TObject : UnityEngine.Object
- {
- DebugCheckInitialize();
- AssetInfo assetInfo = ConvertLocationToAssetInfo(location, typeof(TObject));
- return LoadSubAssetsInternal(assetInfo, false);
- }
- /// <summary>
- /// 异步加载子资源对象
- /// </summary>
- /// <param name="location">资源的定位地址</param>
- /// <param name="type">子对象类型</param>
- public SubAssetsOperationHandle LoadSubAssetsAsync(string location, System.Type type)
- {
- DebugCheckInitialize();
- AssetInfo assetInfo = ConvertLocationToAssetInfo(location, type);
- return LoadSubAssetsInternal(assetInfo, false);
- }
- private SubAssetsOperationHandle LoadSubAssetsInternal(AssetInfo assetInfo, bool waitForAsyncComplete)
- {
- #if UNITY_EDITOR
- if (assetInfo.IsInvalid == false)
- {
- BundleInfo bundleInfo = _bundleServices.GetBundleInfo(assetInfo);
- if (bundleInfo.Bundle.IsRawFile)
- throw new Exception($"Cannot load raw file using {nameof(LoadSubAssetsAsync)} method !");
- }
- #endif
- var handle = _assetSystemImpl.LoadSubAssetsAsync(assetInfo);
- if (waitForAsyncComplete)
- handle.WaitForAsyncComplete();
- return handle;
- }
- #endregion
- #region 资源加载
- /// <summary>
- /// 同步加载资源包内所有资源对象
- /// </summary>
- /// <param name="assetInfo">资源信息</param>
- public AllAssetsOperationHandle LoadAllAssetsSync(AssetInfo assetInfo)
- {
- DebugCheckInitialize();
- return LoadAllAssetsInternal(assetInfo, true);
- }
- /// <summary>
- /// 同步加载资源包内所有资源对象
- /// </summary>
- /// <typeparam name="TObject">资源类型</typeparam>
- /// <param name="location">资源的定位地址</param>
- public AllAssetsOperationHandle LoadAllAssetsSync<TObject>(string location) where TObject : UnityEngine.Object
- {
- DebugCheckInitialize();
- AssetInfo assetInfo = ConvertLocationToAssetInfo(location, typeof(TObject));
- return LoadAllAssetsInternal(assetInfo, true);
- }
- /// <summary>
- /// 同步加载资源包内所有资源对象
- /// </summary>
- /// <param name="location">资源的定位地址</param>
- /// <param name="type">子对象类型</param>
- public AllAssetsOperationHandle LoadAllAssetsSync(string location, System.Type type)
- {
- DebugCheckInitialize();
- AssetInfo assetInfo = ConvertLocationToAssetInfo(location, type);
- return LoadAllAssetsInternal(assetInfo, true);
- }
- /// <summary>
- /// 异步加载资源包内所有资源对象
- /// </summary>
- /// <param name="assetInfo">资源信息</param>
- public AllAssetsOperationHandle LoadAllAssetsAsync(AssetInfo assetInfo)
- {
- DebugCheckInitialize();
- return LoadAllAssetsInternal(assetInfo, false);
- }
- /// <summary>
- /// 异步加载资源包内所有资源对象
- /// </summary>
- /// <typeparam name="TObject">资源类型</typeparam>
- /// <param name="location">资源的定位地址</param>
- public AllAssetsOperationHandle LoadAllAssetsAsync<TObject>(string location) where TObject : UnityEngine.Object
- {
- DebugCheckInitialize();
- AssetInfo assetInfo = ConvertLocationToAssetInfo(location, typeof(TObject));
- return LoadAllAssetsInternal(assetInfo, false);
- }
- /// <summary>
- /// 异步加载资源包内所有资源对象
- /// </summary>
- /// <param name="location">资源的定位地址</param>
- /// <param name="type">子对象类型</param>
- public AllAssetsOperationHandle LoadAllAssetsAsync(string location, System.Type type)
- {
- DebugCheckInitialize();
- AssetInfo assetInfo = ConvertLocationToAssetInfo(location, type);
- return LoadAllAssetsInternal(assetInfo, false);
- }
- private AllAssetsOperationHandle LoadAllAssetsInternal(AssetInfo assetInfo, bool waitForAsyncComplete)
- {
- #if UNITY_EDITOR
- if (assetInfo.IsInvalid == false)
- {
- BundleInfo bundleInfo = _bundleServices.GetBundleInfo(assetInfo);
- if (bundleInfo.Bundle.IsRawFile)
- throw new Exception($"Cannot load raw file using {nameof(LoadAllAssetsAsync)} method !");
- }
- #endif
- var handle = _assetSystemImpl.LoadAllAssetsAsync(assetInfo);
- if (waitForAsyncComplete)
- handle.WaitForAsyncComplete();
- return handle;
- }
- #endregion
- #region 资源下载
- /// <summary>
- /// 创建资源下载器,用于下载当前资源版本所有的资源包文件
- /// </summary>
- /// <param name="downloadingMaxNumber">同时下载的最大文件数</param>
- /// <param name="failedTryAgain">下载失败的重试次数</param>
- /// <param name="timeout">超时时间</param>
- public ResourceDownloaderOperation CreateResourceDownloader(int downloadingMaxNumber, int failedTryAgain, int timeout = 60)
- {
- DebugCheckInitialize();
- return _playModeServices.CreateResourceDownloaderByAll(downloadingMaxNumber, failedTryAgain, timeout);
- }
- /// <summary>
- /// 创建资源下载器,用于下载指定的资源标签关联的资源包文件
- /// </summary>
- /// <param name="tag">资源标签</param>
- /// <param name="downloadingMaxNumber">同时下载的最大文件数</param>
- /// <param name="failedTryAgain">下载失败的重试次数</param>
- /// <param name="timeout">超时时间</param>
- public ResourceDownloaderOperation CreateResourceDownloader(string tag, int downloadingMaxNumber, int failedTryAgain, int timeout = 60)
- {
- DebugCheckInitialize();
- return _playModeServices.CreateResourceDownloaderByTags(new string[] { tag }, downloadingMaxNumber, failedTryAgain, timeout);
- }
- /// <summary>
- /// 创建资源下载器,用于下载指定的资源标签列表关联的资源包文件
- /// </summary>
- /// <param name="tags">资源标签列表</param>
- /// <param name="downloadingMaxNumber">同时下载的最大文件数</param>
- /// <param name="failedTryAgain">下载失败的重试次数</param>
- /// <param name="timeout">超时时间</param>
- public ResourceDownloaderOperation CreateResourceDownloader(string[] tags, int downloadingMaxNumber, int failedTryAgain, int timeout = 60)
- {
- DebugCheckInitialize();
- return _playModeServices.CreateResourceDownloaderByTags(tags, downloadingMaxNumber, failedTryAgain, timeout);
- }
- /// <summary>
- /// 创建资源下载器,用于下载指定的资源依赖的资源包文件
- /// </summary>
- /// <param name="location">资源的定位地址</param>
- /// <param name="downloadingMaxNumber">同时下载的最大文件数</param>
- /// <param name="failedTryAgain">下载失败的重试次数</param>
- /// <param name="timeout">超时时间</param>
- public ResourceDownloaderOperation CreateBundleDownloader(string location, int downloadingMaxNumber, int failedTryAgain, int timeout = 60)
- {
- DebugCheckInitialize();
- var assetInfo = ConvertLocationToAssetInfo(location, null);
- AssetInfo[] assetInfos = new AssetInfo[] { assetInfo };
- return _playModeServices.CreateResourceDownloaderByPaths(assetInfos, downloadingMaxNumber, failedTryAgain, timeout);
- }
- /// <summary>
- /// 创建资源下载器,用于下载指定的资源列表依赖的资源包文件
- /// </summary>
- /// <param name="locations">资源的定位地址列表</param>
- /// <param name="downloadingMaxNumber">同时下载的最大文件数</param>
- /// <param name="failedTryAgain">下载失败的重试次数</param>
- /// <param name="timeout">超时时间</param>
- public ResourceDownloaderOperation CreateBundleDownloader(string[] locations, int downloadingMaxNumber, int failedTryAgain, int timeout = 60)
- {
- DebugCheckInitialize();
- List<AssetInfo> assetInfos = new List<AssetInfo>(locations.Length);
- foreach (var location in locations)
- {
- var assetInfo = ConvertLocationToAssetInfo(location, null);
- assetInfos.Add(assetInfo);
- }
- return _playModeServices.CreateResourceDownloaderByPaths(assetInfos.ToArray(), downloadingMaxNumber, failedTryAgain, timeout);
- }
- /// <summary>
- /// 创建资源下载器,用于下载指定的资源依赖的资源包文件
- /// </summary>
- /// <param name="assetInfo">资源信息</param>
- /// <param name="downloadingMaxNumber">同时下载的最大文件数</param>
- /// <param name="failedTryAgain">下载失败的重试次数</param>
- /// <param name="timeout">超时时间</param>
- public ResourceDownloaderOperation CreateBundleDownloader(AssetInfo assetInfo, int downloadingMaxNumber, int failedTryAgain, int timeout = 60)
- {
- DebugCheckInitialize();
- AssetInfo[] assetInfos = new AssetInfo[] { assetInfo };
- return _playModeServices.CreateResourceDownloaderByPaths(assetInfos, downloadingMaxNumber, failedTryAgain, timeout);
- }
- /// <summary>
- /// 创建资源下载器,用于下载指定的资源列表依赖的资源包文件
- /// </summary>
- /// <param name="assetInfos">资源信息列表</param>
- /// <param name="downloadingMaxNumber">同时下载的最大文件数</param>
- /// <param name="failedTryAgain">下载失败的重试次数</param>
- /// <param name="timeout">超时时间</param>
- public ResourceDownloaderOperation CreateBundleDownloader(AssetInfo[] assetInfos, int downloadingMaxNumber, int failedTryAgain, int timeout = 60)
- {
- DebugCheckInitialize();
- return _playModeServices.CreateResourceDownloaderByPaths(assetInfos, downloadingMaxNumber, failedTryAgain, timeout);
- }
- #endregion
- #region 资源解压
- /// <summary>
- /// 创建内置资源解压器
- /// </summary>
- /// <param name="tag">资源标签</param>
- /// <param name="unpackingMaxNumber">同时解压的最大文件数</param>
- /// <param name="failedTryAgain">解压失败的重试次数</param>
- public ResourceUnpackerOperation CreateResourceUnpacker(string tag, int unpackingMaxNumber, int failedTryAgain)
- {
- DebugCheckInitialize();
- return _playModeServices.CreateResourceUnpackerByTags(new string[] { tag }, unpackingMaxNumber, failedTryAgain, int.MaxValue);
- }
- /// <summary>
- /// 创建内置资源解压器
- /// </summary>
- /// <param name="tags">资源标签列表</param>
- /// <param name="unpackingMaxNumber">同时解压的最大文件数</param>
- /// <param name="failedTryAgain">解压失败的重试次数</param>
- public ResourceUnpackerOperation CreateResourceUnpacker(string[] tags, int unpackingMaxNumber, int failedTryAgain)
- {
- DebugCheckInitialize();
- return _playModeServices.CreateResourceUnpackerByTags(tags, unpackingMaxNumber, failedTryAgain, int.MaxValue);
- }
- /// <summary>
- /// 创建内置资源解压器
- /// </summary>
- /// <param name="unpackingMaxNumber">同时解压的最大文件数</param>
- /// <param name="failedTryAgain">解压失败的重试次数</param>
- public ResourceUnpackerOperation CreateResourceUnpacker(int unpackingMaxNumber, int failedTryAgain)
- {
- DebugCheckInitialize();
- return _playModeServices.CreateResourceUnpackerByAll(unpackingMaxNumber, failedTryAgain, int.MaxValue);
- }
- #endregion
- #region 内部方法
- /// <summary>
- /// 是否包含资源文件
- /// </summary>
- internal bool IsIncludeBundleFile(string cacheGUID)
- {
- // NOTE : 编辑器模拟模式下始终返回TRUE
- if (_playMode == EPlayMode.EditorSimulateMode)
- return true;
- return _playModeServices.ActiveManifest.IsIncludeBundleFile(cacheGUID);
- }
- private AssetInfo ConvertLocationToAssetInfo(string location, System.Type assetType)
- {
- return _playModeServices.ActiveManifest.ConvertLocationToAssetInfo(location, assetType);
- }
- private AssetInfo ConvertAssetGUIDToAssetInfo(string assetGUID, System.Type assetType)
- {
- return _playModeServices.ActiveManifest.ConvertAssetGUIDToAssetInfo(assetGUID, assetType);
- }
- #endregion
- #region 调试方法
- [Conditional("DEBUG")]
- private void DebugCheckInitialize()
- {
- if (_initializeStatus == EOperationStatus.None)
- throw new Exception("Package initialize not completed !");
- else if (_initializeStatus == EOperationStatus.Failed)
- throw new Exception($"Package initialize failed ! {_initializeError}");
- }
- [Conditional("DEBUG")]
- private void DebugCheckUpdateManifest()
- {
- var loadedBundleInfos = _assetSystemImpl.GetLoadedBundleInfos();
- if (loadedBundleInfos.Count > 0)
- {
- YooLogger.Warning($"Found loaded bundle before update manifest ! Recommended to call the {nameof(ForceUnloadAllAssets)} method to release loaded bundle !");
- }
- }
- #endregion
- #region 调试信息
- internal DebugPackageData GetDebugPackageData()
- {
- DebugPackageData data = new DebugPackageData();
- data.PackageName = PackageName;
- data.ProviderInfos = _assetSystemImpl.GetDebugReportInfos();
- return data;
- }
- #endregion
- }
- }
|