TextMeshPro备用字体疑问

news/2024/7/20 22:18:59 标签: ios, Audio, text, Rendering, Texture

1)TextMeshPro备用字体疑问
​2)iOS的部分语言的float分隔符变成了逗号
3)ASTC格式支持与官方文档不符
4)关于音效背景音乐的音频文件的格式设置请教
5)LightProbe的信息位置


这是第269篇UWA技术知识分享的推送。今天我们继续为大家精选了若干和开发、优化相关的问题,建议阅读时间10分钟,认真读完必有收获。

UWA 问答社区:answer.uwa4d.com
UWA QQ群2:793972859(原群已满员)

Text

Q:TextMeshPro设置的Fallback “字体B”, 文本字体是“字体A”,如果文本显示的字符都是字体A的,CPU会不会收集字体B的贴图信息数据发送给GPU用来渲染?

不是很理解这个Fallback字体,发现字体A、字体B都在内存中,也就是说其实都是关联上的。是不是所有的后备字体都会在内存中出现?

A:问题一:TMP中所谓Fallback,也就是后备字体,其含义在于当实际使用中出现了当前字体所不支持的字符时,按照:主字体(也就是当前字体)、主字体的后备字体、后备字体的后备字体、通用后备字体、通用后备字体的后备字体、通用默认字体、通用默认字体的后备字体等等的序列遍历所有设置的后备字体,直到找到能够支持的字体为止。

所以,引擎只有在内存中保留Fallback字体资源,才能在当前字体无法显示所有字符时采用Fallback字体。问题中提到的字体B也在内存中是合理的。

当然,如果开发者能确定字体A可以支持项目中出现的所有字体,那么完全可以检查Project Settings中全局的Default Font Asset、全局的Fallback Font Assets List、字体A的Fallback Font Assets,以上三处设置为空,则可以一定程度上节省内存。

问题二:我补充做了实验。对照情况是用某一种主字体显示“New Text”这一串字符,显然足够支持、而内存中也只有该主字体。然后在刚才提到的主字体的后备字体、后备字体的后备字体、通用后备字体、通用后备字体的后备字体、通用默认字体、通用默认字体的后备字体这个序列的每个环节加上不同的字体,显然它们没有被实际用到,但都进入内存了。List里面有几种字体也是一样。

感谢Faust@UWA问答社区提供了回答,欢迎大家转至社区交流:
LightProbe的信息存在哪儿? -- UWA问答:帮助开发者找到更好的答案


iOS

Q:最近我们打包的时候发现,在iOS设备上,部分语言的小数的分隔符变成了逗号,比如俄罗斯语。后来发现是因为CurrentCulture变成了设备的语言,Android和之前的iOS设备都是en-US,也就导致了读取配置时用float.TryParse会转换失败。

我们的Unity版本是2018.4.33,目前还没有定位是什么原因导致的,不知道有没有人碰到过?如果在游戏启动时强制把CurrentCulture改成英语不知道可不可行?

A:我们项目踩过这个坑,原因就是一些语言里面小数点分隔符不一样,比如法语里分隔符是逗号,属于文化差异。解决方案是游戏启动时设置CurrentCulture为CultureInfo.InvariantCulture:

CultureInfo.DefaultThreadCurrentCulture = CultureInfo.InvariantCulture;
CultureInfo.DefaultThreadCurrentUICulture = CultureInfo.InvariantCulture;
Thread.CurrentThread.CurrentCulture = CultureInfo.InvariantCulture;
Thread.CurrentThread.CurrentUICulture = CultureInfo.InvariantCulture;

参考链接:CultureInfo.InvariantCulture

感谢张迪@UWA问答社区提供了回答,欢迎大家转至社区交流:
LightProbe的信息存在哪儿? -- UWA问答:帮助开发者找到更好的答案


Texture

