mirror of
https://github.com/tuyoogame/YooAsset.git
synced 2026-05-30 05:28:46 +00:00
update web file system
This commit is contained in:
@@ -61,12 +61,20 @@ namespace YooAsset
|
|||||||
}
|
}
|
||||||
|
|
||||||
#region 自定义参数
|
#region 自定义参数
|
||||||
public bool AllowCrossAccess { private set; get; } = false;
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 自定义参数:远程服务接口
|
/// 自定义参数:远程服务接口
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public IRemoteServices RemoteServices { private set; get; } = null;
|
public IRemoteServices RemoteServices { private set; get; } = null;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 禁用Unity的网络缓存
|
||||||
|
/// </summary>
|
||||||
|
public bool DisableUnityWebCache { private set; get; } = false;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 允许跨域访问和下载
|
||||||
|
/// </summary>
|
||||||
|
public bool AllowCrossAccess { private set; get; } = false;
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
|
||||||
@@ -124,14 +132,18 @@ namespace YooAsset
|
|||||||
|
|
||||||
public virtual void SetParameter(string name, object value)
|
public virtual void SetParameter(string name, object value)
|
||||||
{
|
{
|
||||||
if (name == "ALLOW_CROSS_ACCESS")
|
if (name == "REMOTE_SERVICES")
|
||||||
{
|
|
||||||
AllowCrossAccess = (bool)value;
|
|
||||||
}
|
|
||||||
else if (name == "REMOTE_SERVICES")
|
|
||||||
{
|
{
|
||||||
RemoteServices = (IRemoteServices)value;
|
RemoteServices = (IRemoteServices)value;
|
||||||
}
|
}
|
||||||
|
else if (name == "DISABLE_UNITY_WEB_CACHE")
|
||||||
|
{
|
||||||
|
DisableUnityWebCache = (bool)value;
|
||||||
|
}
|
||||||
|
else if (name == "ALLOW_CROSS_ACCESS")
|
||||||
|
{
|
||||||
|
AllowCrossAccess = (bool)value;
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
YooLogger.Warning($"Invalid parameter : {name}");
|
YooLogger.Warning($"Invalid parameter : {name}");
|
||||||
|
|||||||
@@ -110,20 +110,34 @@ namespace YooAsset
|
|||||||
|
|
||||||
private void CreateWebRequest()
|
private void CreateWebRequest()
|
||||||
{
|
{
|
||||||
uint unityCRC = Bundle.UnityCRC;
|
|
||||||
Hash128 fileHash = Hash128.Parse(Bundle.FileHash);
|
|
||||||
|
|
||||||
// 注意:优先从浏览器缓存里获取文件
|
|
||||||
// The file hash defining the version of the asset bundle.
|
|
||||||
_webRequest = DownloadSystemHelper.NewUnityWebRequestGet(_requestURL);
|
_webRequest = DownloadSystemHelper.NewUnityWebRequestGet(_requestURL);
|
||||||
_downloadhandler = new DownloadHandlerAssetBundle(_requestURL, fileHash, unityCRC);
|
_webRequest.downloadHandler = CreateDownloadHandler();
|
||||||
#if UNITY_2020_3_OR_NEWER
|
|
||||||
_downloadhandler.autoLoadAssetBundle = false;
|
|
||||||
#endif
|
|
||||||
_webRequest.downloadHandler = _downloadhandler;
|
|
||||||
_webRequest.disposeDownloadHandlerOnDispose = true;
|
_webRequest.disposeDownloadHandlerOnDispose = true;
|
||||||
_webRequest.SendWebRequest();
|
_webRequest.SendWebRequest();
|
||||||
}
|
}
|
||||||
|
private DownloadHandlerAssetBundle CreateDownloadHandler()
|
||||||
|
{
|
||||||
|
if (_fileSystem.DisableUnityWebCache)
|
||||||
|
{
|
||||||
|
var downloadhandler = new DownloadHandlerAssetBundle(_requestURL, 0);
|
||||||
|
#if UNITY_2020_3_OR_NEWER
|
||||||
|
downloadhandler.autoLoadAssetBundle = false;
|
||||||
|
#endif
|
||||||
|
return downloadhandler;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// 注意:优先从浏览器缓存里获取文件
|
||||||
|
// The file hash defining the version of the asset bundle.
|
||||||
|
uint unityCRC = Bundle.UnityCRC;
|
||||||
|
Hash128 fileHash = Hash128.Parse(Bundle.FileHash);
|
||||||
|
var downloadhandler = new DownloadHandlerAssetBundle(_requestURL, fileHash, unityCRC);
|
||||||
|
#if UNITY_2020_3_OR_NEWER
|
||||||
|
downloadhandler.autoLoadAssetBundle = false;
|
||||||
|
#endif
|
||||||
|
return downloadhandler;
|
||||||
|
}
|
||||||
|
}
|
||||||
private void DisposeWebRequest()
|
private void DisposeWebRequest()
|
||||||
{
|
{
|
||||||
if (_webRequest != null)
|
if (_webRequest != null)
|
||||||
|
|||||||
@@ -160,10 +160,11 @@ namespace YooAsset
|
|||||||
/// <summary>
|
/// <summary>
|
||||||
/// 创建默认的Web文件系统参数
|
/// 创建默认的Web文件系统参数
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public static FileSystemParameters CreateDefaultWebFileSystemParameters()
|
public static FileSystemParameters CreateDefaultWebFileSystemParameters(bool disableUnityWebCache = false)
|
||||||
{
|
{
|
||||||
string fileSystemClass = typeof(DefaultWebFileSystem).FullName;
|
string fileSystemClass = typeof(DefaultWebFileSystem).FullName;
|
||||||
var fileSystemParams = new FileSystemParameters(fileSystemClass, null);
|
var fileSystemParams = new FileSystemParameters(fileSystemClass, null);
|
||||||
|
fileSystemParams.AddParameter("DISABLE_UNITY_WEB_CACHE", disableUnityWebCache);
|
||||||
fileSystemParams.AddParameter("ALLOW_CROSS_ACCESS", false);
|
fileSystemParams.AddParameter("ALLOW_CROSS_ACCESS", false);
|
||||||
return fileSystemParams;
|
return fileSystemParams;
|
||||||
}
|
}
|
||||||
@@ -172,12 +173,13 @@ namespace YooAsset
|
|||||||
/// 创建默认的Web文件系统参数
|
/// 创建默认的Web文件系统参数
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="remoteServices">远端资源地址查询服务类</param>
|
/// <param name="remoteServices">远端资源地址查询服务类</param>
|
||||||
public static FileSystemParameters CreateDefaultWebFileSystemParameters(IRemoteServices remoteServices)
|
public static FileSystemParameters CreateDefaultWebFileSystemParameters(IRemoteServices remoteServices, bool disableUnityWebCache = false)
|
||||||
{
|
{
|
||||||
string fileSystemClass = typeof(DefaultWebFileSystem).FullName;
|
string fileSystemClass = typeof(DefaultWebFileSystem).FullName;
|
||||||
var fileSystemParams = new FileSystemParameters(fileSystemClass, null);
|
var fileSystemParams = new FileSystemParameters(fileSystemClass, null);
|
||||||
fileSystemParams.AddParameter("ALLOW_CROSS_ACCESS", true);
|
|
||||||
fileSystemParams.AddParameter("REMOTE_SERVICES", remoteServices);
|
fileSystemParams.AddParameter("REMOTE_SERVICES", remoteServices);
|
||||||
|
fileSystemParams.AddParameter("DISABLE_UNITY_WEB_CACHE", disableUnityWebCache);
|
||||||
|
fileSystemParams.AddParameter("ALLOW_CROSS_ACCESS", true);
|
||||||
return fileSystemParams;
|
return fileSystemParams;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user