我所遭遇过的游戏中间件---Redux
我所遭遇过的游戏中间件---Redux
一.关于Redux
Substance Redux 是一款纹理处理软件加中间件,专门用于纹理生成和压缩。具其用户指南介绍,它能够对纹理集进行优化,可以将现有压缩算法的性能提高50%或更多。其压缩方式可是无损压缩,也可以是无损压缩。压缩时可以由用户自定义压缩比和图像质量。
Redux可以针对批量纹理文件进行压缩打包。操作流程是新建一个Project项目,为该项目导入若干个纹理文件,可以设置每一个纹理的压缩参数。最后导出压缩文件。Redux可以对多种格式的图像文件进行压缩。如果输入图像的长宽不为2的N次幂,Redux会自动将其拉伸至2的N次幂。ReduxSDK提供的Demo中将压缩文件解压成符合DDS格式的功能。
Redux最大的卖点在于其图像生成功能,它可以用若干个简单的图元,经过算法生成复杂的图像.图元只需要占用很小的磁盘空间,生成方法的保存也用不了多少磁盘空间,按他们官方的说法,游戏中占用磁盘最大的部分是纹理,而使用了Redux可以将纹理占用的磁盘空间降低到最小,从而最多能将游戏的发布包大小降低到二分之一.
二.Redux 压缩方式
Redux 提供3种纹理压缩方式:
Redux Mode 1(Redux 模式 1)是无损压缩算法,在大多数情况下压缩比最小。但是,通常它的渲染速度最快。
Redux mode 2(Redux 模式 2)是提供高质量图像的快速压缩算法,但是尺寸缩减率为 40% 左右。
Redux mode 3(Redux 模式 3)实现了图像质量和尺寸缩减率的大致均衡。图像质量低于模式 2,但是通过此模式可以获得更高的压缩比。尺寸缩减率为60% 左右。
在实际操作中,我将300张DDS文件进行压缩,发现Redux mode 2与Redux mode 3生成的文件大小是一样的。我当时没有在意这些DDS文件具体是什么压缩格式,估计大部分为DXT5的.
三.Redux 压缩文件
Redux 主要针对批量纹理文件进行压缩,压缩后的文件分为两类。一个“头”文件,包含主要数据文件的目录并向解压缩代码提供每个纹理的位置。该文件的扩展名为 .RDXH,用于存储每个纹理的详细信息,例如纹理名称、文件夹和路径。一个或多个“数据”文件,包含实际已压缩的纹理,这类文件的扩展名为.RDXC。第二类文件将采用“块”。可以将所有纹理存储在一个大文件中,这样就只需要处理一个数据“块”。对于导出的压缩“块”文件,可以有以下三种设置方式:
1. No Chunks(无块)——即一个大数据文件,包含项目中每个单独的纹理;
2. Chunks split according to a size limit(根据大小限制来分割块)——例如,每 4 MB 数据创建一个新块;
3. Chunks split according to content(根据内容分割块)——即为每个纹理创建一个新块。此时会生成一个头文件,若干个chunk文件。
生成压缩文件之后,如果对原纹理文件有任何改动,则必需重新生成压缩文件。这种压缩方式不太符合我的想法。我所希望的是通过一个纹理名找到一个压缩文件,加载该文件,解压缩并生成纹理。如果使用Redux,引擎需要先加载一个.RDXH头文件,生成一个Redux定义的ReduxHandle对象。然后根据纹理名找到纹理下标索引,再通过索引值使用Redux提供的接口获取纹理数据。创建只含有一个纹理文件的Redux工程,这样生成的压缩文件中有含有一个纹理。这是很麻烦的事情,工作量会很大。
四.Redux 解压缩
ReduxSDK提供的Demo中将压缩文件解压成符合DDS格式的数据,我曾经对其性能做过测试:首先使用300个DDS文件进行测试。原文件大小为59.6M,如果使用RAR压缩后大小为25.9M。DDS的压缩格式,当时没有记录,估计大部分为DXT5.
|
压缩方式 |
文件大小 |
加载文件时间 |
同步创建纹理时间1 |
同步创建纹理时间2 |
|
不压缩 |
59.6M |
2355ms |
6172 ms |
6133 ms |
|
Redux Mode1 无损压缩 |
19.5M |
743ms |
25016 ms |
24985 ms |
|
Redux Mode2 40% reduction |
17.3M |
702ms |
25862 ms |
25860 ms |
|
Redux Mode3 50% reduction |
17.3M |
674ms |
25878 ms |
25911ms |
|
Redux Mode1 无损压缩 Texture per chunk |
20.6M |
813ms (此为创建ReduxHandle的时间) |
29027ms |
29089ms |
用引擎加载本地文件创建这300个纹理需要的时间约为8秒,通过解压Redux文件来创建300个纹理需要花费30多秒时间,是本地加载的4倍。
针对不同大小的文件,创建纹理所使用的时间如下表所示:
|
纹理大小 |
文件大小 |
引擎加载创建时间 |
Redux Mode1创建时间 |
Redux Mode2创建时间 |
Redux Mode3创建时间 |
|
128*128 |
11K |
1ms |
105 ms |
31 ms |
30 ms |
|
256*256 |
65K |
11 ms |
228 ms |
82 ms |
82 ms |
|
512*512 |
257K |
49 ms |
206 ms |
140 ms |
137 ms |
|
1024*1024 |
1025K |
176 ms |
297 ms |
418 ms |
415 ms |
|
2048*2048 |
5462K |
242 ms |
2263 ms |
2265 ms |
2294 ms |
五.图像生成功能
使用若干个简单的图元,经过算法生成复杂的图像.这里最大的问题是,美术无法适应这种做图方式.正常情况下,美术用绘图板在PS中做图,而Redux则要求美术以解析的方式,先想象出一张图由多少图元组成,再设计好图元的组合方式.如何让图元生成图像,这种逻辑思维太颠覆了.一般人很难高效的用它提供的软件做图.就是因为这个原因,最终这个中间件没有使用.
六.软件问题
(1)
项目的属性设置时,设置Mode2与Mode3生成的压缩文件是一样的。
(2)
对单幅纹理的压缩设置中Redux Mode3 与项目属性中的Mode3不一样。
设置Redux Mode2与Redux Mode3没有任何区别.
(3)
对于一些纹理文件压缩后数据大小,要大于未处理的数据大小。
原DDS文件大小为6.475KB,压缩后为6.682KB
原DDS文件大小为57.6KB,压缩后为140.9KB
(4)
使用有损压缩,对一些纹理会产生明显的斑驳.
(5)
当时我使用的版本,如果纹理的数目过多,会导致软件崩溃。
(6)
Redux线程不安全,所以不能同时解压多个纹理。
七.Redux 后记
我个人对Redux的感觉是:这个中间件很奇怪.目前的发展,硬盘大小不是问题,内存的消耗也不是问题.最大的问题是提高效率.为了提高效率我们经常使用一些用空间换时间的算法.而Redux则反其道而行之,它所做的无非是用时间换空间.以上这些材料还是我两三年前整理的,文章中的性能测试数据仅供参考,不知道现在Redux发展的如何,也不太清楚市面上有多少游戏使用它.用Google搜索了下,也没多少关于它的网页.也许Redux会在移动游戏上有所发展,毕竟现在移动端的磁盘空间比PC端小了很多.
我所遭遇过的游戏中间件---Redux的更多相关文章
- 我所遭遇过的游戏中间件---SpeedTree
我所遭遇过的游戏中间件---SpeedTree SpeedTree是一个专门用于渲染植被的中间件,并提供了一套完善的植物编辑工具.在它官方提供的DEMO中,你会看到高度逼真的树木和植物,在风的影响下树 ...
- 我所遭遇过的游戏中间件---nvDXTLib
我所遭遇过的游戏中间件---nvDXTLib nvDXTLib是Nvidia提供的一套用于DXT纹理压缩SDK.接口十分简洁,就是提供了几个纹理压缩的函数,其中我使用最多的函数是: DXTLIB_AP ...
- 我所遭遇过的游戏中间件---HumanIK
我所遭遇过的游戏中间件---HumanIK Autodesk HumanIK游戏中间件,为游戏创建更加可信.真实的角色动画.该中间件的全身逆向运动(FBIK)系统支持角色真实地与所在环境及其它角色进行 ...
- 我所遭遇过的游戏中间件--Kynapse
我所遭遇过的游戏中间件--Kynapse Autodesk Kynapse游戏中间件是一款面向游戏开发.非玩家控制角色实时模拟的领先的人工智能解决方案.Kynapse具有先进的路径查找功能,比如三维路 ...
- 我所遭遇过的游戏中间件--Scaleform
我所遭遇过的游戏中间件---Scaleform Scaleform帮助开发人员利用现代系统的三维硬件加速性能创建电影品质的菜单.游戏内HUD,动画纹理.迷你游戏以及移动游戏与应用.Scaleform作 ...
- 我所遭遇过的游戏中间件--Apex
我所遭遇过的游戏中间件--Apex Apex是PhysX的扩展中间件,它是在PhysX的基础上封装了一层.用于实现布料,粒子,破碎这三种物理效果.我只研究其布料处理.使用Apex做物理最大的好处是:它 ...
- 我所遭遇过的游戏中间件--PhysX
我所遭遇过的游戏中间件--PhysX PhysX现在是Nvidia的物理中间件.其特点是简练且功能强大.当我最初拿到PHYSX的SDK时,就发现这个物理中间件比Havok要小很多,但该有的功能都有,甚 ...
- 我所遭遇过的游戏中间件--Havok
我所遭遇过的游戏中间件--Havok Havok是我接触的第一款游戏中间件,那是在五,六年前,我刚刚毕业,对游戏开发还是个菜鸟.我记得先是对游戏场景中的地形和其他静态物体生成刚体,然后做角色的Ragd ...
- 我所遭遇过的游戏中间件--FlashOcx
使用Flash做游戏界面的另一种方式是通过Abode提供flash.ocx处理Flash界面.将Flash图像通过GDI绘制出来后,再将图像数据拷贝到一个D3D的纹理结构中,最后由引擎的D3D接口进行 ...
随机推荐
- sqoop遇到的问题
我使用的是CDH版本的 这是我的sqoop脚本 sudo -u hive sqoop import --connect jdbc:mysql://xxxx/rom3 --username xxx -- ...
- 基于Apollo实现.NET Core微服务统一配置(测试环境-单机)
一.前言 注:此篇只是为测试环境下的快速入门.后续会给大家带来生产环境下得实战开发. 具体的大家可以去看官方推荐.非常的简单明了.以下介绍引用官方内容: Apollo(阿波罗)是携程框架部门研发的分布 ...
- BZOJ 1975: [Sdoi2010]魔法猪学院 大水题 第k短路 spfa
https://www.lydsy.com/JudgeOnline/problem.php?id=1975 我好像到现在了第k短路都不会写,mdzz. 先spfa求出最短路,然后扫点存各种前置路径已经 ...
- Go语言特点
作者:asta谢链接:https://www.zhihu.com/question/21409296/answer/18184584来源:知乎 1.Go有什么优势 可直接编译成机器码,不依赖其他库,g ...
- [COGS2580]偏序 II
[COGS2580]偏序 II 题目大意: \(n(n\le50000)\)个五元组,求五维偏序. 思路: CDQ分治套CDQ分治套CDQ分治套树状数组. 时间复杂度\(\mathcal O(n\lo ...
- zoj 3229 上下界网络最大可行流带输出方案
收获: 1. 上下界网络流求最大流步骤: 1) 建出无环无汇的网络,并看是否存在可行流 2) 如果存在,那么以原来的源汇跑一次最大流 3) 流量下界加上当前网络每条边的流量就是最大可行流了. 2. 输 ...
- STL 优先队列详解
优先队列是一个保证队列里元素单调的队列,我们可以利用它来维护一个线性结构的单调性. 一般的优先队列: 当然需要加头文件 #include <queue> priority_queue &l ...
- Ajax 的概念及过程?Ajax 的交互模型?同步和异步的区别?如何解决跨域问题?
Ajax 是什么: 1) 通过异步模式,提升了用户体验 2) 优化了浏览器和服务器之间的传输,减少不必要的数据往返,减少了带宽占用 3) Ajax 在客户端运行,承担了一部分本来由服务器承担的工 ...
- Linux重新学习
一.由来 unix到minix到linux 1991正式发行 1.内核版本:linux核心版本 linux内核官网www.kernel.org 2.发行版本:比如redhat.centOS.suse. ...
- BZOJ 1196: [HNOI2006]公路修建问题 Kruskal/二分
1196: [HNOI2006]公路修建问题 Time Limit: 1 Sec Memory Limit: 162 MB 题目连接 http://www.lydsy.com/JudgeOnline ...