Q:ASTC格式支持与官方文档不符,根据官方文档(Unity - Manual: Recommended, default, and supported texture compression formats, by platform)。理论上我们的测试机中,红米2是不支持的ASTC格式的。但实际测试中发现,它是支持的。这是怎么一回事?

text-align:center;">

A:之前做过相关的测试,红米2(Adren 302)是支持ASTC的,但红米Note2(PowerVR Rogue G6200)是不支持的。并且从Unity 2017.4的Profiler中可以看到纹理的大小是正确的。

这和官方提供的:tvOS (all), iOS (A8), Android (PowerVR 6XT, Mali T600 series, Adreno 400 series, Tegra K1)不符。

从目前的测试来看,可以认为实际支持情况和文档提供的GPU型号并不完全一致。在不支持的机型上会软解成RGBA32或RGB24,实际内存也是一样。

感谢OCEAN@UWA问答社区提供了回答,欢迎大家转至社区交流:
LightProbe的信息存在哪儿? -- UWA问答:帮助开发者找到更好的答案


Audio

Q:在UWA的报告中看到要用Streaming的方式读取音频。想问一下关于音频格式,有优化角度比较全的建议吗?

text-align:center;">

之前项目里的设置大概是这样子的,合适吗?大家常见的做法是怎样的?有没有一个相对合理的经验值,比如10s的音效大小在100KB这样的参考值?

text-align:center;">

A:并不推荐使用MP3播放音乐,原因是使用MP3制作素材会无法避免在循环点引入空白音频,参见:Is it possible to loop MP3 without gaps? - Sound Design Stack Exchange

之前使用过类似于MP3Loop的小工具,但是编码质量也无法控制,最后选择用Ogg(Vorbis)一了百了。

早一些的开发者(1990-2000年前后)会采用MIDI,但MIDI只是记录音乐信息用的格式,实际发声取决于所使用的音源,而音源设计通常会倾向于大而全所以为了有限的MIDI音乐加载完整的音源也会造成资源冗余。

关于PCM或者ADPCM,通常被称为WAV及“三分之一的WAV”,可以根据音效具体内容来决定优化策略,有一个概念需要了解——奈奎斯特采样定理。

简单讲,如果一个声音比较低沉,那么可以适当降低采样率来提升PCM或者ADPCM的“压缩比”,这样可以既保留PCM/ADPCM的低功耗和快速响应,又降低资源占用。假设一个声音比较明显的能量都分布在4000hz之下,那么只需要8000hz的采样率就可以非常好的记录及还原这个声音了。

事实上Unity原声音频最理想的音乐格式是Tracker Module,只是国内开发者了解Demo Scene的比较少,音乐创作者为此类格式创作的经验也非常稀少。

这里贴一个Tracker音乐的外网视频连接,大家可以听一下看看会不会唤起一些童年回忆:https://www.youtube.com/watch?v=gHQYYh7J1O4

翻译了Unity官方十一年前的一篇Blog:《.mod in Unity》
文章的中文翻译可以戳原问答查看。

几个常用Tracker音乐制作软件的网站链接:OpenMPT,MilkyTracker,schismtracker。有兴趣的朋友可以尝试一下用这种古老的格式创作音乐,可以做到既不牺牲音质也不占用多少空间。

关于进一步的音频优化技巧,个人比较推荐刷一遍Wwise的251认证课程内容,免费而且实际上都是些通用的技巧:Courses

感谢Icarus@UWA问答社区提供了回答,欢迎大家转至社区交流:
LightProbe的信息存在哪儿? -- UWA问答:帮助开发者找到更好的答案


Rendering

Q:场景中的LightProbe信息是保存在lightingData.asset文件中吗?

A1:如果要保存,可以考虑这样存:
AssetDatabase.CreateAsset(Instantiate(LightmapSettings.lightProbes), “Assets/lightProbe.asset”);

感谢萧小俊@UWA问答社区提供了回答

A2:不确定,lightingData.asset中主要存放Lightmap的对应关系,但LightProbe是否也在里面就不确定了。

