对于一名游戏开发者来说,本土化总是不能出现在适当的时候。不管我们是否在一开始进行设置,因为我们认为这是正确的方法,但是紧随其后游戏便遭遇了失败。或者即使游戏表现得不错,我们也必须尝试着明确如何将其放置在之后的过程。我已经将这个问题放在之后的问题集分类中:如果这是你所面对的问题,那么这便是你需要为此花钱去解决的问题。
Localization(from agencypost)
最近我参与了一个为本土化提供资金的项目,我们的任务比想象中复杂得多。虽然存在一种简单的方法,但却没有什么好的建议,所以这个任务暂时被搁置了。是使用unity获得了整个资产渠道,但是获得游戏翻译仍然不是件简单的工作。我仍然需要完成我的资源,资产以及关于文本的所有场景搜索,然后对它们进行重组并参考一些实用内容从而给予当前语言的相关翻译。我知道自己可以做得更好,对吧?
在Transfluent我认识了Jani,对于使用一种工具而更轻松地利用unity的资产渠道获得游戏翻译这一点我们具有类似的想法。他已经通过获得一个基本的编辑翻译工具而完成了第一传。因为它遭遇了许多第二层和第三层问题,所以第一传是非常好的出发点。然而,与许多unity图形用户界面编辑窗口一样,即时模式的使用将会以某种方式倒向代码结构并倾向于创造好几千行内容的文件。所以这是推动我们吸取某些教训的一个很好的起点。
本土化的障碍:
1.提取文本并将其放在数据储存区进行翻译
2.删除任何关于文本的简单引用(在场景和预制件中)并用纯粹的脚本控制文本进行替代
3.基于某种形式用字符串替代任何串并置(“hello”+“world”)以及动态文本(如来自用户“hello there”+用户名的文本)
4.重新将储存于数据储存区的文本整合到你所选择的UI解决方法中
5.找到一种方法去使用翻译器翻译你的数据—-这通常包含进入“蓝屋”(如:不创造一款游戏)
6.检查你的游戏是否已经翻译了所有内容—-使用一种你懂的“外语”并且仍然能够用于导航至各种理想选择。例如:Facebook的“英语(盗版)”https://www.facebook.com/settings?section=language
7.在发现短语未翻译时获得新的翻译内容
什么是正确的:
1.隐藏unity的所有OnGUI和GUILayout功能。这有时候看似疯狂,但这将以创造一个非常简单的方法去获得一个带有许多静态文本且能够更快速地进行翻译的UnGUI游戏告终。也许还有些功能较为模糊,就像输入内容是否应该是自动翻译的,但只要那些内容属于异常情况,这便能够帮助你轻松地翻译游戏。
2.对textmeshes,场景和预制件进行资产扫描。它将找到你的文本并对其进行翻译。我认为GameSpecificMigration中的黑名单机制可以得到完善。
3.简单的储存格式。最初,我将数据格式与专用格式绑定在一起,认为这么做会方便许多。ScriptableObjects是并未存在于场景中的基本游戏对象。它们将在运行时间中获得同意的优化,并在与别人合作时呈现出YAML合并友好型特质。确保界面就像一本简单的词典,并且在处理之后出现的各种简单任务上允许更多灵活性的出现。
4.“逆向”语言—-这是检查你的游戏的一种简单的方法,以此确保你能够翻译自己所作出的大多数决定。
5.“捕获模式”—-能够贯穿你的游戏而运行,作为一种寻找资源翻译的方法,而不是从代码中将文本复制到翻译数据库,这似乎比较不容易出错且更容易更新。你也可以选择其它方法,但这种模式能够带给你帮助。
6.编辑窗口逻辑/视图分离。拆分“视图”逻辑,就像通过“应用”逻辑呈现文本,如上传,命令翻译。基于strangeioc的中介模式(http://en.wikipedia.org/wiki/Mediator_pattern),我越来越习惯这种方法。是否想要上传你自己完成的新翻译内容?当然。那么在编辑窗口呢?也要。
7.测试—-测试能够帮助我避免沉浸于某些愚蠢的内容,如脱机以及计划停运。它们将帮助我在前进的过程中核实设计和数据格式,因为如果我不能单独测试它,它便很容易崩溃。尽管我以前使用过nunitlite,不过Unity的测试工具刚刚出现,并且是一个很棒且较为完善的工具,基于Jenkins(游戏邦注:是基于Java开发的一种持续集成工具,用于监控秩序重复的工作),我能够自动操作测试,从而在代码损坏某些内容时立即获得反馈。
未知:(例如“已知的未知”)
1.基于OnLocalize支持的运行时间。显然我们需要一种方法去告知代理语言发生了改变,所以我决定使用Unity向客户发送信息。这并不是我经常做的某些事,但却是我发现其它类似的中间件成功使用过的一种模式。
2.标记化。我认为这将以积极的结果告终,而这更多地取决于KISS原则的功劳。最简单的解决方法只是隐藏字符串。格式以及在“Hello,{0}”格式中使用字符串看似是最正确的方法。事实证明,关于翻译存在许多细微差别,可能会让屏幕截图变得更有效(也有可能变得更糟糕)。
未来的工作:
1.编辑器的支持。翻译你的编辑工具EditorGUILayout和EditorGUI似乎是有效的。我认为所有需要完整的本土化编辑工具的内容在某种程度上都将连接隐藏的editorguilayout和editorgui与一个特定的TranslationUtilityInstance。我不认为这具有挑战性,但是我也不确定是否真的需要这样的内容。
2.确保文本“看起来”是合理的,并且如果翻译内容需要提前运行的话,提供给翻译器一个更棒的提示。这与在获取模式中发送屏幕截图一样简单。
3.更深入的整合—-支持在各种框架上自动换行以及规格调整。
4.支持更多UI框架—-它们带有许多相关联的不同挑战。
5.中间件整合—-整合搭配fungus和其它工具链意味着能够更轻松地创造游戏。拥有像fungus以及其它故事/游戏创造支持工具真的很酷。
6.更多资产扫描。创造更多支持自动转移的文本。思考:本土化playmaker文本。资产扫描器的设置是为了帮助解决编辑器脚本撰写的粘滞位问题,ICustomProcessors只是处理GameObjects将功能延伸向全新的脚本类型。
随着越来越多人使用工具,我们的目标便是根据新识别的用例而继续完善它。
|
Unity开发者如何有效地进行本土化操作
相关文章推荐
-
利用外部渠道引流提高APP下载量转化率的5个方法
不同渠道的搭配组合,给APP下载量提升不少转化,带来不少流量。前段时间,我和几位大咖一块探讨流量引入的相关问题,下面我简单整理一下关于外部引流的几个相关重点。注意一点,做转化率一般的周期为3个月,才能有较明显效果,因此,在这个很长且很复杂的过程中,提....
-
移动平台引领移动互联网变革
导语:2014年是移动互联网高速发展的一年,互联网企业、创业企业和传统企业纷纷认识到移动互联网巨大的商业价值、无限的可能性,技术要素上升到了前所未有的战略高度。2014年是移动互联网高速发展的一年,互联网企业、创业企业和传统企业纷纷认识到移动互联网巨....
-
App Store应用僵尸化:没品质没资本的必然走向
随着Adjust指出AppStore存在数以百万的僵尸应用(号称占比83%,如图1所示),一个更真实的认知也再次被强化:AppStore的应用下载环境比放之四海皆准的二八法则更严苛,在这里F2P应用为了一点曝光空间需要挤得头破血流,而那些预先付费的P....
-
APP和下载通道遭封杀 互联网盒子们遭关闭
小米盒子、乐视盒子、天猫魔盒等互联网机顶盒如今成为风靡客厅的必备品。通过这些软件,用户可以在电视机上随意浏览视频App上的海量内容。不过,近日,盒子们遭到了整顿。6月24日消息,国家新闻出版广电总局网络司近日针对互联网电视牌照商,下发了关于立即关闭互....
-
数据显示国内市场手游多达1万余款 92%正在亏损
据易观智库发布的最新数据预计,今年,我国移动游戏市场规模或将达到237.56亿元,2015年将达到338.43亿元,2016年整个市场规模将超过427亿元。巨大的市场前景不仅让各互联网巨头加大对这部分业务的投入,正在四处寻求机会的手游小团队也如飞蛾扑....
-
个人开发者低成本推广APP的18条技巧
手游的成功性现在看来偶然性很强,游戏品质永远是第一位的,但成功的游戏背后是否都有某些共同之处呢?在成千上万款游戏当中,那些品质很高的成功游戏,又是怎么被用户所知道的呢?现在市面上充满了大牌子大公司和大制作的手机游戏,经常有游戏花300万成本开发,然后....