Unity游戏界面解决方案: PSD For UGUI

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
简介:

流程演示

1、在PhotoShop中解析PSD文件,生成图层图片,PSD结构信息Json文件以及资源列表Xml文件。
2、在Unity中生成面板资源图集和面板Prefab。

UWA Tech Doc
(PSD4UGUI操作流程演示)


设计初心

在游戏开发过程中界面系统需求变化频繁,牵涉到人员最多,从项目长期各系统开发、维护所占时间统计来看,界面系统所占时间是最多的。界面系统开发中界面资源的制作过程中存在两大糟点:

1、开发人员根据美术的设计在Unity中通过对坐标、调颜色等操作复现美术的设计,这步存在大量的没有技术含量的机械性劳动。

2、当第1步中开发人员实现的效果和美术设计存在偏差时,必然需要美术和开发人员的沟通,并且解决存在的偏差,这步带来沟通成本。

这两步效率低,影响了游戏的开发效率,甚至影响游戏品质。笔者通过学习、总结,开发出这个从PSD文件直接生成Unity中Prefab资源的流程,该流程可以高保真的在Unity中复现美术设计,减少沟通,提高游戏整体研发效率。


GUI开发本质

要理解PSD4UGUI流程,首先需要充分理解GUI开发本质。GUI开发可以分成3步:

1、设计阶段(Design)
2、结构化(Structuring)
3、绑定(Binding)

设计是指根据业务需求实现面板的视觉效果。结构化是指将设计好的面板划分功能单元,比如哪里是一个容器,哪里是一个按钮。绑定是指根据业务需求编写逻辑代码使界面元素产生各种交互。其中设计无疑是由美术完成,绑定无疑是由开发完成。结构化是GUI开发过程中在Unity中复现美术设计的一步,是效率比较低的一步。现有的一些解决方案:

1、手动拼界面
开发手动将PSD文件中图层输出,导入到Unity中,通过对坐标、调颜色等操作复现美术设计。这个方法效率低,容易出现位置或颜色偏差,且开发人员不愿意做这种低效的操作。

2、使用界面编辑工具
这个方法需要开发、维护界面编辑工具,这可能需要大量的额外工作,工具的体验是否能做好,相关人员是否愿意使用都是问题。

3、专人拼界面
因为不同人员的思维方式差异,这种方法会引入额外的沟通环节,降低工作效率,并且可能成为流程上的瓶颈。

结构化是划分界面上功能单元的过程,划分功能单元的过程其实是开发对界面功能抽象-分解的过程,是连接绑定的重要步骤,所以结构化的工作本质上应该由开发完成。


PSD4UGUI流程简介

PSD4UGUI流程中将PhotoShop作为界面编辑器,在PSD文件中通过调整图层的结构和名称来完成结构化的工作。
UWA Tech Doc
(使用调整图层结构和名称完成结构化工作)

如上图所示,使用图层名称表示组件的类型、名称以及参数,如Button_arrane_shrink,其中Button是类型,arrane是实例名,shrink是参数,这些字段在图层名称中使用“_”分割,同时也支持多参数。使用图层结构表示组件的相互包含关系,在图上红框中名为btnContainer的Container组件包含有名为arrane、polish、divide的3个Button组件,其中arrane的Button组件中包含有名为label的Label组件,名为image的Image组件。其中图片(Image)和文本(Label)为原子组件,其他组件都是复合组件,复合组件有其他组件组合而成,如按钮(Button),容器(Container)等组件。


PSD4UGUI流程优势

在游戏业务情境(Context)下,提供了一种使美术人员在设计阶段就可以完成绝大部分结构化工作的方法。游戏界面业务系统的特点:

1、界面组件类型少。
2、界面组件重用度高。