感谢OCEAN@UWA问答社区提供了回答

A3:对于LightProbes更多的操作可以参考这篇文章:《聊聊LightProbe原理实现以及对LightProbe数据的修改》

感谢Xuan@UWA问答社区提供了回答,欢迎大家转至社区交流:
LightProbe的信息存在哪儿? -- UWA问答:帮助开发者找到更好的答案

20210927
更多精彩问题等你回答~

  1. Vulkan API的性能及兼容性
  2. Unity TMP字体方案如何选择
  3. 如何实现AAB包的增量更新

封面图来源于网络


今天的分享就到这里。当然,生有涯而知无涯。在漫漫的开发周期中,您看到的这些问题也许都只是冰山一角,我们早已在UWA问答网站上准备了更多的技术话题等你一起来探索和分享。欢迎热爱进步的你加入,也许你的方法恰能解别人的燃眉之急;而他山之“石”,也能攻你之“玉”。

官网:www.uwa4d.com
官方技术博客:blog.uwa4d.com
官方问答社区:answer.uwa4d.com
UWA学堂:edu.uwa4d.com
官方技术QQ群:793972859(原群已满员)


http://www.niftyadmin.cn/n/1030647.html

相关文章

支持资源加载分析、场景分割

GOT Online 又双叒叕更新啦,新版本中我们对Resource、Overview等多个模式的使用做了优化,不仅交互界面更加人性化,功能也更加强大。为了便于大家充分使用该服务,今天我们对这些新特性做下介绍: 加载模块是我们最为关注…

使用Sprite Packer对UI图集进行打包的问题

1)使用Sprite Packer对UI图集进行打包的问题 ​2)Unity处理视锥剔除的问题 3)Profiler查看Shader.CreateGPUProgram的具体Shader信息 4)PPS的UberPost内存占用较高 这是第270篇UWA技术知识分享的推送。今天我们继续为大家精选了若…

Unity中Compute Shader的基础介绍与使用

前言 Compute Shader是如今比较流行的一种技术,例如之前的《天刀手游》,还有最近大火的《永劫无间》,在分享技术的时候都有提到它。 Unity官方对Compute Shader的介绍如下:Unity - Manual: Compute shaders Compute Shader和其他…

Unity引擎UI模块知识Tree

Unity引擎在4.6版本之前是没有内置的UI解决方案的。当时最流行的就是NGUI的框架,目前主流的UI解决方案就是NGUI和UGUI,近几年来,更是以UGUI为主,同时也有团队开始使用FairyGUI。 本文整理的内容会以UGUI为主,当然也会…

Shader打AssetBundle包变体丢失问题

1)Shader打AssetBundle包变体丢失问题 ​2)Unity升级后在iOS平台的贴图导入问题 3)字体文件AssetBundle包崩溃 4)给主相机设置RT的注意事项 5)FBX的导入WeldVertices的设置问题 这是第271篇UWA技术知识分享的推送。今天…

新的启程 | 我们的昨天、今天和明天

今年是UWA创业的第七年,我们获得了一笔数千万人民币A轮融资,本轮融资投资方为Game Trigger(游戏扳机),光源资本担任独家财务顾问。 对于侑虎人来说,这是一个意义非凡的里程碑,意味着这些年来的…

Wwise音频引擎的入门指南

让我们假设这样一个场景——设计师主导 项目想要在游戏的音频方面进行一些提升,听说Wwise是非常好的工具。然而无论是设计师还是程序员,都不是非常了解如何使用。这时候项目希望设计师能够主导Wwise的接入,但设计师可能是一个一直以来醉心于线…

AssetBundle异步加载被中断的问题

1)AssetBundle异步加载被中断的问题 ​2)LuaDLL.lua_pcall()自身产生开销问题 3)法线在手机渲染时出现的错误问题 4)UNITY_MATRIX_I_V 和Camera.main.worldToCameraMatrix.inverse区别 这是第272篇UWA技术知识分享的推送。今天我们…