From 54f585c67a431c4a9a7a438b9f94aa54db4c87f2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E4=BD=95=E5=86=A0=E5=B3=B0?= Date: Fri, 5 Jul 2024 19:29:50 +0800 Subject: [PATCH] update extension sample --- .../Runtime/WechatFileSystem.cs | 166 +++++++++++++++++- 1 file changed, 157 insertions(+), 9 deletions(-) diff --git a/Assets/YooAsset/Samples~/Extension Sample/Runtime/WechatFileSystem.cs b/Assets/YooAsset/Samples~/Extension Sample/Runtime/WechatFileSystem.cs index a05ebf2..7fec0af 100644 --- a/Assets/YooAsset/Samples~/Extension Sample/Runtime/WechatFileSystem.cs +++ b/Assets/YooAsset/Samples~/Extension Sample/Runtime/WechatFileSystem.cs @@ -1,17 +1,48 @@ -#if !UNITY_WECHAT_GAME +#if !UNITY_WECHAT_GAME +using System; +using System.IO; +using System.Collections.Generic; using UnityEngine; using UnityEngine.Networking; using YooAsset; using WeChatWASM; /// -/// ΢СϷļϵͳչ -/// οhttps://wechat-miniprogram.github.io/minigame-unity-webgl-transform/Design/UsingAssetBundle.html +/// 微信小游戏文件系统扩展 +/// 参考:https://wechat-miniprogram.github.io/minigame-unity-webgl-transform/Design/UsingAssetBundle.html /// -internal class WechatFileSystem : DefaultWebFileSystem +internal partial class WechatFileSystem : DefaultWebFileSystem { + private WXFileSystemManager _wxFileSystemMgr; + private readonly Dictionary _wxFilePaths = new Dictionary(10000); + private string _wxFileCacheRoot = string.Empty; + + public override void OnCreate(string packageName, string rootDirectory) + { + base.OnCreate(packageName, rootDirectory); + + _wxFileSystemMgr = WX.GetFileSystemManager(); + _wxFileCacheRoot = WX.env.USER_DATA_PATH; //注意:如果有子目录,请修改此处! + } + /// - /// Դļ + /// 重写资源文件下载方法 + /// + public override FSDownloadFileOperation DownloadFileAsync(params object[] args) + { + PackageBundle bundle = args[0] as PackageBundle; + int failedTryAgain = (int)args[2]; + int timeout = (int)args[3]; + + string mainURL = RemoteServices.GetRemoteMainURL(bundle.FileName); + string fallbackURL = RemoteServices.GetRemoteFallbackURL(bundle.FileName); + var operation = new WechatDownloadFileOperation(this, bundle, mainURL,fallbackURL, failedTryAgain, timeout); + OperationSystem.StartOperation(PackageName, operation); + return operation; + } + + /// + /// 重写资源文件加载方法 /// public override FSLoadBundleOperation LoadBundleFile(PackageBundle bundle) { @@ -21,7 +52,7 @@ internal class WechatFileSystem : DefaultWebFileSystem } /// - /// Դļж + /// 重写资源文件卸载方法 /// public override void UnloadBundleFile(PackageBundle bundle, object result) { @@ -30,10 +61,31 @@ internal class WechatFileSystem : DefaultWebFileSystem assetBundle.WXUnload(true); } - /// - /// дԴļ + /// 重写查询方法 /// + public override bool Exists(PackageBundle bundle) + { + string filePath = GetWXFileLoadPath(bundle); + string result = _wxFileSystemMgr.AccessSync(filePath); + return result.Equals("access:ok"); + } + + #region 内部方法 + private string GetWXFileLoadPath(PackageBundle bundle) + { + if (_wxFilePaths.TryGetValue(bundle.BundleGUID, out string filePath) == false) + { + filePath = PathUtility.Combine(_wxFileCacheRoot, bundle.FileName); + _wxFilePaths.Add(bundle.BundleGUID, filePath); + } + return filePath; + } + #endregion +} + +internal partial class WechatFileSystem +{ internal class WechatLoadBundleOperation : FSLoadBundleOperation { private enum ESteps @@ -48,7 +100,6 @@ internal class WechatFileSystem : DefaultWebFileSystem private UnityWebRequest _webRequest; private ESteps _steps = ESteps.None; - internal WechatLoadBundleOperation(WechatFileSystem fileSystem, PackageBundle bundle) { _fileSystem = fileSystem; @@ -131,5 +182,102 @@ internal class WechatFileSystem : DefaultWebFileSystem #endif } } + internal class WechatDownloadFileOperation : DefaultDownloadFileOperation + { + private WechatFileSystem _fileSystem; + private ESteps _steps = ESteps.None; + + internal WechatDownloadFileOperation(WechatFileSystem fileSystem, PackageBundle bundle, + string mainURL, string fallbackURL, int failedTryAgain, int timeout) + : base(bundle, mainURL, fallbackURL, failedTryAgain, timeout) + { + _fileSystem = fileSystem; + } + internal override void InternalOnStart() + { + _steps = ESteps.CreateRequest; + } + internal override void InternalOnUpdate() + { + // 创建下载器 + if (_steps == ESteps.CreateRequest) + { + // 获取请求地址 + _requestURL = GetRequestURL(); + + // 重置变量 + ResetRequestFiled(); + + // 创建下载器 + CreateWebRequest(); + + _steps = ESteps.CheckRequest; + } + + // 检测下载结果 + if (_steps == ESteps.CheckRequest) + { + DownloadProgress = _webRequest.downloadProgress; + DownloadedBytes = (long)_webRequest.downloadedBytes; + Progress = DownloadProgress; + if (_webRequest.isDone == false) + { + CheckRequestTimeout(); + return; + } + + // 检查网络错误 + if (CheckRequestResult()) + { + _steps = ESteps.Done; + Status = EOperationStatus.Succeed; + } + else + { + _steps = ESteps.TryAgain; + } + + // 注意:最终释放请求器 + DisposeWebRequest(); + } + + // 重新尝试下载 + if (_steps == ESteps.TryAgain) + { + if (FailedTryAgain <= 0) + { + Status = EOperationStatus.Failed; + _steps = ESteps.Done; + YooLogger.Error(Error); + return; + } + + _tryAgainTimer += Time.unscaledDeltaTime; + if (_tryAgainTimer > 1f) + { + FailedTryAgain--; + _steps = ESteps.CreateRequest; + YooLogger.Warning(Error); + } + } + } + + private void CreateWebRequest() + { + _webRequest = WXAssetBundle.GetAssetBundle(_requestURL); + _webRequest.SetRequestHeader("wechatminigame-preload", "1"); + _webRequest.disposeDownloadHandlerOnDispose = true; + _webRequest.SendWebRequest(); + } + private void DisposeWebRequest() + { + if (_webRequest != null) + { + //注意:引擎底层会自动调用Abort方法 + _webRequest.Dispose(); + _webRequest = null; + } + } + } } #endif \ No newline at end of file