zoukankan      html  css  js  c++  java
  • 游戏资源打包

    游戏资源打包几乎是一个网络游戏客户端必备的功能。页游和微端根据实际需求可能不打包资源或者使用小包。

    资源打包有这么几个好处:

    1、加快客户端安装时间。拷贝3000个1mb文件所消耗的时间要远大于拷贝一个3g的文件所消耗的时间

    2、客户端更加整洁,也可以“稍微”避免游戏资源被他人使用。

    3、ios和android上面可以避免文件名大小写不一致造成的文件读取失败。或者说包内可以做到全平台大小写无关

    4、压缩资源,如果是大量png等图片资源可能还体现不出来,但是如果有大量文本和未压缩模型资源,那么打包可以有效减小客户端

    这里介绍两个开源库,可以非常方便的给客户端加入资源打包功能。

    1、StormLib(http://www.zezula.net/en/mpq/stormlib.html),这个就是暴雪MPQ打包格式开源实现版本。通过这个库可以轻易的实现一个PackageManager来加载包内资源

    2、ZPack (http://multi-crash.com/?page_id=340)  这个同样是一个开源打包格式实现。对比上面的MPQ,它更精简,当然功能也更弱一些。不过现有的一些功能已经完全能满足我的实际需求了

    主要特性:

    • 速度
      • 以文件名hash方式检索,读取效率至上
      • 删除包内文件时,只删除文件索引,不需要移动包内数据
      • 在两次flush之间用户可以添加任意多个文件(例如添加整个目录),这期间除了被添加文件数据的写入,没有任何其它多余的文件IO操作
    • 尺寸
      • 添加文件时,优先插入到之前删除文件留下的空闲位置,尽可能利用空间
      • 用户可以调用countFragmentSize检查当前包内空闲空间字节数,必要的话可以调用defrag进行整理以释放空间
      • 暂不支持数据压缩,但用户很容易自行添加压缩支持
    • 安全/健壮
      • 严格保证在用户调用flush()之前,包文件的有效性。这样当用户一次添加/删除较多文件的过程中即使发生意外(例如停电,进程被强行终止等),包文件能保持最后一次flush后的逻辑结构,不会发生灾难性后果
      • 包文件以只读方式打开时,原始的文件名信息不会被加载到内存。也就是说用户可以选择不将原始目录结构和文件名写入包内,包文件仍然能正常读取
    • 可扩展/兼容
      • 从设计上保证当将来需要扩展包文件头或包内文件索引中的数据时,老的代码仍能读取新的数据结构
      • 当数据包和zpEditor版本不一致时,zpEditor仍可以以只读模式打开数据包
    • 工具
      • 虽然包内文件是以扁平方式组织(以保证检索效率),但zpack另外提供工具类ZpExplorer,让用户可以以树状目录形式浏览和编辑包内文件
      • 提供命令行工具,接近dos使用习惯
      • 提供类似windows explorer的编辑器
    • 其它
      • 包文件不受4g大小限制
      • 核心读取模块仅依赖c++标准库,很容易移植到windows以外的平台,例如Linux,Mac,iPhone等
      • 代码小巧精简,不提供任何多余接口。zpack核心源代码仅20k左右

    一个打包模块只要能满足这么几个需求就完全够使用了:

    1、hash的平铺路径,保证足够的查找效率

    2、支持压缩

    3、安全,健壮,不会因为一些操作造成包损坏

    最后感慨下,开源世界太丰富了,多了解一些开源项目就可以省去很多自己重新创造所需要的时间了。

  • 相关阅读:
    Java条件语句之多重 if
    Java条件语句之 if...else
    equals和==的区别
    Java条件语句之 if
    Java中运算符的优先级
    Java中的条件运算符
    tp 推送微信的模板消息
    thinkphp 上传多张图片
    图片服务器和WEB应用服务器相分离的简单方案
    PHP无限级分类实现(递归+非递归)
  • 原文地址:https://www.cnblogs.com/lancidie/p/3019469.html
Copyright © 2011-2022 走看看