《Unity3D高级编程之进阶主程》第二章 架构(三) - 架构的误区,如何做前端架构,以及如何架构Unity3D项目

前端与后端架构之间的共性

目标都是,高性能、高可用、可扩展、安全、可容错。

对于前端,还需要加入更多的用户体验,包括视觉效果和操作灵敏度。 (性能优化,视觉效果,以及操作上的人性化等)

前端技术与后端技术基于操作系统之上,最后都需要了解操作系统的接口以及底层运作原理。区别在于后端在操作系统上构建了一套服务端框架,而前端在操作系统之上构建了一个渲染引擎,两者都需要在这之上构建业务架构。

两套架构要学习,一套是渲染引擎架构,一套是游戏业务架构。

培养架构设计思维

良好的架构设计思维的培养,离不开工作中大量高质量项目的实战锻炼,然后是平时的学习、思考和提炼总结。

架构设计不是静态的,而是动态的。只有能够不断应对环境变化的系统,才是有生命力的系统。

抽象,包括分层、分治、演化

对抽象、分层、分治和演化掌握的深度和灵活应用的水平,直接决定架构师所能解决问题域的复杂性和规模大小,是区分普通应用型架构师和平台型/系统型架构师的一个分水岭。

试着架构Unity3D项目

分层

把最难把控的放在最优先的位置去做,而后再对这些层级进行细致化的构建。

分治

对模块进行细致化构建时,可以用分治法方法去构建。

各个模块的拆分原则:

数据表 -- XLS导为二进制文件还是Json或其他格式,读取接口和解析接口的定义。

UI层 -- 使用NGUI还是UGUI,界面基类,界面管理,输入事件封装,自定义通用组件基类,自定义各类通用组件。

外部资源管理 ---- 是否使用AssetBundle,AssetBundle资源分类,AssetBundle资源间的依赖关系,加载与释放AssetBundle的管理,AssetBundle加密。

AI层 ---- 使用状态机还是行为树或者其他,状态机或行为树接口实现,AI可视化工具,AI扩展接口。

地形地图 ---- 地图是2D还是3D,场景编辑器的结构,是否需要Mesh合并,场景内的大小物件区别对待,大地形在游戏里该怎么逐步显示,是否要划分区块。

寻路与网格 ---- 使用A星还是跳点算法或者其他,使用网格栅格还是三角网格,长距离寻路的解决方案,地图数据管理。

常用库 ---- 时间函数,数学函数,数字变量加密封装,坐标转换函数,Debug调试工具,各大逻辑系统通用工具等等。

角色行为控制 ---- 人物移动处理方案,摄像机的碰撞检测,动画特效编辑器,技能编辑器,行为流的建立。

2D动画控制 ---- 动画组件封装,2D动画的制作流程,2D图合并为图集。

演化

一开始的做的架构中某个部位的并不适合,或需要改善,在后面的工作中,修复和完善架构是演化的重要步骤。

在不断编写完善架构的过程中原本抽象简单的架构,开始复杂化。虽然每个模块都在有条不紊的进行中,但也会不断冒出各种各样不适应或者不符合实际需求的问题出现,我们需要及时跟进演化内容。去除、重构或者改善,前面由于各种原因而导致的错误的理解。

最后架构设计的文档要及时跟进完善。

相关推荐
异次元的归来4 小时前
Unity DOTS中的share component
unity·游戏引擎
工业甲酰苯胺4 小时前
分布式系统架构:服务容错
数据库·架构
冷眼看人间恩怨5 小时前
【Qt笔记】QDockWidget控件详解
c++·笔记·qt·qdockwidget
Java程序之猿6 小时前
微服务分布式(一、项目初始化)
分布式·微服务·架构
向宇it7 小时前
【从零开始入门unity游戏开发之——C#篇25】C#面向对象动态多态——virtual、override 和 base 关键字、抽象类和抽象方法
java·开发语言·unity·c#·游戏引擎
_oP_i8 小时前
unity webgl部署到iis报错
unity
Go_Accepted8 小时前
Unity全局雾效
unity
向宇it8 小时前
【从零开始入门unity游戏开发之——C#篇24】C#面向对象继承——万物之父(object)、装箱和拆箱、sealed 密封类
java·开发语言·unity·c#·游戏引擎
小蜗牛慢慢爬行8 小时前
Hibernate、JPA、Spring DATA JPA、Hibernate 代理和架构
java·架构·hibernate