游戏是一种很耗费资源的应用,特别是在移动设备中的游戏,性能优化是非常重要的
纹理图集(Texture Atlas)也称为精灵表(Sprite Sheet),它是把许多小的精灵图片组合到一张大图里面。使用纹理图集(或精灵表)有如下主要优点:
减少文件读取次数,读取一张图片比读取一堆小文件要快。
减少OpenGL ES绘制调用并且加速渲染。
减少内存消耗。OpenGL ES 1.1仅仅能够使用2的n次幂大小的图片(即宽度或者高度是2、4、8、64...)。如果采用小图片OpenGL ES1.1会分配给每个图片2的n次幂大小的内存空间,即使这张图片达不到这样的宽度和高度也会分配大于此图片的2的n次幂大小的空间。那么运用这种图片集的方式将会减少内存碎片。虽然在Cocos2d-x v2.0后使用了OpenGL ES 2.0,它不会再分配2的几次幂的内存块了,但是减少读取次数和绘制的优势依然存在。
Cocos2d-x全面支持Zwoptex和TexturePacker,所以创建和使用纹理图集是很容易的。
我们通常可以使用纹理图集制作工具Zwoptex 和TexturePacker帮助我们设计和生成纹理图集文件如下图所示,以及纹理图集坐标文件(plist)组成。
plist是属性列表文件,它是一种XML文件,SpirteSheet.plist文件代码如下:
- <span style="font-size:14px;"><?xml version="1.0"encoding="UTF-8"?>
- <!DOCTYPE plist PUBLIC "-//AppleComputer//DTD PLIST 1.0//EN""http://www.apple.com/DTDs/PropertyList-1.0.dtd">
- <plist version="1.0">
- <dict>
- <key>frames</key>
- <dict> ①
- <key>hero1.png</key> ②
- <dict>
- <key>frame</key>
- <string>{{2,1706},{391,327}}</string> ③
- <key>offset</key>
- <string>{6,0}</string>
- <key>rotated</key>
- <false/>
- <key>sourceColorRect</key>
- <string>{{17,0},{391,327}}</string>
- <key>sourceSize</key>
- <string>{413,327}</string> ④
- </dict>
- ……
- <key>mountain1.png</key>
- <dict>
- <key>frame</key>
- <string>{{2,391},{934,388}}</string>
- <key>offset</key>
- <string>{0,-8}</string>
- <key>rotated</key>
- <false/>
- <key>sourceColorRect</key>
- <string>{{0,16},{934,388}}</string>
- <key>sourceSize</key>
- <string>{934,404}</string>
- </dict>
- … …
- </dict>
- <key>metadata</key>
- <dict>
- <key>format</key>
- <integer>2</integer>
- <key>realTextureFileName</key>
- <string>SpirteSheet.png</string>
- <key>size</key>
- <string>{1024,2048}</string>
- <key>smartupdate</key> <string>$TexturePacker:SmartUpdate:5f186491d3aea289c50ba9b77716547f:abc353d00773c0ca19d20b55fb028270:755b0266068b8a3b8dd250a2d186c02b$</string>
- <key>textureFileName</key>
- <string>SpirteSheet.png</string>
- </dict>
- </dict>
- </plist>
- </span>
上述代码是plist文件,其中代码①~④描述了一个精灵帧(小的精灵图片)位置,第②行代码是精灵帧的名字,一般情况下它的命名与原始的精灵图片名相同。第③行代码描述了精灵帧的位置和大小,{2,1706}是精灵帧的位置,{391,327}是精灵帧的大小。由于我们不需要自己编写plist文件,其它的属性我们就不再介绍了。
使用精灵表文件最简单的方式是使用Sprite 的create (const std::string &filename, const Rect &rect)函数,其中创建矩形Rect对象可以参考坐标文件中第③行代码的{{2,1706},{391,327}}数据。使用create代码如下:
- <span style="font-size:14px;"> auto mountain1 = Sprite::create("SpriteSheet.png",Rect(2,391,934, 388));
- mountain1->setAnchorPoint(Point::ZERO);
- mountain1->setPosition(Point(-200,80));
- mountain1->addChild(mountain1,0);</span>
在创建纹理Texture2D对象,也可以使用精灵表文件,代码如下:
- <span style="font-size:14px;"> Texture2D* cache = TextureCache::getInstance()->addImage("SpirteSheet.png");
- auto hero1 = Sprite::create();
- hero1->setTexture(cache);
- hero1->setTextureRect(Rect(2,1706,391,327)); ①
- hero1->setPosition(Point(800,200));
- this->addChild(hero1,0);</span>
上述代码第①行中的setTextureRect函数,使用坐标文件中描述的数据。
本书交流讨论网站:http://www.cocoagame.net
《Cocos2d-x实战 C++卷》现已上线,各大商店均已开售:
京东:http://item.jd.com/11584534.html
当当:http://product.dangdang.com/23606265.html
互动出版网:http://product.china-pub.com/3770734
《Cocos2d-x实战 C++卷》源码及样章下载地址:
源码下载地址:http://51work6.com/forum.php?mod=viewthread&tid=1155&extra=page%3D1
样章下载地址:http://51work6.com/forum.php?mod=viewthread&tid=1157&extra=page%3D1
相关推荐
在本篇文章中,我们将深入探讨纹理图集和Babylon.js中的精灵管理,以及如何利用它们优化游戏性能。 **纹理图集(Texture Atlas)** 纹理图集是一种资源管理技术,它将多个小的2D图像合并到一个大的单一纹理中。这样...
在Cocos2d-x 3.0及以上版本中,引擎内部的优化使得即使不使用`CCSpriteBatchNode`,也可以有效地管理多个使用相同纹理的精灵,从而自动实现类似`CCSpriteBatchNode`的优化效果。这意味着开发者可以在不牺牲性能的...
Unity中的图集打包是优化2D游戏资源管理的重要手段,它可以将多个小图像合并到一个大纹理中,减少渲染时的Draw Call,提高游戏性能。TexturePacker是一款强大的第三方工具,专为创建高效的图集而设计,广泛应用于...
在Unity项目中,配合优化的图集策略,还可以考虑使用其他技术如Sprite Packer、Unity的Sprite Renderer组件的Sorting Layer和Order in Layer属性来进一步优化渲染顺序,减少不必要的Draw Call。同时,对于不需要同时...
1. **资源合并**:将游戏中分散的精灵图片、帧动画等合并到一个大的纹理图集上,减少了对硬盘和内存的频繁访问,提高加载速度。 2. **九宫格切割**:支持对图集中的图片进行九宫格切割,使得图片在拉伸时保持边角...
TexturePacker是一款强大的图集打包工具,专门设计用于优化2D图形资源的管理,尤其在游戏开发领域,如cocos和Unity3D等游戏引擎。它将多个小图像(精灵)整合到一张大图(图集)中,以提高渲染效率和减少加载时间。...
为了优化内存使用和提高性能,开发者会将多个小图片(帧)组合成一张大的精灵表(Sprite Sheet),也称为纹理 atlas 或纹理图集。 以下是实现这个过程的关键知识点: 1. **纹理图集(Texture Atlas)**:纹理图集...
图集(Atlas)是一种常见的优化手段,它将多个小图片合并到一个大纹理中,减少渲染时的Draw Call,提高游戏性能。TexturePacker是一款强大的第三方图集打包工具,它可以与Unity集成,帮助开发者更高效地管理2D资源。...
5. **优化选项**:该工具还提供了多种优化选项,如裁剪多余空白区域、自动排序以减少内存使用等,有助于提升游戏性能。 6. **H5游戏与手游的适配**:在H5游戏中,使用TexturePacker可以减少HTTP请求次数,提高页面...
- **纹理打包**:工具会根据设定的参数,如格式、压缩方式等,将大图和精灵表打包成易于加载和使用的资源文件。 3. **在游戏开发中的应用** - **性能提升**:减少Draw Call次数,提高渲染效率,降低CPU和GPU负担...
1. **图集打包原理**:图集打包的基本思路是将多个小的精灵图像整合到一个大纹理中,这样在渲染时可以一次性绘制多个精灵,减少GPU切换纹理的次数,从而提高渲染效率。在Unity中,UGUI系统支持自定义图集打包,但...
文件名"3500Font_0.png"很可能是字体图集的图像文件,这种图集通常是以精灵表(Sprite Atlas)的形式存在,将多个小图像(每个代表一个字符)组合在一个大图中,以优化内存使用和渲染效率。在Unity中,你可以通过...
纹理图集(Texture Atlas)是一种在游戏开发和图形渲染领域广泛应用的技术,它允许开发者将多个小的、独立的图像合并到一个大的纹理中,以优化内存使用和渲染效率。`TextureAtlasMaker` 是一个基于 C++ 的小型项目,...
"利用TexturePacker一键打包unity图集"的主题旨在介绍如何借助TexturePacker工具高效地整合和优化Unity项目的精灵(Sprite)资源。这个压缩包包含了TexturePacker的安装文件以及一个实战示例,可以帮助开发者快速...
图集是将多个精灵合并到一个大纹理中,以减少Draw Call(绘制调用)的数量,这是Unity3D中重要的性能优化手段。Draw Call是GPU进行一次渲染操作的指令,过多的Draw Call会导致渲染效率降低。通过图集优化,我们可以...
它能够将这些独立的PNG帧合并到一个大的图集中,这个图集被称为“精灵表”或“纹理图集”。这样做有几个好处: 1. **优化内存**:合成后的图集占用的内存比单独的PNG文件少,因为共享的颜色信息只存储一次。 2. **...
5. **数据导出**:Zwoptex能够生成XML或JSON文件,这些文件包含了纹理图集的详细信息,如精灵位置、大小等。cocos2d引擎能够直接读取这些文件,使得在代码中操作精灵变得简单。 6. **版本控制**:Zwoptex支持版本...
使用NGUI打包图集工具,开发者可以将多个独立的精灵(Sprites)或UI图片合并成一个大的图集文件。这个过程通常包括以下几个步骤: 1. **选择素材**:在Unity编辑器中,你需要先将要打包的图片素材导入到项目中。...
在游戏开发和移动应用设计中,为了优化资源加载速度和内存使用,开发者通常会将多个小图合并成一个大图,即图集(Atlas)。这种技术被称为纹理打包(Texture Packing),常用的打包工具如TexturePacker可以将多个...