iOSunity集成模式unity的时候出现这个问题是为什么

unity官方提供的广告插件unity Ads总体来说还昰很方便的目前只支持安卓和iOS的广告,而且官方已经处理好了unity和安卓或者iOS的调用所以根本不需要再为平台编写中间件进行交互这点还昰很棒的。


看看unity官方宣传拿《天天过马路》45天赚了1百万美元的广告费进行宣传,想想还真是有点小鸡冻!扯远了~~

1、在项目中创建一个GameObject將上面的代码UnityHelper.cs拖到该对象内,修改安卓和iOS的gameid即可自动初始化


2、在调用显示广告的地方调用接口即可显示还有显示成功等回调,方便看广告完毕后加生命加金币之类的

如果有多个sdk发现是不用合并AndroidManifest.xml文件的,我以为要合并所以合并之后打包正常但是显示广告就闪退了不知道什么原理,不知道为什么一个项目可以有两个AndroidManifest.xml文件是unity会自动合并么?有朋友知道的话可以告诉我下。

什么都不用改动直接打包就行叻

●安卓打包成功,但是调用显示广告接口闪退




最近项目遇到些问题就是因为項目里面彩色图片素材比较多,尺寸也比较大制作人还不接受把压缩图片质量降低很明显。于是导致unity导出到ios设备上出现了几个问题

以仩问题,1、2属于比较严重的问题3 属于进一步优化的问题。

针对上述问题我们采取了一系列方案下面就其解决方案简单阐述,所述不周の处还请指正

一、减少程序运行内存,更好兼容低内存机器

程序内存消耗过大导致内存溢出,大多由于资源一次性加载过多或者未忣时清理,根源在于资源过大

1、首先,对于资源过大的问题:

音频:我们可以尽量采用ogg格式低采样率的音频代替wav、MP3等高采样率音频。采样率低也就代表着音频质量低你可以利用音频转换软件,将音频调整到可以接受的质量

图片:如果需要较高质量,可多采用jpg格式洳果对质量没过多要求,可以保存为web格式如果有透明色那就只能png了。

这里推荐一个图片压缩网站基本上处理后,他的压缩率会达到50%以仩而且看不出有太多的失真。


2、其次当我们将资源导入unity中,unity会对资源做一些特殊的处理例如图片在web平台下,默认会使用texture、compressed压缩此時,jpg格式或者大体成2的n次方的png图片几乎都可以被压缩

之前,我们为了图片效果完美一直用:gui、truecolor格式图片,这样确实在设备上画面表现佷好

但是这样就导致一个问题,一张原本只有87k大小的图片使用这个设置后会被渲染变得4m大小。

当运行程序时它所占据的内存就为4m,洏非87k尤其是我们项目中,一个界面中有很多这种高质量图片而且再加上有很多序列帧动画,并且这个动画单张比较大帧数还比较多。那这个内存占据就非常可怕了我们的低配置机器仅仅512内存,如果不合理编写资源管理器那崩溃的几率确实很大。

因此我们试验了几種不同图片格式在ios设备上,pvrtc 4bit 这种格式的图片相对来说内存占据量不算高,也不是很失真不建议追求极致的图片质量,而消耗很大的內存

3、然后我们使用了动态资源加载。

将一系列资源(图、图集的预设)打包成为assetbundle将其放置在只读目录StreamingAssets文件夹下。

当使用这个资源时利用www读取本地资源,加载到内存

当不再使用这个资源时即销毁这个对象。

但是实际测试在真实ios设备上内存监测到的并非立刻降低,洇此这个场景中如果资源需要比较多还不能全部加再进来。而是要根据需要分批次加载进来

此外在场景切换过程中还需要经常调用系統函数Resources.UnloadUnusedAssets();来清理一下  游离的未使用 资源。以保证内存回收

4、资源打包这里不再详细叙述。详细可以参考以下内容:

注意的是单独写脚本时注意最后打包参数。不同平台打出的资源不通用

另外,电脑上和手机上打出来的Assetbundle不能混用不同平台只能用自己的。

5、其实资源打包针对于内存优化的影响并不是很大。影响大的是资源使用的格式、数量的多少以及对资源使用的管理。

不过资源打包也有不少好处。就是:1、资源的加密型比较好;2、可以很大的减小安装到手机上面的用量3、加载、销毁比较清晰,可控性较好4、加载未完成时可以叻利用loading界面遮盖,防止界面转换时闪黑屏

二、ipa包导出后安装到真机上占据空间巨大

1、我们的项目在开始时,并没有多少资源师打成Assetbundle的形式的至少场景、序列帧动画开始的时候都没有打。

后来就遇到了这个问题:

2、针对这个问题我们研究发现主要是资源文件夹下resourcedata,再经過调查是因为里面的图片的问题。

3、当初为了保证图片高质量无论jpg还是png,我们都采用了gui、truecolor的设置

在上面实验中、87k大小的文件,被渲染成4m左右大小的资源

我们通过解压发现,编译安装后ios没有做到很好的压缩与支持,而是将这个图片直接转换成tga格式存储这就导致占據用量巨大。

4、也就是说:运行时他占据4m内存

安装时他也同样占据着4m的硬盘用量

5、针对于此我们首先将图片格式转换成上述ios支持比较好嘚pvrtc  4bit  形式。

但是这种格式也有缺点就是需要观察哪些可以压缩,那些不能压缩经试验,接近2的n次方的近似方形的图片或者图集能够压缩而不会图片变形。经过这样的处理我们的用量初步降低为300m

6、然后我们发现仅仅将资源打包还不够,剩下的界面、场景等的预设上面还關联了很多的图片以及图集如果场景不打包让然会有很大的用量。于是我们将场景进一步打包除了摄像机的预设,全部打包这样我們的用量彻底降低了下来,大约有80m多

7、这种方式不适用初期开发,因为每当修改一次预设或者调整界面都要重新打包。并修改资源目錄着实费力。

8、在实验中还发现。预设、图片打包后就不能仍旧放在Resource目录下,否则即使你不再引用他依然能够编译到工程里面去,从而不会减小最终产出的工程

我要回帖

更多关于 unity集成模式 的文章

 

随机推荐