Unity4.6 UGUI 图片打包设置(小图打包成图集 SpritePacker)

 

 

在学习UGUI的过程中,一直使用小图也就是散图,一个按钮一个图片,一个图标一个图片,这样每一个图片都有一个Drawcall。

 

之前公司的游戏都是使用Unity4.3+NGUI,在NGUI中可以使用Texturepacker,先把小图片打包成一张大图,然后在NGUI中设置引用大图中的哪一块作为图片,这样能减少很多Drawcall。

 

但是在UGUI中没有办法使用Texturepacker了,也迷糊了几天。

 

之后一直在百度谷歌寻找,才发现原来Unity4.6中自带了图集打包工具SpritePacker。

 


 

在Unity4.6中,我们把一张图片拖入到Project中,可以设置它的用途,是Texture还是作为2DUI使用。而且注意到多了一个 Packing Tag的设置项。这个设置项就是设置小图打包成大图后的atlas的名称!

 


 

注意:

 

放在Resources中的图片,Unity不会打包到图集中!

 


 

来看下面的实例:

 

我在界面中放了7个image,每个image是一张不同的图片

 


 

 


 

喜闻乐见的7个Drawcall,7个图片就7个Drawcall,嗯,老板让我明天滚蛋了。

 


 

然后我们来看下如何打开Unity自带的自动的图集打包。

 


 

首先,Unity默认是在编辑器环境下不打开图集打包工具的,只有在Build的时候才会执行自动打包图集。

 


 

Edit - Project Setting - Editor

 

默认为下图设置:

 


 

 


 

我们修改为:

 

 


 

一直启用Sprite Packer,这样我们在编辑器环境下也可以使用自动打包图集。

 

再来运行看下:

 


 


 

嗯?还是7个Drawcall,Unity 坑我们?

 


 

其实不是,仔细再想下,上面提到了 Packing Tag 这个参数,是么有设置的。

 

 


 

既然没有设置 Packing Tag,那Unity应该不知道怎么去打包图集……,因为没有名字嘛。

 


 

我们给这7个图片设置一个名字,例如 test,然后保存Apply,再次运行测试

 

 


 

为什么有两个?Unity坑我们呢!!

 


 

其实不是,是因为这7张图片,有一张图片我放到了 Resources文件夹里面,上面就说道,Resources中的图片Unity是不会打包的哦!

 


 

那么Unity把我们的小图片打包到哪里去了,找不到呀,被吃了吗?我想再看一眼效果怎么办!

 


 

在Unity菜单的Window中有一个 Sprite Packer,我们打开它

 


 

 


 

在这里就可以看到打包的图集。

 


 

左边红框是图集名字,也就是我们设置的 Packing Tag 。

 

第二个是打包的方式,默认打包,还有一种是紧凑型打包 ,两种方式没啥大区别。上面这7张图片用Texturepacker打包后只有512x512大小,但是用Unity的Sprite Packer打包后是1024x512 ……这让人很不解。

 

 

 
 
 
posted @ 2017-11-02 00:47  alps_01  阅读(2627)  评论(0编辑  收藏  举报