Compare commits

...

5 Commits

Author SHA1 Message Date
Blank 8f25d11139
Merge 60fe96fb9c into cdaa45e163 2024-11-11 14:01:12 +08:00
Blank 60fe96fb9c
[增加]增加下载状态变化的时候包名称的返回
1.主要是如果在同时下载包的时候且注册到统一的返回事件的时候无法识别当前是什么包下载的返回结果.这样给开发者有一定的操作成本.需要独立的去记录包和下载列表的关系
2024-08-27 19:19:42 +08:00
Blank dda2a4c659
[增加] 增加日志打印的标记和时间
1. 该日志标记在查询定位的时候非常有用.主要区分是否是业务日志还是资源日志.
2. 关于时间:可以查看在真机上的资源加载时间长短和资源问题的定位.
2024-08-27 19:16:18 +08:00
Blank a6b333fe35
[修改] 修改外部可以获取当前操作对象的包名称
1. 主要是外部如果是回调的时候,不一定在之前的代码位置了.所需要需要从操作对象中直接获取当前的包名
2024-08-27 19:13:36 +08:00
Blank 850ae88bc6
[增加]1. 增加是否加载成功的快捷判断属性
1. 该接口主要方便于外部直接判断是否成功,而无需再次使用枚举的方式判断
2024-08-27 19:10:43 +08:00
4 changed files with 80 additions and 362 deletions
Assets/YooAsset/Runtime
OperationSystem
ResourceManager/Handle
ResourcePackage/Operation

View File

@ -98,7 +98,7 @@ namespace YooAsset
throw new System.NotImplementedException(this.GetType().Name);
}
internal string GetPackageName()
public string GetPackageName()
{
return _packageName;
}

View File

@ -15,6 +15,14 @@ namespace YooAsset
}
internal abstract void InvokeCallback();
/// <summary>
/// 是否成功
/// </summary>
public bool IsSucceed
{
get { return IsDone && Status == EOperationStatus.Succeed; }
}
/// <summary>
/// 获取资源信息
/// </summary>

View File

@ -15,10 +15,10 @@ namespace YooAsset
private const int MAX_LOADER_COUNT = 64;
public delegate void OnDownloadOver(bool isSucceed);
public delegate void OnDownloadProgress(int totalDownloadCount, int currentDownloadCount, long totalDownloadBytes, long currentDownloadBytes);
public delegate void OnDownloadError(string fileName, string error);
public delegate void OnStartDownloadFile(string fileName, long sizeBytes);
public delegate void OnDownloadOver(string packageName, bool isSucceed);
public delegate void OnDownloadProgress(string packageName, int totalDownloadCount, int currentDownloadCount, long totalDownloadBytes, long currentDownloadBytes);
public delegate void OnDownloadError(string packageName, string fileName, string error);
public delegate void OnStartDownloadFile(string packageName, string fileName, long sizeBytes);
private readonly string _packageName;
private readonly int _downloadingMaxNumber;
@ -160,7 +160,7 @@ namespace YooAsset
_lastDownloadBytes = downloadBytes;
_lastDownloadCount = _cachedDownloadCount;
Progress = (float)_lastDownloadBytes / TotalDownloadBytes;
OnDownloadProgressCallback?.Invoke(TotalDownloadCount, _lastDownloadCount, TotalDownloadBytes, _lastDownloadBytes);
OnDownloadProgressCallback?.Invoke(GetPackageName(), TotalDownloadCount, _lastDownloadCount, TotalDownloadBytes, _lastDownloadBytes);
}
// 动态创建新的下载器到最大数量限制
@ -177,7 +177,7 @@ namespace YooAsset
var downloader = bundleInfo.CreateDownloader(_failedTryAgain, _timeout);
_downloaders.Add(downloader);
_bundleInfoList.RemoveAt(index);
OnStartDownloadFileCallback?.Invoke(bundleInfo.Bundle.BundleName, bundleInfo.Bundle.FileSize);
OnStartDownloadFileCallback?.Invoke(GetPackageName(), bundleInfo.Bundle.BundleName, bundleInfo.Bundle.FileSize);
}
}
@ -191,15 +191,15 @@ namespace YooAsset
_steps = ESteps.Done;
Status = EOperationStatus.Failed;
Error = $"Failed to download file : {bundleName}";
OnDownloadErrorCallback?.Invoke(bundleName, failedDownloader.Error);
OnDownloadOverCallback?.Invoke(false);
OnDownloadErrorCallback?.Invoke(GetPackageName(), bundleName, failedDownloader.Error);
OnDownloadOverCallback?.Invoke(GetPackageName(), false);
}
else
{
// 结算成功
_steps = ESteps.Done;
Status = EOperationStatus.Succeed;
OnDownloadOverCallback?.Invoke(true);
OnDownloadOverCallback?.Invoke(GetPackageName(), true);
}
}
}

View File