美术在创建、设计游戏界面的时候存在着资源重用库,通过简单的复制、粘贴重用库资源,就可以完成界面设计。在美术和开发配合过程中,开发将美术资源重用库结构化弄好,美术制作的时候通过从资源重用库中完整的复制、粘贴结构化好的组件来创建新面板,这样一来,在设计阶段即可完成大部分结构化工作。这样开发拿到美术完成设计的Psd文件后只要进行少量的图层结构、名称调整工作即可快速的完成整个界面的结构化工作。


PSD4UGUI流程技术细节

1、PSD文件解析脚本:使用Photoshop ActionManager接口编写的Jsx脚本可以快速的解析PSD文件,解析生成Json、图层图片及资源列表Xml文件。

PSD文件解析脚本
UWA Tech Doc

PSD文件解析结果Json文件
UWA Tech Doc

资源列表Xml文件
UWA Tech Doc

2、Unity中生成图集和Prefab工具

根据PSD文件解析生成的图片资源和Json信息自动生成图集和Prefab,其中Prefab的结构和PSD中的结构一致。

生成图集并分离Alpha通道
UWA Tech Doc
生成Prefab
UWA Tech Doc

3、根据游戏业务定制的基础组件库。如在游戏业务中常见但是UGUI库中不存在的列表(List)组件。


PSD4UGUI技术优势

1、封装
提供常用的业务组件,封装图集制作,公共图集管理等底层细节,使开发只需专注上层业务,提高游戏开发效率。

2、内存
整合以下机制可以减少游戏内存使用量:

a.图集Alpha通道分离
b.便利的公共图集制作、管理、调整流程
c.局部图集合并设置
d.通过图片变色、镜像翻转、旋转等方式减少图片使用量
e.通过设定参数即可自动生成九宫图片,优化九宫图片面积
f.通过分割图片来优化生成的图集面积
g.通过设置图片输出缩放参数,可以方便的取得图集面积和显示效果的平衡
h.剔除图片低透明度区域,减少图集面积。

3、CPU
通过hide,deferred等参数可以在创建Prefab时隐藏界面上的元素,减少界面加载进游戏时的SetActive和AddComponent的调用次数,延迟初始化相关元素,可以优化界面首次打开时的卡顿感。

4、GPU
通过剔除图片的低透明区域,可以减少OverDraw,提高渲染效率。

5、换皮
在游戏开发中界面整体换风格比较常见,在PSD4UGUI中只需美术修改PSD中资源并保持结构不变,重新生成图集和Prefab即可完成。提供PSDDiff工具检查前后结构是否一致。


PSD4GUI在多语言版本制作中的优势

多语言制作过程中界面相关的调整工作主要包括两部分:
1、文字配置
2、图片化文字

传统做法的中文字配置通常是通过在代码中读取文字的配置id来实现,这个过程需要在逻辑代码中写相关代码,有额外的工作量,不同语言表达相同意思时字符的长度可能不一样,解决不同长度文本长度兼容性问题比较麻烦。图片化文字,传统做法将图片调整为动态加载,游戏运行时根据不同的语言设置加载不同语言的资源,修改成外部加载需要额外的工作量,维护图集也有额外的工作量。本质上传统的做法是一套资源兼容不同的语言,兼容的过程必然存在妥协,某些时候会牺牲产品的品质。并且这种做法对开发强依赖,可能形成流程上的瓶颈,拖累游戏的研发整体进度。

PSD4UGUI流程中通过在PSD中配置文本内容id参数即可完成文本配置过程。
UWA Tech Doc
(PSD文件中配置文本内容id)

UWA Tech Doc
(多语言标签)

通过多语言标签,隔离不同语言版本的资源。生成图集和Prefab时根据语言设置生成不同语言版本的图集和Prefab资源。PSD4UGUI流程本质上为不同语言生成不同版本的资源,从根本上就不存在兼容性的问题了,并且所有操作都集中在Psd文件中,策划、美术人员也可以很方便的参与多语言版本开发过程,使多语言版本开发流程对开发弱依赖,有利于提高工作效率。


劣势

1、条条框框较多,有一定的学习成本,其中开发人员理解GUI开发本质,开发人员应该在流程中起主导角色是关键。
2、开发人员对PhotoShop的抗拒心理。





