Update YooAsset
parent
1c7b90806c
commit
a00924bb54
|
@ -20,7 +20,7 @@ namespace YooAsset
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public static int AssetLoadingMaxNumber { private set; get; }
|
public static int AssetLoadingMaxNumber { private set; get; }
|
||||||
|
|
||||||
public static IDecryptServices DecryptServices { private set; get; }
|
public static IDecryptionServices DecryptionServices { private set; get; }
|
||||||
public static IBundleServices BundleServices { private set; get; }
|
public static IBundleServices BundleServices { private set; get; }
|
||||||
|
|
||||||
|
|
||||||
|
@ -28,11 +28,11 @@ namespace YooAsset
|
||||||
/// 初始化资源系统
|
/// 初始化资源系统
|
||||||
/// 注意:在使用AssetSystem之前需要初始化
|
/// 注意:在使用AssetSystem之前需要初始化
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public static void Initialize(bool simulationOnEditor, int assetLoadingMaxNumber, IDecryptServices decryptServices, IBundleServices bundleServices)
|
public static void Initialize(bool simulationOnEditor, int assetLoadingMaxNumber, IDecryptionServices decryptionServices, IBundleServices bundleServices)
|
||||||
{
|
{
|
||||||
SimulationOnEditor = simulationOnEditor;
|
SimulationOnEditor = simulationOnEditor;
|
||||||
AssetLoadingMaxNumber = assetLoadingMaxNumber;
|
AssetLoadingMaxNumber = assetLoadingMaxNumber;
|
||||||
DecryptServices = decryptServices;
|
DecryptionServices = decryptionServices;
|
||||||
BundleServices = bundleServices;
|
BundleServices = bundleServices;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -307,7 +307,7 @@ namespace YooAsset
|
||||||
DebugSummy.DebugProviderInfo providerInfo = new DebugSummy.DebugProviderInfo();
|
DebugSummy.DebugProviderInfo providerInfo = new DebugSummy.DebugProviderInfo();
|
||||||
providerInfo.AssetPath = provider.AssetPath;
|
providerInfo.AssetPath = provider.AssetPath;
|
||||||
providerInfo.RefCount = provider.RefCount;
|
providerInfo.RefCount = provider.RefCount;
|
||||||
providerInfo.States = (int)provider.States;
|
providerInfo.Status = (int)provider.Status;
|
||||||
providerInfo.BundleInfos.Clear();
|
providerInfo.BundleInfos.Clear();
|
||||||
summy.ProviderInfos.Add(providerInfo);
|
summy.ProviderInfos.Add(providerInfo);
|
||||||
|
|
||||||
|
|
|
@ -1,19 +0,0 @@
|
||||||
|
|
||||||
namespace YooAsset
|
|
||||||
{
|
|
||||||
/// <summary>
|
|
||||||
/// 解密方法
|
|
||||||
/// </summary>
|
|
||||||
public enum EDecryptMethod
|
|
||||||
{
|
|
||||||
/// <summary>
|
|
||||||
/// 获取解密的数据偏移
|
|
||||||
/// </summary>
|
|
||||||
GetDecryptOffset,
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// 获取解密的字节数据
|
|
||||||
/// </summary>
|
|
||||||
GetDecryptBinary,
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,11 +0,0 @@
|
||||||
fileFormatVersion: 2
|
|
||||||
guid: 6a446add12cd4554a9bd178a7ef2db55
|
|
||||||
MonoImporter:
|
|
||||||
externalObjects: {}
|
|
||||||
serializedVersion: 2
|
|
||||||
defaultReferences: []
|
|
||||||
executionOrder: 0
|
|
||||||
icon: {instanceID: 0}
|
|
||||||
userData:
|
|
||||||
assetBundleName:
|
|
||||||
assetBundleVariant:
|
|
|
@ -1,18 +0,0 @@
|
||||||
|
|
||||||
namespace YooAsset
|
|
||||||
{
|
|
||||||
public interface IDecryptServices
|
|
||||||
{
|
|
||||||
EDecryptMethod DecryptType { get; }
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// 获取解密的数据偏移
|
|
||||||
/// </summary>
|
|
||||||
ulong GetDecryptOffset(BundleInfo bundleInfo);
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// 获取解密的字节数据
|
|
||||||
/// </summary>
|
|
||||||
byte[] GetDecryptBinary(BundleInfo bundleInfo);
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -0,0 +1,11 @@
|
||||||
|
|
||||||
|
namespace YooAsset
|
||||||
|
{
|
||||||
|
public interface IDecryptionServices
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// 获取加密文件的数据偏移量
|
||||||
|
/// </summary>
|
||||||
|
ulong GetFileOffset(BundleInfo bundleInfo);
|
||||||
|
}
|
||||||
|
}
|
|
@ -7,6 +7,17 @@ namespace YooAsset
|
||||||
{
|
{
|
||||||
internal class BundleFileLoader
|
internal class BundleFileLoader
|
||||||
{
|
{
|
||||||
|
public enum EStatus
|
||||||
|
{
|
||||||
|
None = 0,
|
||||||
|
Download,
|
||||||
|
CheckDownload,
|
||||||
|
LoadFile,
|
||||||
|
CheckFile,
|
||||||
|
Success,
|
||||||
|
Fail,
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 资源包文件信息
|
/// 资源包文件信息
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
@ -20,7 +31,7 @@ namespace YooAsset
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 加载状态
|
/// 加载状态
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public ELoaderStates States { private set; get; }
|
public EStatus Status { private set; get; }
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 是否已经销毁
|
/// 是否已经销毁
|
||||||
|
@ -33,13 +44,13 @@ namespace YooAsset
|
||||||
private FileDownloader _fileDownloader;
|
private FileDownloader _fileDownloader;
|
||||||
private AssetBundleCreateRequest _cacheRequest;
|
private AssetBundleCreateRequest _cacheRequest;
|
||||||
internal AssetBundle CacheBundle { private set; get; }
|
internal AssetBundle CacheBundle { private set; get; }
|
||||||
|
|
||||||
|
|
||||||
public BundleFileLoader(BundleInfo bundleInfo)
|
public BundleFileLoader(BundleInfo bundleInfo)
|
||||||
{
|
{
|
||||||
BundleFileInfo = bundleInfo;
|
BundleFileInfo = bundleInfo;
|
||||||
RefCount = 0;
|
RefCount = 0;
|
||||||
States = ELoaderStates.None;
|
Status = EStatus.None;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -89,31 +100,31 @@ namespace YooAsset
|
||||||
if (IsDone())
|
if (IsDone())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (States == ELoaderStates.None)
|
if (Status == EStatus.None)
|
||||||
{
|
{
|
||||||
// 检测加载地址是否为空
|
// 检测加载地址是否为空
|
||||||
if (string.IsNullOrEmpty(BundleFileInfo.LocalPath))
|
if (string.IsNullOrEmpty(BundleFileInfo.LocalPath))
|
||||||
{
|
{
|
||||||
States = ELoaderStates.Fail;
|
Status = EStatus.Fail;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (string.IsNullOrEmpty(BundleFileInfo.RemoteMainURL))
|
if (string.IsNullOrEmpty(BundleFileInfo.RemoteMainURL))
|
||||||
States = ELoaderStates.LoadFile;
|
Status = EStatus.LoadFile;
|
||||||
else
|
else
|
||||||
States = ELoaderStates.Download;
|
Status = EStatus.Download;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 1. 从服务器下载
|
// 1. 从服务器下载
|
||||||
if (States == ELoaderStates.Download)
|
if (Status == EStatus.Download)
|
||||||
{
|
{
|
||||||
int failedTryAgain = int.MaxValue;
|
int failedTryAgain = int.MaxValue;
|
||||||
_fileDownloader = DownloadSystem.BeginDownload(BundleFileInfo, failedTryAgain);
|
_fileDownloader = DownloadSystem.BeginDownload(BundleFileInfo, failedTryAgain);
|
||||||
States = ELoaderStates.CheckDownload;
|
Status = EStatus.CheckDownload;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 2. 检测服务器下载结果
|
// 2. 检测服务器下载结果
|
||||||
if (States == ELoaderStates.CheckDownload)
|
if (Status == EStatus.CheckDownload)
|
||||||
{
|
{
|
||||||
if (_fileDownloader.IsDone() == false)
|
if (_fileDownloader.IsDone() == false)
|
||||||
return;
|
return;
|
||||||
|
@ -121,23 +132,23 @@ namespace YooAsset
|
||||||
if (_fileDownloader.HasError())
|
if (_fileDownloader.HasError())
|
||||||
{
|
{
|
||||||
_fileDownloader.ReportError();
|
_fileDownloader.ReportError();
|
||||||
States = ELoaderStates.Fail;
|
Status = EStatus.Fail;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
States = ELoaderStates.LoadFile;
|
Status = EStatus.LoadFile;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// 3. 加载AssetBundle
|
// 3. 加载AssetBundle
|
||||||
if (States == ELoaderStates.LoadFile)
|
if (Status == EStatus.LoadFile)
|
||||||
{
|
{
|
||||||
#if UNITY_EDITOR
|
#if UNITY_EDITOR
|
||||||
// 注意:Unity2017.4编辑器模式下,如果AssetBundle文件不存在会导致编辑器崩溃,这里做了预判。
|
// 注意:Unity2017.4编辑器模式下,如果AssetBundle文件不存在会导致编辑器崩溃,这里做了预判。
|
||||||
if (System.IO.File.Exists(BundleFileInfo.LocalPath) == false)
|
if (System.IO.File.Exists(BundleFileInfo.LocalPath) == false)
|
||||||
{
|
{
|
||||||
YooLogger.Warning($"Not found assetBundle file : {BundleFileInfo.LocalPath}");
|
YooLogger.Warning($"Not found assetBundle file : {BundleFileInfo.LocalPath}");
|
||||||
States = ELoaderStates.Fail;
|
Status = EStatus.Fail;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -145,30 +156,14 @@ namespace YooAsset
|
||||||
// Load assetBundle file
|
// Load assetBundle file
|
||||||
if (BundleFileInfo.IsEncrypted)
|
if (BundleFileInfo.IsEncrypted)
|
||||||
{
|
{
|
||||||
if (AssetSystem.DecryptServices == null)
|
if (AssetSystem.DecryptionServices == null)
|
||||||
throw new Exception($"{nameof(BundleFileLoader)} need IDecryptServices : {BundleFileInfo.BundleName}");
|
throw new Exception($"{nameof(BundleFileLoader)} need IDecryptServices : {BundleFileInfo.BundleName}");
|
||||||
|
|
||||||
EDecryptMethod decryptType = AssetSystem.DecryptServices.DecryptType;
|
ulong offset = AssetSystem.DecryptionServices.GetFileOffset(BundleFileInfo);
|
||||||
if (decryptType == EDecryptMethod.GetDecryptOffset)
|
if (_isWaitForAsyncComplete)
|
||||||
{
|
CacheBundle = AssetBundle.LoadFromFile(BundleFileInfo.LocalPath, 0, offset);
|
||||||
ulong offset = AssetSystem.DecryptServices.GetDecryptOffset(BundleFileInfo);
|
|
||||||
if (_isWaitForAsyncComplete)
|
|
||||||
CacheBundle = AssetBundle.LoadFromFile(BundleFileInfo.LocalPath, 0, offset);
|
|
||||||
else
|
|
||||||
_cacheRequest = AssetBundle.LoadFromFileAsync(BundleFileInfo.LocalPath, 0, offset);
|
|
||||||
}
|
|
||||||
else if (decryptType == EDecryptMethod.GetDecryptBinary)
|
|
||||||
{
|
|
||||||
byte[] binary = AssetSystem.DecryptServices.GetDecryptBinary(BundleFileInfo);
|
|
||||||
if (_isWaitForAsyncComplete)
|
|
||||||
CacheBundle = AssetBundle.LoadFromMemory(binary);
|
|
||||||
else
|
|
||||||
_cacheRequest = AssetBundle.LoadFromMemoryAsync(binary);
|
|
||||||
}
|
|
||||||
else
|
else
|
||||||
{
|
_cacheRequest = AssetBundle.LoadFromFileAsync(BundleFileInfo.LocalPath, 0, offset);
|
||||||
throw new NotImplementedException($"{decryptType}");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -177,11 +172,11 @@ namespace YooAsset
|
||||||
else
|
else
|
||||||
_cacheRequest = AssetBundle.LoadFromFileAsync(BundleFileInfo.LocalPath);
|
_cacheRequest = AssetBundle.LoadFromFileAsync(BundleFileInfo.LocalPath);
|
||||||
}
|
}
|
||||||
States = ELoaderStates.CheckFile;
|
Status = EStatus.CheckFile;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 4. 检测AssetBundle加载结果
|
// 4. 检测AssetBundle加载结果
|
||||||
if (States == ELoaderStates.CheckFile)
|
if (Status == EStatus.CheckFile)
|
||||||
{
|
{
|
||||||
if (_cacheRequest != null)
|
if (_cacheRequest != null)
|
||||||
{
|
{
|
||||||
|
@ -203,11 +198,11 @@ namespace YooAsset
|
||||||
if (CacheBundle == null)
|
if (CacheBundle == null)
|
||||||
{
|
{
|
||||||
YooLogger.Error($"Failed to load assetBundle file : {BundleFileInfo.BundleName}");
|
YooLogger.Error($"Failed to load assetBundle file : {BundleFileInfo.BundleName}");
|
||||||
States = ELoaderStates.Fail;
|
Status = EStatus.Fail;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
States = ELoaderStates.Success;
|
Status = EStatus.Success;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -240,7 +235,7 @@ namespace YooAsset
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public bool IsDone()
|
public bool IsDone()
|
||||||
{
|
{
|
||||||
return States == ELoaderStates.Success || States == ELoaderStates.Fail;
|
return Status == EStatus.Success || Status == EStatus.Fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -302,7 +297,7 @@ namespace YooAsset
|
||||||
if (_isShowWaitForAsyncError == false)
|
if (_isShowWaitForAsyncError == false)
|
||||||
{
|
{
|
||||||
_isShowWaitForAsyncError = true;
|
_isShowWaitForAsyncError = true;
|
||||||
YooLogger.Error($"WaitForAsyncComplete failed ! BundleName : {BundleFileInfo.BundleName} States : {States}");
|
YooLogger.Error($"WaitForAsyncComplete failed ! BundleName : {BundleFileInfo.BundleName} States : {Status}");
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -74,7 +74,7 @@ namespace YooAsset
|
||||||
debugInfo.BundleName = loader.BundleFileInfo.BundleName;
|
debugInfo.BundleName = loader.BundleFileInfo.BundleName;
|
||||||
debugInfo.Version = loader.BundleFileInfo.Version;
|
debugInfo.Version = loader.BundleFileInfo.Version;
|
||||||
debugInfo.RefCount = loader.RefCount;
|
debugInfo.RefCount = loader.RefCount;
|
||||||
debugInfo.States = (int)loader.States;
|
debugInfo.Status = (int)loader.Status;
|
||||||
output.Add(debugInfo);
|
output.Add(debugInfo);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,17 +0,0 @@
|
||||||
|
|
||||||
namespace YooAsset
|
|
||||||
{
|
|
||||||
/// <summary>
|
|
||||||
/// 文件加载器状态
|
|
||||||
/// </summary>
|
|
||||||
public enum ELoaderStates
|
|
||||||
{
|
|
||||||
None = 0,
|
|
||||||
Download,
|
|
||||||
CheckDownload,
|
|
||||||
LoadFile,
|
|
||||||
CheckFile,
|
|
||||||
Success,
|
|
||||||
Fail,
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,11 +0,0 @@
|
||||||
fileFormatVersion: 2
|
|
||||||
guid: 90f00fe388279034aaee9c89c07e2ef1
|
|
||||||
MonoImporter:
|
|
||||||
externalObjects: {}
|
|
||||||
serializedVersion: 2
|
|
||||||
defaultReferences: []
|
|
||||||
executionOrder: 0
|
|
||||||
icon: {instanceID: 0}
|
|
||||||
userData:
|
|
||||||
assetBundleName:
|
|
||||||
assetBundleVariant:
|
|
|
@ -0,0 +1,8 @@
|
||||||
|
fileFormatVersion: 2
|
||||||
|
guid: fcfac83df022948478c32bf11b8e0987
|
||||||
|
folderAsset: yes
|
||||||
|
DefaultImporter:
|
||||||
|
externalObjects: {}
|
||||||
|
userData:
|
||||||
|
assetBundleName:
|
||||||
|
assetBundleVariant:
|
|
@ -24,15 +24,20 @@ namespace YooAsset
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 当前的加载状态
|
/// 当前状态
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public EAssetStates States
|
public EOperationStatus Status
|
||||||
{
|
{
|
||||||
get
|
get
|
||||||
{
|
{
|
||||||
if (IsValid == false)
|
if (IsValid == false)
|
||||||
return EAssetStates.None;
|
return EOperationStatus.None;
|
||||||
return _provider.States;
|
if (_provider.Status == AssetProviderBase.EStatus.Fail)
|
||||||
|
return EOperationStatus.Failed;
|
||||||
|
else if (_provider.Status == AssetProviderBase.EStatus.Success)
|
||||||
|
return EOperationStatus.Succeed;
|
||||||
|
else
|
||||||
|
return EOperationStatus.None;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,6 +3,16 @@ namespace YooAsset
|
||||||
{
|
{
|
||||||
internal abstract class AssetProviderBase : IAssetProvider
|
internal abstract class AssetProviderBase : IAssetProvider
|
||||||
{
|
{
|
||||||
|
public enum EStatus
|
||||||
|
{
|
||||||
|
None = 0,
|
||||||
|
CheckBundle,
|
||||||
|
Loading,
|
||||||
|
Checking,
|
||||||
|
Success,
|
||||||
|
Fail,
|
||||||
|
}
|
||||||
|
|
||||||
protected bool IsWaitForAsyncComplete { private set; get; } = false;
|
protected bool IsWaitForAsyncComplete { private set; get; } = false;
|
||||||
|
|
||||||
public string AssetPath { private set; get; }
|
public string AssetPath { private set; get; }
|
||||||
|
@ -11,7 +21,7 @@ namespace YooAsset
|
||||||
public UnityEngine.Object AssetObject { protected set; get; }
|
public UnityEngine.Object AssetObject { protected set; get; }
|
||||||
public UnityEngine.Object[] AllAssets { protected set; get; }
|
public UnityEngine.Object[] AllAssets { protected set; get; }
|
||||||
public IAssetInstance AssetInstance { protected set; get; }
|
public IAssetInstance AssetInstance { protected set; get; }
|
||||||
public EAssetStates States { protected set; get; }
|
public EStatus Status { protected set; get; }
|
||||||
public int RefCount { private set; get; }
|
public int RefCount { private set; get; }
|
||||||
public AssetOperationHandle Handle { private set; get; }
|
public AssetOperationHandle Handle { private set; get; }
|
||||||
public System.Action<AssetOperationHandle> Callback { set; get; }
|
public System.Action<AssetOperationHandle> Callback { set; get; }
|
||||||
|
@ -20,7 +30,7 @@ namespace YooAsset
|
||||||
{
|
{
|
||||||
get
|
get
|
||||||
{
|
{
|
||||||
return States == EAssetStates.Success || States == EAssetStates.Fail;
|
return Status == EStatus.Success || Status == EStatus.Fail;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
public bool IsValid
|
public bool IsValid
|
||||||
|
@ -44,7 +54,7 @@ namespace YooAsset
|
||||||
AssetPath = assetPath;
|
AssetPath = assetPath;
|
||||||
AssetName = System.IO.Path.GetFileName(assetPath);
|
AssetName = System.IO.Path.GetFileName(assetPath);
|
||||||
AssetType = assetType;
|
AssetType = assetType;
|
||||||
States = EAssetStates.None;
|
Status = EStatus.None;
|
||||||
Handle = new AssetOperationHandle(this);
|
Handle = new AssetOperationHandle(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -26,13 +26,13 @@ namespace YooAsset
|
||||||
if (IsDone)
|
if (IsDone)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (States == EAssetStates.None)
|
if (Status == EStatus.None)
|
||||||
{
|
{
|
||||||
States = EAssetStates.CheckBundle;
|
Status = EStatus.CheckBundle;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 1. 检测资源包
|
// 1. 检测资源包
|
||||||
if (States == EAssetStates.CheckBundle)
|
if (Status == EStatus.CheckBundle)
|
||||||
{
|
{
|
||||||
if (IsWaitForAsyncComplete)
|
if (IsWaitForAsyncComplete)
|
||||||
{
|
{
|
||||||
|
@ -47,17 +47,17 @@ namespace YooAsset
|
||||||
|
|
||||||
if (OwnerBundle.CacheBundle == null)
|
if (OwnerBundle.CacheBundle == null)
|
||||||
{
|
{
|
||||||
States = EAssetStates.Fail;
|
Status = EStatus.Fail;
|
||||||
InvokeCompletion();
|
InvokeCompletion();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
States = EAssetStates.Loading;
|
Status = EStatus.Loading;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// 2. 加载资源对象
|
// 2. 加载资源对象
|
||||||
if (States == EAssetStates.Loading)
|
if (Status == EStatus.Loading)
|
||||||
{
|
{
|
||||||
if (IsWaitForAsyncComplete)
|
if (IsWaitForAsyncComplete)
|
||||||
{
|
{
|
||||||
|
@ -73,11 +73,11 @@ namespace YooAsset
|
||||||
else
|
else
|
||||||
_cacheRequest = OwnerBundle.CacheBundle.LoadAssetAsync(AssetName, AssetType);
|
_cacheRequest = OwnerBundle.CacheBundle.LoadAssetAsync(AssetName, AssetType);
|
||||||
}
|
}
|
||||||
States = EAssetStates.Checking;
|
Status = EStatus.Checking;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 3. 检测加载结果
|
// 3. 检测加载结果
|
||||||
if (States == EAssetStates.Checking)
|
if (Status == EStatus.Checking)
|
||||||
{
|
{
|
||||||
if (_cacheRequest != null)
|
if (_cacheRequest != null)
|
||||||
{
|
{
|
||||||
|
@ -95,8 +95,8 @@ namespace YooAsset
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
States = AssetObject == null ? EAssetStates.Fail : EAssetStates.Success;
|
Status = AssetObject == null ? EStatus.Fail : EStatus.Success;
|
||||||
if (States == EAssetStates.Fail)
|
if (Status == EStatus.Fail)
|
||||||
YooLogger.Warning($"Failed to load asset : {AssetName} from bundle : {OwnerBundle.BundleFileInfo.BundleName}");
|
YooLogger.Warning($"Failed to load asset : {AssetName} from bundle : {OwnerBundle.BundleFileInfo.BundleName}");
|
||||||
InvokeCompletion();
|
InvokeCompletion();
|
||||||
}
|
}
|
||||||
|
|
|
@ -42,7 +42,7 @@ namespace YooAsset
|
||||||
ownerInfo.BundleName = OwnerBundle.BundleFileInfo.BundleName;
|
ownerInfo.BundleName = OwnerBundle.BundleFileInfo.BundleName;
|
||||||
ownerInfo.Version = OwnerBundle.BundleFileInfo.Version;
|
ownerInfo.Version = OwnerBundle.BundleFileInfo.Version;
|
||||||
ownerInfo.RefCount = OwnerBundle.RefCount;
|
ownerInfo.RefCount = OwnerBundle.RefCount;
|
||||||
ownerInfo.States = (int)OwnerBundle.States;
|
ownerInfo.Status = (int)OwnerBundle.Status;
|
||||||
output.Add(ownerInfo);
|
output.Add(ownerInfo);
|
||||||
|
|
||||||
DependBundles.GetBundleDebugInfos(output);
|
DependBundles.GetBundleDebugInfos(output);
|
||||||
|
|
|
@ -29,13 +29,13 @@ namespace YooAsset
|
||||||
if (IsDone)
|
if (IsDone)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (States == EAssetStates.None)
|
if (Status == EStatus.None)
|
||||||
{
|
{
|
||||||
States = EAssetStates.CheckBundle;
|
Status = EStatus.CheckBundle;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 1. 检测资源包
|
// 1. 检测资源包
|
||||||
if (States == EAssetStates.CheckBundle)
|
if (Status == EStatus.CheckBundle)
|
||||||
{
|
{
|
||||||
if (DependBundles.IsDone() == false)
|
if (DependBundles.IsDone() == false)
|
||||||
return;
|
return;
|
||||||
|
@ -44,34 +44,34 @@ namespace YooAsset
|
||||||
|
|
||||||
if (OwnerBundle.CacheBundle == null)
|
if (OwnerBundle.CacheBundle == null)
|
||||||
{
|
{
|
||||||
States = EAssetStates.Fail;
|
Status = EStatus.Fail;
|
||||||
InvokeCompletion();
|
InvokeCompletion();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
States = EAssetStates.Loading;
|
Status = EStatus.Loading;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// 2. 加载场景
|
// 2. 加载场景
|
||||||
if (States == EAssetStates.Loading)
|
if (Status == EStatus.Loading)
|
||||||
{
|
{
|
||||||
_asyncOp = SceneManager.LoadSceneAsync(AssetName, _param.LoadMode);
|
_asyncOp = SceneManager.LoadSceneAsync(AssetName, _param.LoadMode);
|
||||||
if (_asyncOp != null)
|
if (_asyncOp != null)
|
||||||
{
|
{
|
||||||
_asyncOp.allowSceneActivation = true;
|
_asyncOp.allowSceneActivation = true;
|
||||||
States = EAssetStates.Checking;
|
Status = EStatus.Checking;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
YooLogger.Warning($"Failed to load scene : {AssetName}");
|
YooLogger.Warning($"Failed to load scene : {AssetName}");
|
||||||
States = EAssetStates.Fail;
|
Status = EStatus.Fail;
|
||||||
InvokeCompletion();
|
InvokeCompletion();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// 3. 检测加载结果
|
// 3. 检测加载结果
|
||||||
if (States == EAssetStates.Checking)
|
if (Status == EStatus.Checking)
|
||||||
{
|
{
|
||||||
if (_asyncOp.isDone)
|
if (_asyncOp.isDone)
|
||||||
{
|
{
|
||||||
|
@ -81,7 +81,7 @@ namespace YooAsset
|
||||||
if (_param.ActivateOnLoad)
|
if (_param.ActivateOnLoad)
|
||||||
instance.Activate();
|
instance.Activate();
|
||||||
|
|
||||||
States = instance.Scene.IsValid() ? EAssetStates.Success : EAssetStates.Fail;
|
Status = instance.Scene.IsValid() ? EStatus.Success : EStatus.Fail;
|
||||||
InvokeCompletion();
|
InvokeCompletion();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,13 +26,13 @@ namespace YooAsset
|
||||||
if (IsDone)
|
if (IsDone)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (States == EAssetStates.None)
|
if (Status == EStatus.None)
|
||||||
{
|
{
|
||||||
States = EAssetStates.CheckBundle;
|
Status = EStatus.CheckBundle;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 1. 检测资源包
|
// 1. 检测资源包
|
||||||
if (States == EAssetStates.CheckBundle)
|
if (Status == EStatus.CheckBundle)
|
||||||
{
|
{
|
||||||
if (IsWaitForAsyncComplete)
|
if (IsWaitForAsyncComplete)
|
||||||
{
|
{
|
||||||
|
@ -47,17 +47,17 @@ namespace YooAsset
|
||||||
|
|
||||||
if (OwnerBundle.CacheBundle == null)
|
if (OwnerBundle.CacheBundle == null)
|
||||||
{
|
{
|
||||||
States = EAssetStates.Fail;
|
Status = EStatus.Fail;
|
||||||
InvokeCompletion();
|
InvokeCompletion();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
States = EAssetStates.Loading;
|
Status = EStatus.Loading;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// 2. 加载资源对象
|
// 2. 加载资源对象
|
||||||
if (States == EAssetStates.Loading)
|
if (Status == EStatus.Loading)
|
||||||
{
|
{
|
||||||
if (IsWaitForAsyncComplete)
|
if (IsWaitForAsyncComplete)
|
||||||
{
|
{
|
||||||
|
@ -73,11 +73,11 @@ namespace YooAsset
|
||||||
else
|
else
|
||||||
_cacheRequest = OwnerBundle.CacheBundle.LoadAssetWithSubAssetsAsync(AssetName, AssetType);
|
_cacheRequest = OwnerBundle.CacheBundle.LoadAssetWithSubAssetsAsync(AssetName, AssetType);
|
||||||
}
|
}
|
||||||
States = EAssetStates.Checking;
|
Status = EStatus.Checking;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 3. 检测加载结果
|
// 3. 检测加载结果
|
||||||
if (States == EAssetStates.Checking)
|
if (Status == EStatus.Checking)
|
||||||
{
|
{
|
||||||
if (_cacheRequest != null)
|
if (_cacheRequest != null)
|
||||||
{
|
{
|
||||||
|
@ -95,8 +95,8 @@ namespace YooAsset
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
States = AllAssets == null ? EAssetStates.Fail : EAssetStates.Success;
|
Status = AllAssets == null ? EStatus.Fail : EStatus.Success;
|
||||||
if (States == EAssetStates.Fail)
|
if (Status == EStatus.Fail)
|
||||||
YooLogger.Warning($"Failed to load sub assets : {AssetName} from bundle : {OwnerBundle.BundleFileInfo.BundleName}");
|
YooLogger.Warning($"Failed to load sub assets : {AssetName} from bundle : {OwnerBundle.BundleFileInfo.BundleName}");
|
||||||
InvokeCompletion();
|
InvokeCompletion();
|
||||||
}
|
}
|
||||||
|
|
|
@ -27,19 +27,19 @@ namespace YooAsset
|
||||||
if (IsDone)
|
if (IsDone)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (States == EAssetStates.None)
|
if (Status == EStatus.None)
|
||||||
{
|
{
|
||||||
// 检测资源文件是否存在
|
// 检测资源文件是否存在
|
||||||
string guid = UnityEditor.AssetDatabase.AssetPathToGUID(AssetPath);
|
string guid = UnityEditor.AssetDatabase.AssetPathToGUID(AssetPath);
|
||||||
if (string.IsNullOrEmpty(guid))
|
if (string.IsNullOrEmpty(guid))
|
||||||
{
|
{
|
||||||
States = EAssetStates.Fail;
|
Status = EStatus.Fail;
|
||||||
InvokeCompletion();
|
InvokeCompletion();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
States = EAssetStates.Loading;
|
Status = EStatus.Loading;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 注意:模拟异步加载效果提前返回
|
// 注意:模拟异步加载效果提前返回
|
||||||
|
@ -48,17 +48,17 @@ namespace YooAsset
|
||||||
}
|
}
|
||||||
|
|
||||||
// 1. 加载资源对象
|
// 1. 加载资源对象
|
||||||
if (States == EAssetStates.Loading)
|
if (Status == EStatus.Loading)
|
||||||
{
|
{
|
||||||
AssetObject = UnityEditor.AssetDatabase.LoadAssetAtPath(AssetPath, AssetType);
|
AssetObject = UnityEditor.AssetDatabase.LoadAssetAtPath(AssetPath, AssetType);
|
||||||
States = EAssetStates.Checking;
|
Status = EStatus.Checking;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 2. 检测加载结果
|
// 2. 检测加载结果
|
||||||
if (States == EAssetStates.Checking)
|
if (Status == EStatus.Checking)
|
||||||
{
|
{
|
||||||
States = AssetObject == null ? EAssetStates.Fail : EAssetStates.Success;
|
Status = AssetObject == null ? EStatus.Fail : EStatus.Success;
|
||||||
if (States == EAssetStates.Fail)
|
if (Status == EStatus.Fail)
|
||||||
YooLogger.Warning($"Failed to load asset object : {AssetPath}");
|
YooLogger.Warning($"Failed to load asset object : {AssetPath}");
|
||||||
InvokeCompletion();
|
InvokeCompletion();
|
||||||
}
|
}
|
||||||
|
|
|
@ -28,13 +28,13 @@ namespace YooAsset
|
||||||
if (IsDone)
|
if (IsDone)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (States == EAssetStates.None)
|
if (Status == EStatus.None)
|
||||||
{
|
{
|
||||||
States = EAssetStates.Loading;
|
Status = EStatus.Loading;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 1. 加载资源对象
|
// 1. 加载资源对象
|
||||||
if (States == EAssetStates.Loading)
|
if (Status == EStatus.Loading)
|
||||||
{
|
{
|
||||||
LoadSceneParameters loadSceneParameters = new LoadSceneParameters();
|
LoadSceneParameters loadSceneParameters = new LoadSceneParameters();
|
||||||
loadSceneParameters.loadSceneMode = _param.LoadMode;
|
loadSceneParameters.loadSceneMode = _param.LoadMode;
|
||||||
|
@ -42,18 +42,18 @@ namespace YooAsset
|
||||||
if (_asyncOp != null)
|
if (_asyncOp != null)
|
||||||
{
|
{
|
||||||
_asyncOp.allowSceneActivation = true;
|
_asyncOp.allowSceneActivation = true;
|
||||||
States = EAssetStates.Checking;
|
Status = EStatus.Checking;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
YooLogger.Warning($"Failed to load scene : {AssetName}");
|
YooLogger.Warning($"Failed to load scene : {AssetName}");
|
||||||
States = EAssetStates.Fail;
|
Status = EStatus.Fail;
|
||||||
InvokeCompletion();
|
InvokeCompletion();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// 2. 检测加载结果
|
// 2. 检测加载结果
|
||||||
if (States == EAssetStates.Checking)
|
if (Status == EStatus.Checking)
|
||||||
{
|
{
|
||||||
if (_asyncOp.isDone)
|
if (_asyncOp.isDone)
|
||||||
{
|
{
|
||||||
|
@ -63,7 +63,7 @@ namespace YooAsset
|
||||||
if(_param.ActivateOnLoad)
|
if(_param.ActivateOnLoad)
|
||||||
instance.Activate();
|
instance.Activate();
|
||||||
|
|
||||||
States = instance.Scene.IsValid() ? EAssetStates.Success : EAssetStates.Fail;
|
Status = instance.Scene.IsValid() ? EStatus.Success : EStatus.Fail;
|
||||||
InvokeCompletion();
|
InvokeCompletion();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -27,19 +27,19 @@ namespace YooAsset
|
||||||
if (IsDone)
|
if (IsDone)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (States == EAssetStates.None)
|
if (Status == EStatus.None)
|
||||||
{
|
{
|
||||||
// 检测资源文件是否存在
|
// 检测资源文件是否存在
|
||||||
string guid = UnityEditor.AssetDatabase.AssetPathToGUID(AssetPath);
|
string guid = UnityEditor.AssetDatabase.AssetPathToGUID(AssetPath);
|
||||||
if (string.IsNullOrEmpty(guid))
|
if (string.IsNullOrEmpty(guid))
|
||||||
{
|
{
|
||||||
States = EAssetStates.Fail;
|
Status = EStatus.Fail;
|
||||||
InvokeCompletion();
|
InvokeCompletion();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
States = EAssetStates.Loading;
|
Status = EStatus.Loading;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 注意:模拟异步加载效果提前返回
|
// 注意:模拟异步加载效果提前返回
|
||||||
|
@ -48,7 +48,7 @@ namespace YooAsset
|
||||||
}
|
}
|
||||||
|
|
||||||
// 1. 加载资源对象
|
// 1. 加载资源对象
|
||||||
if (States == EAssetStates.Loading)
|
if (Status == EStatus.Loading)
|
||||||
{
|
{
|
||||||
var findAssets = UnityEditor.AssetDatabase.LoadAllAssetsAtPath(AssetPath);
|
var findAssets = UnityEditor.AssetDatabase.LoadAllAssetsAtPath(AssetPath);
|
||||||
List<UnityEngine.Object> result = new List<Object>(findAssets.Length);
|
List<UnityEngine.Object> result = new List<Object>(findAssets.Length);
|
||||||
|
@ -58,14 +58,14 @@ namespace YooAsset
|
||||||
result.Add(findObj);
|
result.Add(findObj);
|
||||||
}
|
}
|
||||||
AllAssets = result.ToArray();
|
AllAssets = result.ToArray();
|
||||||
States = EAssetStates.Checking;
|
Status = EStatus.Checking;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 2. 检测加载结果
|
// 2. 检测加载结果
|
||||||
if (States == EAssetStates.Checking)
|
if (Status == EStatus.Checking)
|
||||||
{
|
{
|
||||||
States = AllAssets == null ? EAssetStates.Fail : EAssetStates.Success;
|
Status = AllAssets == null ? EStatus.Fail : EStatus.Success;
|
||||||
if (States == EAssetStates.Fail)
|
if (Status == EStatus.Fail)
|
||||||
YooLogger.Warning($"Failed to load all asset object : {AssetPath}");
|
YooLogger.Warning($"Failed to load all asset object : {AssetPath}");
|
||||||
InvokeCompletion();
|
InvokeCompletion();
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,16 +0,0 @@
|
||||||
|
|
||||||
namespace YooAsset
|
|
||||||
{
|
|
||||||
/// <summary>
|
|
||||||
/// 资源加载状态
|
|
||||||
/// </summary>
|
|
||||||
public enum EAssetStates
|
|
||||||
{
|
|
||||||
None = 0,
|
|
||||||
CheckBundle,
|
|
||||||
Loading,
|
|
||||||
Checking,
|
|
||||||
Success,
|
|
||||||
Fail,
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,11 +0,0 @@
|
||||||
fileFormatVersion: 2
|
|
||||||
guid: aa6c0fe63326c604bb699be16747c1e2
|
|
||||||
MonoImporter:
|
|
||||||
externalObjects: {}
|
|
||||||
serializedVersion: 2
|
|
||||||
defaultReferences: []
|
|
||||||
executionOrder: 0
|
|
||||||
icon: {instanceID: 0}
|
|
||||||
userData:
|
|
||||||
assetBundleName:
|
|
||||||
assetBundleVariant:
|
|
|
@ -39,7 +39,7 @@ namespace YooAsset
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 当前的加载状态
|
/// 当前的加载状态
|
||||||
/// </summary>
|
/// </summary>
|
||||||
EAssetStates States { get; }
|
AssetProviderBase.EStatus Status { get; }
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 引用计数
|
/// 引用计数
|
||||||
|
|
|
@ -6,6 +6,9 @@ namespace YooAsset
|
||||||
{
|
{
|
||||||
public abstract class AsyncOperationBase : IEnumerator
|
public abstract class AsyncOperationBase : IEnumerator
|
||||||
{
|
{
|
||||||
|
// 用户请求的回调
|
||||||
|
private Action<AsyncOperationBase> _callback;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 状态
|
/// 状态
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
@ -27,11 +30,6 @@ namespace YooAsset
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// 用户请求的回调
|
|
||||||
/// </summary>
|
|
||||||
private Action<AsyncOperationBase> _callback;
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 完成事件
|
/// 完成事件
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|
|
@ -86,7 +86,7 @@ namespace YooAsset
|
||||||
{
|
{
|
||||||
if (_cachedHashList.ContainsKey(hash))
|
if (_cachedHashList.ContainsKey(hash))
|
||||||
{
|
{
|
||||||
string filePath = PatchHelper.MakeSandboxCacheFilePath(hash);
|
string filePath = SandboxHelper.MakeSandboxCacheFilePath(hash);
|
||||||
if (File.Exists(filePath))
|
if (File.Exists(filePath))
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
|
@ -124,7 +124,7 @@ namespace YooAsset
|
||||||
}
|
}
|
||||||
public static bool CheckContentIntegrity(PatchBundle patchBundle)
|
public static bool CheckContentIntegrity(PatchBundle patchBundle)
|
||||||
{
|
{
|
||||||
string filePath = PatchHelper.MakeSandboxCacheFilePath(patchBundle.Hash);
|
string filePath = SandboxHelper.MakeSandboxCacheFilePath(patchBundle.Hash);
|
||||||
return CheckContentIntegrity(filePath, patchBundle.SizeBytes, patchBundle.CRC);
|
return CheckContentIntegrity(filePath, patchBundle.SizeBytes, patchBundle.CRC);
|
||||||
}
|
}
|
||||||
public static bool CheckContentIntegrity(string filePath, long size, string crc)
|
public static bool CheckContentIntegrity(string filePath, long size, string crc)
|
||||||
|
|
|
@ -59,8 +59,8 @@ namespace YooAsset
|
||||||
|
|
||||||
if (_steps == ESteps.LoadAppManifest)
|
if (_steps == ESteps.LoadAppManifest)
|
||||||
{
|
{
|
||||||
string filePath = AssetPathHelper.MakeStreamingLoadPath(ResourceSettingData.Setting.PatchManifestFileName);
|
string filePath = PathHelper.MakeStreamingLoadPath(ResourceSettingData.Setting.PatchManifestFileName);
|
||||||
_downloadURL = AssetPathHelper.ConvertToWWWPath(filePath);
|
_downloadURL = PathHelper.ConvertToWWWPath(filePath);
|
||||||
_downloader = new UnityWebRequester();
|
_downloader = new UnityWebRequester();
|
||||||
_downloader.SendRequest(_downloadURL);
|
_downloader.SendRequest(_downloadURL);
|
||||||
_steps = ESteps.CheckAppManifest;
|
_steps = ESteps.CheckAppManifest;
|
||||||
|
@ -134,11 +134,11 @@ namespace YooAsset
|
||||||
if (_impl.ClearCacheWhenDirty)
|
if (_impl.ClearCacheWhenDirty)
|
||||||
{
|
{
|
||||||
YooLogger.Warning("Clear cache files.");
|
YooLogger.Warning("Clear cache files.");
|
||||||
PatchHelper.DeleteSandboxCacheFolder();
|
SandboxHelper.DeleteSandboxCacheFolder();
|
||||||
}
|
}
|
||||||
|
|
||||||
// 删除清单文件
|
// 删除清单文件
|
||||||
PatchHelper.DeleteSandboxPatchManifestFile();
|
SandboxHelper.DeleteSandboxPatchManifestFile();
|
||||||
// 更新缓存文件
|
// 更新缓存文件
|
||||||
PatchCache.UpdateCache();
|
PatchCache.UpdateCache();
|
||||||
}
|
}
|
||||||
|
@ -149,8 +149,8 @@ namespace YooAsset
|
||||||
{
|
{
|
||||||
// 加载APP内的补丁清单
|
// 加载APP内的补丁清单
|
||||||
YooLogger.Log($"Load application patch manifest.");
|
YooLogger.Log($"Load application patch manifest.");
|
||||||
string filePath = AssetPathHelper.MakeStreamingLoadPath(ResourceSettingData.Setting.PatchManifestFileName);
|
string filePath = PathHelper.MakeStreamingLoadPath(ResourceSettingData.Setting.PatchManifestFileName);
|
||||||
_downloadURL = AssetPathHelper.ConvertToWWWPath(filePath);
|
_downloadURL = PathHelper.ConvertToWWWPath(filePath);
|
||||||
_downloader = new UnityWebRequester();
|
_downloader = new UnityWebRequester();
|
||||||
_downloader.SendRequest(_downloadURL);
|
_downloader.SendRequest(_downloadURL);
|
||||||
_steps = ESteps.CheckAppManifest;
|
_steps = ESteps.CheckAppManifest;
|
||||||
|
@ -181,10 +181,10 @@ namespace YooAsset
|
||||||
if (_steps == ESteps.LoadSandboxManifest)
|
if (_steps == ESteps.LoadSandboxManifest)
|
||||||
{
|
{
|
||||||
// 加载沙盒内的补丁清单
|
// 加载沙盒内的补丁清单
|
||||||
if (PatchHelper.CheckSandboxPatchManifestFileExist())
|
if (SandboxHelper.CheckSandboxPatchManifestFileExist())
|
||||||
{
|
{
|
||||||
YooLogger.Log($"Load sandbox patch manifest.");
|
YooLogger.Log($"Load sandbox patch manifest.");
|
||||||
string filePath = AssetPathHelper.MakePersistentLoadPath(ResourceSettingData.Setting.PatchManifestFileName);
|
string filePath = PathHelper.MakePersistentLoadPath(ResourceSettingData.Setting.PatchManifestFileName);
|
||||||
string jsonData = File.ReadAllText(filePath);
|
string jsonData = File.ReadAllText(filePath);
|
||||||
_impl.LocalPatchManifest = PatchManifest.Deserialize(jsonData);
|
_impl.LocalPatchManifest = PatchManifest.Deserialize(jsonData);
|
||||||
}
|
}
|
||||||
|
|
|
@ -122,7 +122,7 @@ namespace YooAsset
|
||||||
_downloaderHash.Dispose();
|
_downloaderHash.Dispose();
|
||||||
|
|
||||||
// 如果补丁清单文件的哈希值相同
|
// 如果补丁清单文件的哈希值相同
|
||||||
string currentFileHash = PatchHelper.GetSandboxPatchManifestFileHash();
|
string currentFileHash = SandboxHelper.GetSandboxPatchManifestFileHash();
|
||||||
if (currentFileHash == webManifestHash)
|
if (currentFileHash == webManifestHash)
|
||||||
{
|
{
|
||||||
YooLogger.Log($"Patch manifest file hash is not change : {webManifestHash}");
|
YooLogger.Log($"Patch manifest file hash is not change : {webManifestHash}");
|
||||||
|
@ -206,7 +206,7 @@ namespace YooAsset
|
||||||
|
|
||||||
// 注意:这里会覆盖掉沙盒内的补丁清单文件
|
// 注意:这里会覆盖掉沙盒内的补丁清单文件
|
||||||
YooLogger.Log("Save remote patch manifest file.");
|
YooLogger.Log("Save remote patch manifest file.");
|
||||||
string savePath = AssetPathHelper.MakePersistentLoadPath(ResourceSettingData.Setting.PatchManifestFileName);
|
string savePath = PathHelper.MakePersistentLoadPath(ResourceSettingData.Setting.PatchManifestFileName);
|
||||||
PatchManifest.Serialize(savePath, _impl.LocalPatchManifest);
|
PatchManifest.Serialize(savePath, _impl.LocalPatchManifest);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -246,7 +246,7 @@ namespace YooAsset
|
||||||
}
|
}
|
||||||
|
|
||||||
// 查看文件是否存在
|
// 查看文件是否存在
|
||||||
string filePath = PatchHelper.MakeSandboxCacheFilePath(patchBundle.Hash);
|
string filePath = SandboxHelper.MakeSandboxCacheFilePath(patchBundle.Hash);
|
||||||
if (File.Exists(filePath) == false)
|
if (File.Exists(filePath) == false)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
@ -285,7 +285,7 @@ namespace YooAsset
|
||||||
}
|
}
|
||||||
private bool RunThread(PatchBundle patchBundle)
|
private bool RunThread(PatchBundle patchBundle)
|
||||||
{
|
{
|
||||||
string filePath = PatchHelper.MakeSandboxCacheFilePath(patchBundle.Hash);
|
string filePath = SandboxHelper.MakeSandboxCacheFilePath(patchBundle.Hash);
|
||||||
ThreadInfo info = new ThreadInfo(filePath, patchBundle);
|
ThreadInfo info = new ThreadInfo(filePath, patchBundle);
|
||||||
return ThreadPool.QueueUserWorkItem(new WaitCallback(VerifyFile), info);
|
return ThreadPool.QueueUserWorkItem(new WaitCallback(VerifyFile), info);
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,10 +19,10 @@ namespace YooAsset
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public static PatchCache LoadCache()
|
public static PatchCache LoadCache()
|
||||||
{
|
{
|
||||||
if (PatchHelper.CheckSandboxCacheFileExist())
|
if (SandboxHelper.CheckSandboxCacheFileExist())
|
||||||
{
|
{
|
||||||
YooLogger.Log("Load patch cache from disk.");
|
YooLogger.Log("Load patch cache from disk.");
|
||||||
string filePath = PatchHelper.GetSandboxCacheFilePath();
|
string filePath = SandboxHelper.GetSandboxCacheFilePath();
|
||||||
string jsonData = FileUtility.ReadFile(filePath);
|
string jsonData = FileUtility.ReadFile(filePath);
|
||||||
return JsonUtility.FromJson<PatchCache>(jsonData);
|
return JsonUtility.FromJson<PatchCache>(jsonData);
|
||||||
}
|
}
|
||||||
|
@ -31,7 +31,7 @@ namespace YooAsset
|
||||||
YooLogger.Log($"Create patch cache to disk : {Application.version}");
|
YooLogger.Log($"Create patch cache to disk : {Application.version}");
|
||||||
PatchCache cache = new PatchCache();
|
PatchCache cache = new PatchCache();
|
||||||
cache.CacheAppVersion = Application.version;
|
cache.CacheAppVersion = Application.version;
|
||||||
string filePath = PatchHelper.GetSandboxCacheFilePath();
|
string filePath = SandboxHelper.GetSandboxCacheFilePath();
|
||||||
string jsonData = JsonUtility.ToJson(cache);
|
string jsonData = JsonUtility.ToJson(cache);
|
||||||
FileUtility.CreateFile(filePath, jsonData);
|
FileUtility.CreateFile(filePath, jsonData);
|
||||||
return cache;
|
return cache;
|
||||||
|
@ -46,7 +46,7 @@ namespace YooAsset
|
||||||
YooLogger.Log($"Update patch cache to disk : {Application.version}");
|
YooLogger.Log($"Update patch cache to disk : {Application.version}");
|
||||||
PatchCache cache = new PatchCache();
|
PatchCache cache = new PatchCache();
|
||||||
cache.CacheAppVersion = Application.version;
|
cache.CacheAppVersion = Application.version;
|
||||||
string filePath = PatchHelper.GetSandboxCacheFilePath();
|
string filePath = SandboxHelper.GetSandboxCacheFilePath();
|
||||||
string jsonData = JsonUtility.ToJson(cache);
|
string jsonData = JsonUtility.ToJson(cache);
|
||||||
FileUtility.CreateFile(filePath, jsonData);
|
FileUtility.CreateFile(filePath, jsonData);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,100 +0,0 @@
|
||||||
using System.IO;
|
|
||||||
using System.Text;
|
|
||||||
|
|
||||||
namespace YooAsset
|
|
||||||
{
|
|
||||||
internal static class PatchHelper
|
|
||||||
{
|
|
||||||
private const string StrCacheFileName = "Cache.bytes";
|
|
||||||
private const string StrCacheFolderName = "CacheFiles";
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// 清空沙盒目录
|
|
||||||
/// </summary>
|
|
||||||
public static void ClearSandbox()
|
|
||||||
{
|
|
||||||
string directoryPath = AssetPathHelper.MakePersistentLoadPath(string.Empty);
|
|
||||||
if (Directory.Exists(directoryPath))
|
|
||||||
Directory.Delete(directoryPath, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// 删除沙盒内补丁清单文件
|
|
||||||
/// </summary>
|
|
||||||
public static void DeleteSandboxPatchManifestFile()
|
|
||||||
{
|
|
||||||
string filePath = AssetPathHelper.MakePersistentLoadPath(ResourceSettingData.Setting.PatchManifestFileName);
|
|
||||||
if (File.Exists(filePath))
|
|
||||||
File.Delete(filePath);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// 删除沙盒内的缓存文件
|
|
||||||
/// </summary>
|
|
||||||
public static void DeleteSandboxCacheFile()
|
|
||||||
{
|
|
||||||
string filePath = GetSandboxCacheFilePath();
|
|
||||||
if (File.Exists(filePath))
|
|
||||||
File.Delete(filePath);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// 删除沙盒内的缓存文件夹
|
|
||||||
/// </summary>
|
|
||||||
public static void DeleteSandboxCacheFolder()
|
|
||||||
{
|
|
||||||
string directoryPath = AssetPathHelper.MakePersistentLoadPath(StrCacheFolderName);
|
|
||||||
if (Directory.Exists(directoryPath))
|
|
||||||
Directory.Delete(directoryPath, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// 获取沙盒内缓存文件的路径
|
|
||||||
/// </summary>
|
|
||||||
public static string GetSandboxCacheFilePath()
|
|
||||||
{
|
|
||||||
return AssetPathHelper.MakePersistentLoadPath(StrCacheFileName);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// 检测沙盒内缓存文件是否存在
|
|
||||||
/// </summary>
|
|
||||||
public static bool CheckSandboxCacheFileExist()
|
|
||||||
{
|
|
||||||
string filePath = GetSandboxCacheFilePath();
|
|
||||||
return File.Exists(filePath);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// 检测沙盒内补丁清单文件是否存在
|
|
||||||
/// </summary>
|
|
||||||
public static bool CheckSandboxPatchManifestFileExist()
|
|
||||||
{
|
|
||||||
string filePath = AssetPathHelper.MakePersistentLoadPath(ResourceSettingData.Setting.PatchManifestFileName);
|
|
||||||
return File.Exists(filePath);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// 获取沙盒内补丁清单文件的哈希值
|
|
||||||
/// 注意:如果沙盒内补丁清单文件不存在,返回空字符串
|
|
||||||
/// </summary>
|
|
||||||
/// <returns></returns>
|
|
||||||
public static string GetSandboxPatchManifestFileHash()
|
|
||||||
{
|
|
||||||
string filePath = AssetPathHelper.MakePersistentLoadPath(ResourceSettingData.Setting.PatchManifestFileName);
|
|
||||||
if (File.Exists(filePath))
|
|
||||||
return HashUtility.FileMD5(filePath);
|
|
||||||
else
|
|
||||||
return string.Empty;
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// 获取缓存文件的存储路径
|
|
||||||
/// </summary>
|
|
||||||
public static string MakeSandboxCacheFilePath(string fileName)
|
|
||||||
{
|
|
||||||
return AssetPathHelper.MakePersistentLoadPath($"{StrCacheFolderName}/{fileName}");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,11 +0,0 @@
|
||||||
fileFormatVersion: 2
|
|
||||||
guid: 887179b2bb92ca04988d1091b3b8f8e2
|
|
||||||
MonoImporter:
|
|
||||||
externalObjects: {}
|
|
||||||
serializedVersion: 2
|
|
||||||
defaultReferences: []
|
|
||||||
executionOrder: 0
|
|
||||||
icon: {instanceID: 0}
|
|
||||||
userData:
|
|
||||||
assetBundleName:
|
|
||||||
assetBundleVariant:
|
|
|
@ -170,7 +170,7 @@ namespace YooAsset
|
||||||
foreach (var patchBundle in AppPatchManifest.BundleList)
|
foreach (var patchBundle in AppPatchManifest.BundleList)
|
||||||
{
|
{
|
||||||
// 如果已经在沙盒内
|
// 如果已经在沙盒内
|
||||||
string filePath = PatchHelper.MakeSandboxCacheFilePath(patchBundle.Hash);
|
string filePath = SandboxHelper.MakeSandboxCacheFilePath(patchBundle.Hash);
|
||||||
if (System.IO.File.Exists(filePath))
|
if (System.IO.File.Exists(filePath))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
@ -216,7 +216,7 @@ namespace YooAsset
|
||||||
private BundleInfo ConvertToDownloadInfo(PatchBundle patchBundle)
|
private BundleInfo ConvertToDownloadInfo(PatchBundle patchBundle)
|
||||||
{
|
{
|
||||||
// 注意:资源版本号只用于确定下载路径
|
// 注意:资源版本号只用于确定下载路径
|
||||||
string sandboxPath = PatchHelper.MakeSandboxCacheFilePath(patchBundle.Hash);
|
string sandboxPath = SandboxHelper.MakeSandboxCacheFilePath(patchBundle.Hash);
|
||||||
string remoteMainURL = GetPatchDownloadMainURL(patchBundle.Version, patchBundle.Hash);
|
string remoteMainURL = GetPatchDownloadMainURL(patchBundle.Version, patchBundle.Hash);
|
||||||
string remoteFallbackURL = GetPatchDownloadFallbackURL(patchBundle.Version, patchBundle.Hash);
|
string remoteFallbackURL = GetPatchDownloadFallbackURL(patchBundle.Version, patchBundle.Hash);
|
||||||
BundleInfo bundleInfo = new BundleInfo(patchBundle, sandboxPath, remoteMainURL, remoteFallbackURL);
|
BundleInfo bundleInfo = new BundleInfo(patchBundle, sandboxPath, remoteMainURL, remoteFallbackURL);
|
||||||
|
@ -236,8 +236,8 @@ namespace YooAsset
|
||||||
// 解压相关
|
// 解压相关
|
||||||
private BundleInfo ConvertToUnpackInfo(PatchBundle patchBundle)
|
private BundleInfo ConvertToUnpackInfo(PatchBundle patchBundle)
|
||||||
{
|
{
|
||||||
string sandboxPath = PatchHelper.MakeSandboxCacheFilePath(patchBundle.Hash);
|
string sandboxPath = SandboxHelper.MakeSandboxCacheFilePath(patchBundle.Hash);
|
||||||
string streamingLoadPath = AssetPathHelper.MakeStreamingLoadPath(patchBundle.Hash);
|
string streamingLoadPath = PathHelper.MakeStreamingLoadPath(patchBundle.Hash);
|
||||||
BundleInfo bundleInfo = new BundleInfo(patchBundle, sandboxPath, streamingLoadPath, streamingLoadPath);
|
BundleInfo bundleInfo = new BundleInfo(patchBundle, sandboxPath, streamingLoadPath, streamingLoadPath);
|
||||||
return bundleInfo;
|
return bundleInfo;
|
||||||
}
|
}
|
||||||
|
@ -265,7 +265,7 @@ namespace YooAsset
|
||||||
{
|
{
|
||||||
if (appPatchBundle.IsBuildin && appPatchBundle.Hash == patchBundle.Hash)
|
if (appPatchBundle.IsBuildin && appPatchBundle.Hash == patchBundle.Hash)
|
||||||
{
|
{
|
||||||
string appLoadPath = AssetPathHelper.MakeStreamingLoadPath(appPatchBundle.Hash);
|
string appLoadPath = PathHelper.MakeStreamingLoadPath(appPatchBundle.Hash);
|
||||||
BundleInfo bundleInfo = new BundleInfo(appPatchBundle, appLoadPath);
|
BundleInfo bundleInfo = new BundleInfo(appPatchBundle, appLoadPath);
|
||||||
return bundleInfo;
|
return bundleInfo;
|
||||||
}
|
}
|
||||||
|
@ -274,7 +274,7 @@ namespace YooAsset
|
||||||
// 查询沙盒资源
|
// 查询沙盒资源
|
||||||
if (DownloadSystem.ContainsVerifyFile(patchBundle.Hash))
|
if (DownloadSystem.ContainsVerifyFile(patchBundle.Hash))
|
||||||
{
|
{
|
||||||
string sandboxLoadPath = PatchHelper.MakeSandboxCacheFilePath(patchBundle.Hash);
|
string sandboxLoadPath = SandboxHelper.MakeSandboxCacheFilePath(patchBundle.Hash);
|
||||||
BundleInfo bundleInfo = new BundleInfo(patchBundle, sandboxLoadPath);
|
BundleInfo bundleInfo = new BundleInfo(patchBundle, sandboxLoadPath);
|
||||||
return bundleInfo;
|
return bundleInfo;
|
||||||
}
|
}
|
||||||
|
|
|
@ -36,7 +36,7 @@ namespace YooAsset
|
||||||
|
|
||||||
if (AppPatchManifest.Bundles.TryGetValue(bundleName, out PatchBundle patchBundle))
|
if (AppPatchManifest.Bundles.TryGetValue(bundleName, out PatchBundle patchBundle))
|
||||||
{
|
{
|
||||||
string localPath = AssetPathHelper.MakeStreamingLoadPath(patchBundle.Hash);
|
string localPath = PathHelper.MakeStreamingLoadPath(patchBundle.Hash);
|
||||||
BundleInfo bundleInfo = new BundleInfo(patchBundle, localPath);
|
BundleInfo bundleInfo = new BundleInfo(patchBundle, localPath);
|
||||||
return bundleInfo;
|
return bundleInfo;
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,7 +29,7 @@ namespace YooAsset
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 加载状态
|
/// 加载状态
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public int States { set; get; }
|
public int Status { set; get; }
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -50,7 +50,7 @@ namespace YooAsset
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 加载状态
|
/// 加载状态
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public int States { set; get; }
|
public int Status { set; get; }
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 依赖的资源包列表
|
/// 依赖的资源包列表
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
namespace YooAsset
|
namespace YooAsset
|
||||||
{
|
{
|
||||||
[CreateAssetMenu(fileName = "YooAssetSettings", menuName = "YooAsset/Create Settings")]
|
[CreateAssetMenu(fileName = "YooAssetSettings", menuName = "YooAsset/Create Settings")]
|
||||||
public class YooAssetSettings : ScriptableObject
|
internal class YooAssetSettings : ScriptableObject
|
||||||
{
|
{
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// AssetBundle文件的后缀名
|
/// AssetBundle文件的后缀名
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
|
|
||||||
namespace YooAsset
|
namespace YooAsset
|
||||||
{
|
{
|
||||||
public static class ResourceSettingData
|
internal static class ResourceSettingData
|
||||||
{
|
{
|
||||||
private static YooAssetSettings _setting = null;
|
private static YooAssetSettings _setting = null;
|
||||||
public static YooAssetSettings Setting
|
public static YooAssetSettings Setting
|
||||||
|
|
|
@ -2,7 +2,10 @@
|
||||||
|
|
||||||
namespace YooAsset
|
namespace YooAsset
|
||||||
{
|
{
|
||||||
internal static class AssetPathHelper
|
/// <summary>
|
||||||
|
/// 资源路径帮助类
|
||||||
|
/// </summary>
|
||||||
|
internal static class PathHelper
|
||||||
{
|
{
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 获取规范化的路径
|
/// 获取规范化的路径
|
||||||
|
@ -72,7 +75,7 @@ namespace YooAsset
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 合并资源路径
|
/// 合并资源路径
|
||||||
/// </summary>
|
/// </summary>
|
||||||
internal static string CombineAssetPath(string root, string location)
|
public static string CombineAssetPath(string root, string location)
|
||||||
{
|
{
|
||||||
if (string.IsNullOrEmpty(root))
|
if (string.IsNullOrEmpty(root))
|
||||||
return location;
|
return location;
|
||||||
|
@ -83,7 +86,7 @@ namespace YooAsset
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 获取AssetDatabase的加载路径
|
/// 获取AssetDatabase的加载路径
|
||||||
/// </summary>
|
/// </summary>
|
||||||
internal static string FindDatabaseAssetPath(string filePath)
|
public static string FindDatabaseAssetPath(string filePath)
|
||||||
{
|
{
|
||||||
#if UNITY_EDITOR
|
#if UNITY_EDITOR
|
||||||
if (File.Exists(filePath))
|
if (File.Exists(filePath))
|
||||||
|
@ -119,4 +122,102 @@ namespace YooAsset
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 沙盒帮助类
|
||||||
|
/// </summary>
|
||||||
|
internal static class SandboxHelper
|
||||||
|
{
|
||||||
|
private const string StrCacheFileName = "Cache.bytes";
|
||||||
|
private const string StrCacheFolderName = "CacheFiles";
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 清空沙盒目录
|
||||||
|
/// </summary>
|
||||||
|
public static void ClearSandbox()
|
||||||
|
{
|
||||||
|
string directoryPath = PathHelper.MakePersistentLoadPath(string.Empty);
|
||||||
|
if (Directory.Exists(directoryPath))
|
||||||
|
Directory.Delete(directoryPath, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 删除沙盒内补丁清单文件
|
||||||
|
/// </summary>
|
||||||
|
public static void DeleteSandboxPatchManifestFile()
|
||||||
|
{
|
||||||
|
string filePath = PathHelper.MakePersistentLoadPath(ResourceSettingData.Setting.PatchManifestFileName);
|
||||||
|
if (File.Exists(filePath))
|
||||||
|
File.Delete(filePath);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 删除沙盒内的缓存文件
|
||||||
|
/// </summary>
|
||||||
|
public static void DeleteSandboxCacheFile()
|
||||||
|
{
|
||||||
|
string filePath = GetSandboxCacheFilePath();
|
||||||
|
if (File.Exists(filePath))
|
||||||
|
File.Delete(filePath);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 删除沙盒内的缓存文件夹
|
||||||
|
/// </summary>
|
||||||
|
public static void DeleteSandboxCacheFolder()
|
||||||
|
{
|
||||||
|
string directoryPath = PathHelper.MakePersistentLoadPath(StrCacheFolderName);
|
||||||
|
if (Directory.Exists(directoryPath))
|
||||||
|
Directory.Delete(directoryPath, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 获取沙盒内缓存文件的路径
|
||||||
|
/// </summary>
|
||||||
|
public static string GetSandboxCacheFilePath()
|
||||||
|
{
|
||||||
|
return PathHelper.MakePersistentLoadPath(StrCacheFileName);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 检测沙盒内缓存文件是否存在
|
||||||
|
/// </summary>
|
||||||
|
public static bool CheckSandboxCacheFileExist()
|
||||||
|
{
|
||||||
|
string filePath = GetSandboxCacheFilePath();
|
||||||
|
return File.Exists(filePath);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 检测沙盒内补丁清单文件是否存在
|
||||||
|
/// </summary>
|
||||||
|
public static bool CheckSandboxPatchManifestFileExist()
|
||||||
|
{
|
||||||
|
string filePath = PathHelper.MakePersistentLoadPath(ResourceSettingData.Setting.PatchManifestFileName);
|
||||||
|
return File.Exists(filePath);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 获取沙盒内补丁清单文件的哈希值
|
||||||
|
/// 注意:如果沙盒内补丁清单文件不存在,返回空字符串
|
||||||
|
/// </summary>
|
||||||
|
/// <returns></returns>
|
||||||
|
public static string GetSandboxPatchManifestFileHash()
|
||||||
|
{
|
||||||
|
string filePath = PathHelper.MakePersistentLoadPath(ResourceSettingData.Setting.PatchManifestFileName);
|
||||||
|
if (File.Exists(filePath))
|
||||||
|
return HashUtility.FileMD5(filePath);
|
||||||
|
else
|
||||||
|
return string.Empty;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 获取缓存文件的存储路径
|
||||||
|
/// </summary>
|
||||||
|
public static string MakeSandboxCacheFilePath(string fileName)
|
||||||
|
{
|
||||||
|
return PathHelper.MakePersistentLoadPath($"{StrCacheFolderName}/{fileName}");
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
|
@ -38,7 +38,7 @@ namespace YooAsset
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 文件解密接口
|
/// 文件解密接口
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public IDecryptServices DecryptServices = null;
|
public IDecryptionServices DecryptionServices = null;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 资源系统自动释放零引用资源的间隔秒数
|
/// 资源系统自动释放零引用资源的间隔秒数
|
||||||
|
@ -145,7 +145,7 @@ namespace YooAsset
|
||||||
}
|
}
|
||||||
|
|
||||||
if (string.IsNullOrEmpty(parameters.LocationRoot) == false)
|
if (string.IsNullOrEmpty(parameters.LocationRoot) == false)
|
||||||
_locationRoot = AssetPathHelper.GetRegularPath(parameters.LocationRoot);
|
_locationRoot = PathHelper.GetRegularPath(parameters.LocationRoot);
|
||||||
|
|
||||||
// 运行模式
|
// 运行模式
|
||||||
if (parameters is EditorPlayModeParameters)
|
if (parameters is EditorPlayModeParameters)
|
||||||
|
@ -162,21 +162,21 @@ namespace YooAsset
|
||||||
{
|
{
|
||||||
_editorPlayModeImpl = new EditorPlayModeImpl();
|
_editorPlayModeImpl = new EditorPlayModeImpl();
|
||||||
_bundleServices = _editorPlayModeImpl;
|
_bundleServices = _editorPlayModeImpl;
|
||||||
AssetSystem.Initialize(true, parameters.AssetLoadingMaxNumber, parameters.DecryptServices, _bundleServices);
|
AssetSystem.Initialize(true, parameters.AssetLoadingMaxNumber, parameters.DecryptionServices, _bundleServices);
|
||||||
return _editorPlayModeImpl.InitializeAsync();
|
return _editorPlayModeImpl.InitializeAsync();
|
||||||
}
|
}
|
||||||
else if (_playMode == EPlayMode.OfflinePlayMode)
|
else if (_playMode == EPlayMode.OfflinePlayMode)
|
||||||
{
|
{
|
||||||
_offlinePlayModeImpl = new OfflinePlayModeImpl();
|
_offlinePlayModeImpl = new OfflinePlayModeImpl();
|
||||||
_bundleServices = _offlinePlayModeImpl;
|
_bundleServices = _offlinePlayModeImpl;
|
||||||
AssetSystem.Initialize(false, parameters.AssetLoadingMaxNumber, parameters.DecryptServices, _bundleServices);
|
AssetSystem.Initialize(false, parameters.AssetLoadingMaxNumber, parameters.DecryptionServices, _bundleServices);
|
||||||
return _offlinePlayModeImpl.InitializeAsync();
|
return _offlinePlayModeImpl.InitializeAsync();
|
||||||
}
|
}
|
||||||
else if (_playMode == EPlayMode.HostPlayMode)
|
else if (_playMode == EPlayMode.HostPlayMode)
|
||||||
{
|
{
|
||||||
_hostPlayModeImpl = new HostPlayModeImpl();
|
_hostPlayModeImpl = new HostPlayModeImpl();
|
||||||
_bundleServices = _hostPlayModeImpl;
|
_bundleServices = _hostPlayModeImpl;
|
||||||
AssetSystem.Initialize(false, parameters.AssetLoadingMaxNumber, parameters.DecryptServices, _bundleServices);
|
AssetSystem.Initialize(false, parameters.AssetLoadingMaxNumber, parameters.DecryptionServices, _bundleServices);
|
||||||
var hostPlayModeParameters = parameters as HostPlayModeParameters;
|
var hostPlayModeParameters = parameters as HostPlayModeParameters;
|
||||||
return _hostPlayModeImpl.InitializeAsync(
|
return _hostPlayModeImpl.InitializeAsync(
|
||||||
hostPlayModeParameters.ClearCacheWhenDirty,
|
hostPlayModeParameters.ClearCacheWhenDirty,
|
||||||
|
@ -508,7 +508,7 @@ namespace YooAsset
|
||||||
public static void ClearSandbox()
|
public static void ClearSandbox()
|
||||||
{
|
{
|
||||||
YooLogger.Warning("Clear sandbox.");
|
YooLogger.Warning("Clear sandbox.");
|
||||||
PatchHelper.ClearSandbox();
|
SandboxHelper.ClearSandbox();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -516,7 +516,7 @@ namespace YooAsset
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public static string GetSandboxRoot()
|
public static string GetSandboxRoot()
|
||||||
{
|
{
|
||||||
return AssetPathHelper.MakePersistentRootPath();
|
return PathHelper.MakePersistentRootPath();
|
||||||
}
|
}
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
@ -554,12 +554,12 @@ namespace YooAsset
|
||||||
{
|
{
|
||||||
if (_playMode == EPlayMode.EditorPlayMode)
|
if (_playMode == EPlayMode.EditorPlayMode)
|
||||||
{
|
{
|
||||||
string filePath = AssetPathHelper.CombineAssetPath(_locationRoot, location);
|
string filePath = PathHelper.CombineAssetPath(_locationRoot, location);
|
||||||
return AssetPathHelper.FindDatabaseAssetPath(filePath);
|
return PathHelper.FindDatabaseAssetPath(filePath);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
return AssetPathHelper.CombineAssetPath(_locationRoot, location);
|
return PathHelper.CombineAssetPath(_locationRoot, location);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endregion
|
#endregion
|
||||||
|
|
Loading…
Reference in New Issue