2022-03-10 16:55:12 +08:00
|
|
|
|
# 资源更新
|
|
|
|
|
|
2022-04-12 19:36:18 +08:00
|
|
|
|
**获取资源版本**
|
|
|
|
|
|
2022-10-08 16:25:36 +08:00
|
|
|
|
对于联机运行模式,在更新补丁清单之前,需要获取一个资源版本。
|
2022-04-12 19:36:18 +08:00
|
|
|
|
|
2022-10-08 16:25:36 +08:00
|
|
|
|
该资源版本可以通过YooAssets提供的接口来更新,也可以通过HTTP访问游戏服务器来获取。
|
2022-03-10 16:55:12 +08:00
|
|
|
|
|
2022-04-12 19:36:18 +08:00
|
|
|
|
````c#
|
|
|
|
|
private IEnumerator UpdateStaticVersion()
|
|
|
|
|
{
|
2022-10-18 19:27:47 +08:00
|
|
|
|
var package = YooAssets.GetAssetsPackage("DefaultPackage");
|
2022-11-21 09:52:18 +08:00
|
|
|
|
var operation = package.UpdatePackageVersionAsync();
|
2022-04-12 19:36:18 +08:00
|
|
|
|
yield return operation;
|
2022-03-10 16:55:12 +08:00
|
|
|
|
|
2022-04-12 19:36:18 +08:00
|
|
|
|
if (operation.Status == EOperationStatus.Succeed)
|
|
|
|
|
{
|
|
|
|
|
//更新成功
|
2022-10-28 10:46:35 +08:00
|
|
|
|
string PackageVersion = operation.PackageVersion;
|
|
|
|
|
Debug.Log($"Updated package Version : {PackageVersion}");
|
2022-04-12 19:36:18 +08:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
//更新失败
|
|
|
|
|
Debug.LogError(operation.Error);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
````
|
|
|
|
|
|
|
|
|
|
**更新补丁清单**
|
2022-03-10 16:55:12 +08:00
|
|
|
|
|
2022-04-12 19:36:18 +08:00
|
|
|
|
对于联机运行模式,在获取到资源版本号之后,就可以更新资源清单了。
|
2022-03-10 16:55:12 +08:00
|
|
|
|
|
|
|
|
|
````c#
|
|
|
|
|
private IEnumerator UpdatePatchManifest()
|
|
|
|
|
{
|
2022-10-18 19:27:47 +08:00
|
|
|
|
var package = YooAssets.GetAssetsPackage("DefaultPackage");
|
2022-11-21 09:52:18 +08:00
|
|
|
|
var operation = package.UpdatePackageManifestAsync(packageVersion);
|
2022-03-10 16:55:12 +08:00
|
|
|
|
yield return operation;
|
|
|
|
|
|
|
|
|
|
if (operation.Status == EOperationStatus.Succeed)
|
|
|
|
|
{
|
|
|
|
|
//更新成功
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
//更新失败
|
|
|
|
|
Debug.LogError(operation.Error);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
````
|
|
|
|
|
|
|
|
|
|
**补丁包下载**
|
|
|
|
|
|
|
|
|
|
在补丁清单更新完毕后,就可以更新资源文件了。
|
|
|
|
|
|
|
|
|
|
根据产品需求,可以选择更新全部资源,或者只更新部分资源。
|
|
|
|
|
|
|
|
|
|
补丁包下载接口:
|
|
|
|
|
|
2022-10-18 19:27:47 +08:00
|
|
|
|
- YooAssets.CreatePatchDownloader(int downloadingMaxNumber, int failedTryAgain, int timeout)
|
2022-05-04 00:12:06 +08:00
|
|
|
|
|
|
|
|
|
用于下载更新当前资源版本所有的资源包文件。
|
|
|
|
|
|
2022-10-18 19:27:47 +08:00
|
|
|
|
- YooAssets.CreatePatchDownloader(string[] tags, int downloadingMaxNumber, int failedTryAgain, int timeout)
|
2022-05-04 00:12:06 +08:00
|
|
|
|
|
|
|
|
|
用于下载更新资源标签指定的资源包文件。
|
|
|
|
|
|
2022-10-18 19:27:47 +08:00
|
|
|
|
- YooAssets.CreateBundleDownloader(string[] locations, int downloadingMaxNumber, int failedTryAgain, int timeout)
|
2022-05-04 00:12:06 +08:00
|
|
|
|
|
|
|
|
|
用于下载更新指定的资源列表依赖的资源包文件。
|
2022-03-10 16:55:12 +08:00
|
|
|
|
|
|
|
|
|
````c#
|
|
|
|
|
IEnumerator Download()
|
|
|
|
|
{
|
|
|
|
|
int downloadingMaxNum = 10;
|
|
|
|
|
int failedTryAgain = 3;
|
2022-10-18 19:27:47 +08:00
|
|
|
|
int timeout = 60;
|
2022-10-28 10:46:35 +08:00
|
|
|
|
var package = YooAssets.GetAssetsPackage("DefaultPackage");
|
|
|
|
|
var downloader = package.CreatePatchDownloader(downloadingMaxNum, failedTryAgain, timeout);
|
2022-03-10 16:55:12 +08:00
|
|
|
|
|
|
|
|
|
//没有需要下载的资源
|
|
|
|
|
if (downloader.TotalDownloadCount == 0)
|
|
|
|
|
{
|
|
|
|
|
yield break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//需要下载的文件总数和总大小
|
|
|
|
|
int totalDownloadCount = downloader.TotalDownloadCount;
|
|
|
|
|
long totalDownloadBytes = downloader.TotalDownloadBytes;
|
|
|
|
|
|
|
|
|
|
//注册回调方法
|
2022-06-25 11:41:13 +08:00
|
|
|
|
downloader.OnDownloadErrorCallback = OnDownloadErrorFunction;
|
|
|
|
|
downloader.OnDownloadProgressCallback = OnDownloadProgressUpdateFunction;
|
|
|
|
|
downloader.OnDownloadOverCallback = OnDownloadOverFunction;
|
|
|
|
|
downloader.OnStartDownloadFileCallback = OnStartDownloadFileFunction;
|
2022-03-10 16:55:12 +08:00
|
|
|
|
|
|
|
|
|
//开启下载
|
|
|
|
|
downloader.BeginDownload();
|
|
|
|
|
yield return downloader;
|
|
|
|
|
|
|
|
|
|
//检测下载结果
|
|
|
|
|
if (downloader.Status == EOperationStatus.Succeed)
|
|
|
|
|
{
|
|
|
|
|
//下载成功
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
//下载失败
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
````
|
|
|
|
|
|
2022-11-04 13:22:31 +08:00
|
|
|
|
**弱联网环境解决方案**
|
2022-06-28 20:20:36 +08:00
|
|
|
|
|
2022-11-04 13:22:31 +08:00
|
|
|
|
对于偏单机但是也有资源热更需求的项目。当玩家在无网络的时候,我们又不希望玩家卡在资源更新步骤而不能正常游戏。所以当玩家本地网络有问题的时候,我们可以跳过资源更新的步骤。
|
2022-06-28 20:20:36 +08:00
|
|
|
|
|
|
|
|
|
````c#
|
2022-11-04 13:22:31 +08:00
|
|
|
|
private IEnumerator Start()
|
2022-06-28 20:20:36 +08:00
|
|
|
|
{
|
2022-10-18 19:27:47 +08:00
|
|
|
|
var package = YooAssets.GetAssetsPackage("DefaultPackage");
|
2022-11-21 09:52:18 +08:00
|
|
|
|
var operation = package.UpdatePackageVersionAsync(30);
|
2022-06-28 20:20:36 +08:00
|
|
|
|
yield return operation;
|
2022-06-29 10:02:57 +08:00
|
|
|
|
if (operation.Status == EOperationStatus.Succeed)
|
2022-06-28 20:20:36 +08:00
|
|
|
|
{
|
2022-11-04 13:22:31 +08:00
|
|
|
|
// 如果获取远端资源版本成功,说明当前网络连接通畅,可以走正常更新流程。
|
2022-06-29 10:02:57 +08:00
|
|
|
|
......
|
2022-06-28 20:20:36 +08:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2022-11-04 13:22:31 +08:00
|
|
|
|
// 如果获取远端资源版本失败,说明当前网络无连接。
|
|
|
|
|
// 在正常开始游戏之前,需要验证本地清单内容的完整性。
|
2022-12-27 10:20:13 +08:00
|
|
|
|
string packageVersion = package.GetPackageVersion();
|
|
|
|
|
var operation = package.CheckPackageContentsAsync(packageVersion);
|
2022-11-04 13:22:31 +08:00
|
|
|
|
yield return operation;
|
|
|
|
|
if (operation.Status == EOperationStatus.Succeed)
|
|
|
|
|
{
|
|
|
|
|
StartGame();
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
// 资源内容本地并不完整,需要提示玩家联网更新。
|
|
|
|
|
ShowMessageBox("请检查本地网络,有新的游戏内容需要更新!");
|
|
|
|
|
}
|
2022-06-28 20:20:36 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
````
|
|
|
|
|
|
2022-11-04 11:39:16 +08:00
|
|
|
|
### 源代码解析
|
|
|
|
|
|
|
|
|
|
- 联机运行模式
|
|
|
|
|
|
2022-11-21 09:52:18 +08:00
|
|
|
|
UpdatePackageManifestAsync()为资源清单更新方法。该方法的内部实现原理如下:
|
2022-11-04 11:39:16 +08:00
|
|
|
|
|
|
|
|
|
![image](./Image/CodeTutorial2-img1.png)
|