原文出处:侑虎科技
转载请与作者联系,同时请务必标明文章原始出处和原文链接及本声明。

目录
相关文章
|
4月前
|
图形学 C#
超实用!深度解析Unity引擎,手把手教你从零开始构建精美的2D平面冒险游戏,涵盖资源导入、角色控制与动画、碰撞检测等核心技巧,打造沉浸式游戏体验完全指南
【8月更文挑战第31天】本文是 Unity 2D 游戏开发的全面指南,手把手教你从零开始构建精美的平面冒险游戏。首先,通过 Unity Hub 创建 2D 项目并导入游戏资源。接着,编写 `PlayerController` 脚本来实现角色移动,并添加动画以增强视觉效果。最后,通过 Collider 2D 组件实现碰撞检测等游戏机制。每一步均展示 Unity 在 2D 游戏开发中的强大功能。
224 6
|
4月前
|
图形学 缓存 算法
掌握这五大绝招,让您的Unity游戏瞬间加载完毕,从此告别漫长等待,大幅提升玩家首次体验的满意度与留存率!
【8月更文挑战第31天】游戏的加载时间是影响玩家初次体验的关键因素,特别是在移动设备上。本文介绍了几种常见的Unity游戏加载优化方法,包括资源的预加载与异步加载、使用AssetBundles管理动态资源、纹理和模型优化、合理利用缓存系统以及脚本优化。通过具体示例代码展示了如何实现异步加载场景,并提出了针对不同资源的优化策略。综合运用这些技术可以显著缩短加载时间,提升玩家满意度。
302 5
|
3月前
|
测试技术 C# 图形学
掌握Unity调试与测试的终极指南:从内置调试工具到自动化测试框架,全方位保障游戏品质不踩坑,打造流畅游戏体验的必备技能大揭秘!
【9月更文挑战第1天】在开发游戏时,Unity 引擎让创意变为现实。但软件开发中难免遇到 Bug,若不解决,将严重影响用户体验。调试与测试成为确保游戏质量的最后一道防线。本文介绍如何利用 Unity 的调试工具高效排查问题,并通过 Profiler 分析性能瓶颈。此外,Unity Test Framework 支持自动化测试,提高开发效率。结合单元测试与集成测试,确保游戏逻辑正确无误。对于在线游戏,还需进行压力测试以验证服务器稳定性。总之,调试与测试贯穿游戏开发全流程,确保最终作品既好玩又稳定。
167 4
|
3月前
|
前端开发 图形学 开发者
【独家揭秘】那些让你的游戏瞬间鲜活起来的Unity UI动画技巧:从零开始打造动态按钮,提升玩家交互体验的绝招大公开!
【9月更文挑战第1天】在游戏开发领域,Unity 是最受欢迎的游戏引擎之一,其强大的跨平台发布能力和丰富的功能集让开发者能够迅速打造出高质量的游戏。优秀的 UI 设计对于游戏至关重要,尤其是在手游市场,出色的 UI 能给玩家留下深刻的第一印象。Unity 的 UGUI 系统提供了一整套解决方案,包括 Canvas、Image 和 Button 等组件,支持添加各种动画效果。
170 3
|
3月前
|
设计模式 存储 人工智能
深度解析Unity游戏开发:从零构建可扩展与可维护的游戏架构,让你的游戏项目在模块化设计、脚本对象运用及状态模式处理中焕发新生,实现高效迭代与团队协作的完美平衡之路
【9月更文挑战第1天】游戏开发中的架构设计是项目成功的关键。良好的架构能提升开发效率并确保项目的长期可维护性和可扩展性。在使用Unity引擎时,合理的架构尤为重要。本文探讨了如何在Unity中实现可扩展且易维护的游戏架构,包括模块化设计、使用脚本对象管理数据、应用设计模式(如状态模式)及采用MVC/MVVM架构模式。通过这些方法,可以显著提高开发效率和游戏质量。例如,模块化设计将游戏拆分为独立模块。
221 3
|
4月前
|
图形学 开发者 存储
超越基础教程:深度拆解Unity地形编辑器的每一个隐藏角落,让你的游戏世界既浩瀚无垠又细节满满——从新手到高手的全面技巧升级秘籍
【8月更文挑战第31天】Unity地形编辑器是游戏开发中的重要工具,可快速创建复杂多变的游戏环境。本文通过比较不同地形编辑技术,详细介绍如何利用其功能构建广阔且精细的游戏世界,并提供具体示例代码,展示从基础地形绘制到植被与纹理添加的全过程。通过学习这些技巧,开发者能显著提升游戏画面质量和玩家体验。
193 3
|
3月前
|
图形学 C++ C#
Unity插件开发全攻略:从零起步教你用C++扩展游戏功能,解锁Unity新玩法的详细步骤与实战技巧大公开
【8月更文挑战第31天】Unity 是一款功能强大的游戏开发引擎,支持多平台发布并拥有丰富的插件生态系统。本文介绍 Unity 插件开发基础,帮助读者从零开始编写自定义插件以扩展其功能。插件通常用 C++ 编写,通过 Mono C# 运行时调用,需在不同平台上编译。文中详细讲解了开发环境搭建、简单插件编写及在 Unity 中调用的方法,包括创建 C# 封装脚本和处理跨平台问题,助力开发者提升游戏开发效率。
299 0
|
3月前
|
vr&ar 图形学 API
Unity与VR控制器交互全解:从基础配置到力反馈应用,多角度提升虚拟现实游戏的真实感与沉浸体验大揭秘
【8月更文挑战第31天】虚拟现实(VR)技术迅猛发展,Unity作为主流游戏开发引擎,支持多种VR硬件并提供丰富的API,尤其在VR控制器交互设计上具备高度灵活性。本文详细介绍了如何在Unity中配置VR支持、设置控制器、实现按钮交互及力反馈,结合碰撞检测和物理引擎提升真实感,助力开发者创造沉浸式体验。
194 0
|
3月前
|
图形学 开发者
【独家揭秘】Unity游戏开发秘籍:从基础到进阶,掌握材质与纹理的艺术,打造超现实游戏视效的全过程剖析——案例教你如何让每一面墙都会“说话”
【8月更文挑战第31天】Unity 是全球领先的跨平台游戏开发引擎,以其高效性能和丰富的工具集著称,尤其在提升游戏视觉效果方面表现突出。本文通过具体案例分析,介绍如何利用 Unity 中的材质与纹理技术打造逼真且具艺术感的游戏世界。材质定义物体表面属性,如颜色、光滑度等;纹理则用于模拟真实细节。结合使用两者可显著增强场景真实感。以 FPS 游戏为例,通过调整材质参数和编写脚本动态改变属性,可实现自然视觉效果。此外,Unity 还提供了多种高级技术和优化方法供开发者探索。
59 0
|
4月前
|
开发者 图形学 API
从零起步,深度揭秘:运用Unity引擎及网络编程技术,一步步搭建属于你的实时多人在线对战游戏平台——详尽指南与实战代码解析,带你轻松掌握网络化游戏开发的核心要领与最佳实践路径
【8月更文挑战第31天】构建实时多人对战平台是技术与创意的结合。本文使用成熟的Unity游戏开发引擎,从零开始指导读者搭建简单的实时对战平台。内容涵盖网络架构设计、Unity网络API应用及客户端与服务器通信。首先,创建新项目并选择适合多人游戏的模板,使用推荐的网络传输层。接着,定义基本玩法,如2D多人射击游戏,创建角色预制件并添加Rigidbody2D组件。然后,引入网络身份组件以同步对象状态。通过示例代码展示玩家控制逻辑,包括移动和发射子弹功能。最后,设置服务器端逻辑,处理客户端连接和断开。本文帮助读者掌握构建Unity多人对战平台的核心知识,为进一步开发打下基础。
155 0