对于一名游戏开发者来说,本土化总是不能出现在适当的时候。不管我们是否在一开始进行设置,因为我们认为这是正确的方法,但是紧随其后游戏便遭遇了失败。或者即使游戏表现得不错,我们也必须尝试着明确如何将其放置在之后的过程。我已经将这个问题放在之后的问题集分类中:如果这是你所面对的问题,那么这便是你需要为此花钱去解决的问题。
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开发者如何有效地进行本土化操作
相关文章推荐
-
最受欢迎的游戏引擎集结号:跨平台篇
移动应用分类五花八门,面对众多对手,移动游戏突破重围,成了大家日常生活中的基础娱乐活动之一。也因此,越来越多的开发者开始投身移动游戏的开发中。不过,面对多样化的目标平台,要知道选择一个适合自己的跨平台游戏引擎是一件非常重要的事。所以,本文中例举了除了....
-
别踩白块儿:屌丝逆袭现实版的创业故事
【游戏陀螺8月7日消息】《别踩白块儿》这款手游如今到底有多火?3月底上线AppStore便陆续在全球40多个国家或地区免费游戏榜登顶榜首,超过一百个国家或地区排名前十,5、6月份连续荣登全球游戏下载总榜(iOS+Android)第一宝座,游戏上线3个....
-
爱数据:50%开发者每月收入不到500美元
开发者经济近日发布的《2014年移动开发经济报告》调查了约一万名开发者,结果显示50%的iOS开发者和47%的Android开发者处于应用开发贫困线以下,每月收入不到500美元。这意味着移动开发并不是一个能养家糊口的靠谱行当。以下是开发者APP月收入....
-
微软2016世界开发者大会的十项重要内容
北京时间3月31日消息,据科技网站TheVerge报道,微软世界开发者大会今早在圣弗朗西斯科举办,微软CEO萨蒂亚纳德拉(SatyaNadella)以及windows和设备部门的执行副总裁特里迈尔森(TerryMyerson)向全世界的开发者介绍了微....
-
微信内测微视频 游戏营销或又添新花样
最近,微信开始内测新功能微视频,其产品理念与微视等短视频应用相似,但功能更偏底层工具:1.启动手机摄像头,拍摄6-8秒短视频,在朋友圈内传播;2.没有对其他第三方社交网络,比如微博、QQ空间的分享功能;3.只有最基础的拍摄功能,主题、滤镜、配乐等功能....
-
创业者如何打造一场罗永浩式的产品秀?
我们常听到这样一句话:品牌就是讲故事。的确是这样,无论是看香奈儿、普拉达,还是苹果、小米、锤子、又或者海底捞的服务、雕爷牛腩的500万秘方、薛蟠烤串的内蒙自营牧场,甚至是褚橙的励志故事,我们发现,这些被人们所熟知的品牌背后都有着大大小小的故事,成为人....