PS2纹理贴图编码算法A1B5G5R5

上一篇文章里我们介绍了PS2使用的图片压缩算法RLE,这次我们再来研究一下它的纹理贴图编码算法------A1B5G5R5

对于纹理来说,常用的图片编码格式如jpgpng都不适合。因为图片是由GPU读取并进行渲染的,你总不能送过去一张jpg图片,让GPU要读取其中一个像素的时候,先把整个图片解码吧?因此最理想的图片格式是未经压缩的位图格式,可以根据像素点坐标直接获取RGB数据。今天要介绍的A1B5G5R5正是这种编码格式之一。

标准的32位位图,每个像素占用4字节数据,分别为RGBA四个通道。拿上面这两个纹理图片来说,它们的像素数量都为128x128,因此图片大小为128x128x4字节。

上图为32位RGBA每像素数据结构。

对于A1B5G5R5编码来说,每个像素占用2字节数据,其中alpha通道占用1位,其它3种颜色各占5位

上图为A1B5G5R5每像素数据结构。

A1B5G5R5解码为32位RGBA可以用下图的方法进行。

伪代码如下:

python 复制代码
while tex_offset < len(self.texture):
    b = tex_struct.unpack_from(self.texture, tex_offset)[0]
    out[rgb_tex_offset] = (b & 0x1F) << 3 # R
    out[rgb_tex_offset + 1] = ((b >> 5) & 0x1F) << 3 # G
    out[rgb_tex_offset + 2] = ((b >> 10) & 0x1F) << 3 # B
    rgb_tex_offset += 3
    tex_offset += tex_struct.size

很明显可以看到,将32位RGBA图片编码成16位A1B5G5R5,会丢失每种色彩的最后3个bit数据,是一种有损编码格式,但带来的好处是压缩比2:1,图片缩小了一半。再配合上一篇讲到的RLE编码,可以进一步缩小图片大小。

最后放上上面两个纹理图片渲染后的效果,有小伙伴还记得这两个游戏吗?

本篇文章使用的代码和图片摘自我的一个github项目:ps2mc-browser,欢迎大家添砖加瓦。

相关推荐
CoovallyAIHub5 小时前
Moonshine:比 Whisper 快 100 倍的端侧语音识别神器,Star 6.6K!
深度学习·算法·计算机视觉
CoovallyAIHub6 小时前
速度暴涨10倍、成本暴降6倍!Mercury 2用扩散取代自回归,重新定义LLM推理速度
深度学习·算法·计算机视觉
CoovallyAIHub6 小时前
实时视觉AI智能体框架来了!Vision Agents 狂揽7K Star,延迟低至30ms,YOLO+Gemini实时联动!
算法·架构·github
CoovallyAIHub6 小时前
开源:YOLO最强对手?D-FINE目标检测与实例分割框架深度解析
人工智能·算法·github
CoovallyAIHub6 小时前
OpenClaw:从“19万星标”到“行业封杀”,这只“赛博龙虾”究竟触动了谁的神经?
算法·架构·github
刀法如飞7 小时前
程序员必须知道的核心算法思想
算法·编程开发·算法思想
徐小夕8 小时前
pxcharts Ultra V2.3更新:多维表一键导出 PDF,渲染兼容性拉满!
vue.js·算法·github
CoovallyAIHub9 小时前
OpenClaw一脚踩碎传统CV?机器终于不再只是看世界
深度学习·算法·计算机视觉
CoovallyAIHub9 小时前
仅凭单目相机实现3D锥桶定位?UNet-RKNet破解自动驾驶锥桶检测难题
深度学习·算法·计算机视觉
zone77399 小时前
002:RAG 入门-LangChain 读取文本
后端·算法·面试