@ -1,377 +1,87 @@
using System;
using System.IO;
using System.Security.Cryptography;
using System.Text;
using System;
using System.Diagnostics;
namespace YooAsset
{
/// <summary>
/// 路径工具类
/// 自定义日志处理
/// </summary>
internal static class PathUtility
public interface ILogger
{
/// <summary>
/// 路径归一化
/// 注意替换为Linux路径格式
/// </summary>
public static string RegularPath(string path)
{
return path.Replace('\\', '/').Replace("\\", "/");
}
void Log(string message);
void Warning(string message);
void Error(string message);
void Exception(System.Exception exception);
}
internal static class YooLogger
{
public static ILogger Logger = null;
/// <summary>
/// 移除路径里的后缀名
/// 日志
/// </summary>
public static string RemoveExtension(string str)
[Conditional("DEBUG")]
public static void Log(string info)
{
if (string.IsNullOrEmpty(str))
return str;
int index = str.LastIndexOf('.');
if (index == -1)
return str;
if (Logger != null)
{
Logger.Log(GetTime() + info);
}
else
return str.Remove(index); //"assets/config/test.unity3d" --> "assets/config/test"
}
/// <summary>
/// 合并路径
/// </summary>
public static string Combine(string path1, string path2)
{
return StringUtility.Format("{0}/{1}", path1, path2);
}
/// <summary>
/// 合并路径
/// </summary>
public static string Combine(string path1, string path2, string path3)
{
return StringUtility.Format("{0}/{1}/{2}", path1, path2, path3);
}
/// <summary>
/// 合并路径
/// </summary>
public static string Combine(string path1, string path2, string path3, string path4)
{
return StringUtility.Format("{0}/{1}/{2}/{3}", path1, path2, path3, path4);
}
}
/// <summary>
/// 字符串工具类
/// </summary>
internal static class StringUtility
{
[ThreadStatic]
private static StringBuilder _cacheBuilder = new StringBuilder(2048);
public static string Format(string format, object arg0)
{
if (string.IsNullOrEmpty(format))
throw new ArgumentNullException();
_cacheBuilder.Length = 0;
_cacheBuilder.AppendFormat(format, arg0);
return _cacheBuilder.ToString();
}
public static string Format(string format, object arg0, object arg1)
{
if (string.IsNullOrEmpty(format))
throw new ArgumentNullException();
_cacheBuilder.Length = 0;
_cacheBuilder.AppendFormat(format, arg0, arg1);
return _cacheBuilder.ToString();
}
public static string Format(string format, object arg0, object arg1, object arg2)
{
if (string.IsNullOrEmpty(format))
throw new ArgumentNullException();
_cacheBuilder.Length = 0;
_cacheBuilder.AppendFormat(format, arg0, arg1, arg2);
return _cacheBuilder.ToString();
}
public static string Format(string format, params object[] args)
{
if (string.IsNullOrEmpty(format))
throw new ArgumentNullException();
if (args == null)
throw new ArgumentNullException();
_cacheBuilder.Length = 0;
_cacheBuilder.AppendFormat(format, args);
return _cacheBuilder.ToString();
}
}
/// <summary>
/// 文件工具类
/// </summary>
internal static class FileUtility
{
/// <summary>
/// 读取文件的文本数据
/// </summary>
public static string ReadAllText(string filePath)
{
if (File.Exists(filePath) == false)
return null;
return File.ReadAllText(filePath, Encoding.UTF8);
}
/// <summary>
/// 读取文件的字节数据
/// </summary>
public static byte[] ReadAllBytes(string filePath)
{
if (File.Exists(filePath) == false)
return null;
return File.ReadAllBytes(filePath);
}
/// <summary>
/// 写入文本数据(会覆盖指定路径的文件)
/// </summary>
public static void WriteAllText(string filePath, string content)
{
// 创建文件夹路径
CreateFileDirectory(filePath);
byte[] bytes = Encoding.UTF8.GetBytes(content);
File.WriteAllBytes(filePath, bytes); //避免写入BOM标记
}
/// <summary>
/// 写入字节数据(会覆盖指定路径的文件)
/// </summary>
public static void WriteAllBytes(string filePath, byte[] data)
{
// 创建文件夹路径
CreateFileDirectory(filePath);
File.WriteAllBytes(filePath, data);
}
/// <summary>
/// 创建文件的文件夹路径
/// </summary>
public static void CreateFileDirectory(string filePath)
{
// 获取文件的文件夹路径
string directory = Path.GetDirectoryName(filePath);
CreateDirectory(directory);
}
/// <summary>
/// 创建文件夹路径
/// </summary>
public static void CreateDirectory(string directory)
{
// If the directory doesn't exist, create it.
if (Directory.Exists(directory) == false)
Directory.CreateDirectory(directory);
}
/// <summary>
/// 获取文件大小(字节数)
/// </summary>
public static long GetFileSize(string filePath)
{
FileInfo fileInfo = new FileInfo(filePath);
return fileInfo.Length;
}
}
/// <summary>
/// 哈希工具类
/// </summary>
public static class HashUtility
{
private static string ToString(byte[] hashBytes)
{
string result = BitConverter.ToString(hashBytes);
result = result.Replace("-", "");
return result.ToLower();
}
#region SHA1
/// <summary>
/// 获取字符串的Hash值
/// </summary>
public static string StringSHA1(string str)
{
byte[] buffer = Encoding.UTF8.GetBytes(str);
return BytesSHA1(buffer);
}
/// <summary>
/// 获取文件的Hash值
/// </summary>
public static string FileSHA1(string filePath)
{
using (FileStream fs = new FileStream(filePath, FileMode.Open, FileAccess.Read, FileShare.Read))
{
return StreamSHA1(fs);
UnityEngine.Debug.Log(GetTime() + info);
}
}
/// <summary>
/// 获取文件的Hash值
/// 警告
/// </summary>
public static string FileSHA1Safely(string filePath)
public static void Warning(string info)
{
try
if (Logger != null)
{
return FileSHA1(filePath);
Logger.Warning(GetTime() + info);
}
catch (Exception e)
else
{
YooLogger.Exception(e);
return string.Empty;
UnityEngine.Debug.LogWarning(GetTime() + info);
}
}
/// <summary>
/// 获取数据流的Hash值
/// 错误
/// </summary>
public static string StreamSHA1(Stream stream)
public static void Error(string info)
{
// 说明创建的是SHA1类的实例生成的是160位的散列码
HashAlgorithm hash = HashAlgorithm.Create();
byte[] hashBytes = hash.ComputeHash(stream);
return ToString(hashBytes);
}
/// <summary>
/// 获取字节数组的Hash值
/// </summary>
public static string BytesSHA1(byte[] buffer)
{
// 说明创建的是SHA1类的实例生成的是160位的散列码
HashAlgorithm hash = HashAlgorithm.Create();
byte[] hashBytes = hash.ComputeHash(buffer);
return ToString(hashBytes);
}
#endregion
#region MD5
/// <summary>
/// 获取字符串的MD5
/// </summary>
public static string StringMD5(string str)
{
byte[] buffer = Encoding.UTF8.GetBytes(str);
return BytesMD5(buffer);
}
/// <summary>
/// 获取文件的MD5
/// </summary>
public static string FileMD5(string filePath)
{
using (FileStream fs = new FileStream(filePath, FileMode.Open, FileAccess.Read, FileShare.Read))
if (Logger != null)
{
return StreamMD5(fs);
Logger.Error(GetTime() + info);
}
else
{
UnityEngine.Debug.LogError(GetTime() + info);
}
}
/// <summary>
/// 获取文件的MD5
/// </summary>
public static string FileMD5Safely(string filePath)
private static string GetTime()
{
try
return $"[YooAsset]:[{DateTime.Now:HH:mm:ss.fff}]:";
}
/// <summary>
/// 异常
/// </summary>
public static void Exception(System.Exception exception)
{
if (Logger != null)
{
return FileMD5(filePath);
Logger.Exception(exception);
}
catch (Exception e)
else
{
YooLogger.Exception(e);
return string.Empty;
UnityEngine.Debug.LogException(exception);
}
}
/// <summary>
/// 获取数据流的MD5
/// </summary>
public static string StreamMD5(Stream stream)
{
MD5CryptoServiceProvider provider = new MD5CryptoServiceProvider();
byte[] hashBytes = provider.ComputeHash(stream);
return ToString(hashBytes);
}
/// <summary>
/// 获取字节数组的MD5
/// </summary>
public static string BytesMD5(byte[] buffer)
{
MD5CryptoServiceProvider provider = new MD5CryptoServiceProvider();
byte[] hashBytes = provider.ComputeHash(buffer);
return ToString(hashBytes);
}
#endregion
#region CRC32
/// <summary>
/// 获取字符串的CRC32
/// </summary>
public static string StringCRC32(string str)
{
byte[] buffer = Encoding.UTF8.GetBytes(str);
return BytesCRC32(buffer);
}
/// <summary>
/// 获取文件的CRC32
/// </summary>
public static string FileCRC32(string filePath)
{
using (FileStream fs = new FileStream(filePath, FileMode.Open, FileAccess.Read, FileShare.Read))
{
return StreamCRC32(fs);
}
}
/// <summary>
/// 获取文件的CRC32
/// </summary>
public static string FileCRC32Safely(string filePath)
{
try
{
return FileCRC32(filePath);
}
catch (Exception e)
{
YooLogger.Exception(e);
return string.Empty;
}
}
/// <summary>
/// 获取数据流的CRC32
/// </summary>
public static string StreamCRC32(Stream stream)
{
CRC32Algorithm hash = new CRC32Algorithm();
byte[] hashBytes = hash.ComputeHash(stream);
return ToString(hashBytes);
}
/// <summary>
/// 获取字节数组的CRC32
/// </summary>
public static string BytesCRC32(byte[] buffer)
{
CRC32Algorithm hash = new CRC32Algorithm();
byte[] hashBytes = hash.ComputeHash(buffer);
return ToString(hashBytes);
}
#endregion
}
}