在介绍UE4渲染体系前,我们有必要来先看一下UE4是用什么样的方式来构建游戏场景数据的。

1 Object

在UE4中当我们说Object,通常是指代引擎代码中的UObject类,它是引擎里管理绝大部分类和对象的基石,这是因为它提供了非常多的开发者需要的功能特性,例如元数据、反射、垃圾回收、序列化、编辑器支持等一系列功能。

与Unity中的物体容器GameObject相比(名字上类似),个人理解UObject存在更像是一种UE4提供的开发核心工具箱,各种需要高复用性的核心功能都集成到里面,不仅仅说场景里的各个物体需要用到UObject提供的功能,不可见的底层数据管理同样也需要使用到这些。

2 Actor

Actor通常指代引擎代码中的AActor类,所有可以放置到游戏场景中的"物体"都是一个Actor,例如角色、怪物、光(ALight)、场景(AStaticMeshActor)、摄像机(ACameraActor)等等。它提供的功能和Unity的GameObject就比较相似了,作为一个容器包含一个"物体"的各种内容,自然地AActor继承自UObject类,在UObject的基础上,还提供了网络同步、创建销毁、帧更新等功能。

对很多刚接触的开发者来说,可能Actor的名字看起来有点突兀,UE4并没有特别说明该名称的由来,个人理解,Actor单词本身的意思是演员,如果可以把游戏看作一场演出的话,其中就是各位出演角色各司其职,角色和怪物完成各种交互、光照(就像打光师)完成场景光照、场景物体可以各种移动变化、摄像机完成拍摄等等。

3 Component

Component通常指代引擎代码中的UActorComponent类,继承UObject,是所有组件类型的基类,通常挂载在Actor实例下,如同之前所介绍的,Actor本身是一个容器,而Actor具体的特性则由其具有的Component决定,如在世界场景中的位置旋转缩放(USceneComponent)、模样(UMeshComponent)等等。

Component对于Actor来说并不是必选的,可以存在没有组件的空Actor、不需要空间位置的Actor、不需要模样的Actor等等,这样在我们DIY自己需要的Actor时,就可以尽可能少地引入不需要的内容了。

4 Level

Level通常指代引擎代码中的ULevel,也被叫做关卡,是UE4中用于组织游戏场景的基本单位,由一系列可见和不可见的Actor组成,同时还包含Level自身的一些属性,比如关卡属性、关卡蓝图等等,和Unity中的Scene概念相通。

5 World

World,引擎代码中的UWorld,如果说Level代表场景,那World代表承载这个场景的世界,Level必须放在World中才能显示出其中的内容,对于一些以关卡切换来转换游戏场景的游戏来说,他们一个Level就是一个World,这样的概念可能有点多余,但是在很多开放世界的项目中,一个World同时可能不止一个Level,很多3A游戏的无缝多场景切换也是得益于流式关卡(Streaming Level)的使用。

6 Script

除了以上的基本概念,还有脚本(Script)存在于世界的各个Actor中,脚本可以用于给Actor添加不同的行为,脚本可以是C++定义编写的,也可是蓝图定义的,从功能上看,脚本和Component十分相像,但在UE4的组织形式上看,脚本并非是一种Component,而更像是一种对Actor的补充,从程序员角度来讲,就像是对Actor一些接口的覆写(Override),例如自定义BeginPlay、Tick、EndPlay等(对应Unity中的Start、Update、End)时Actor应该有的操作。

顺带一提

你可能已经发现在提到引擎代码中的类名时,相比名称会多出一个前缀(Prefix),这是UE4中一种编码规范,用来指代该类的类别:

  • T:模板类,例如TArray
  • U:继承UObject的类;
  • A:继承AActor的类;
  • S:继承SWidget的类;
  • I:抽象界面类;
  • E:枚举;
  • F:其他多数类(不在UObject继承体系内);

参考文献

《图解UE4渲染体系》Part 0 引擎基础的更多相关文章

  1. 《图解UE4渲染体系》Part 1 多线程渲染

    上回书<Part 0 引擎基础>说到,我们粗略地知道UE4是以哪些类来管理一个游戏场景里的数据的,但这仅仅是我们开始探索UE4渲染体系的一小步. 本回主要介绍UE4渲染体系中比较宏观顶层的 ...

  2. 剖析虚幻渲染体系(14)- 延展篇:现代渲染引擎演变史Part 1(萌芽期)

    目录 14.1 本篇概述 14.1.1 游戏引擎简介 14.1.2 游戏引擎模块 14.1.3 游戏引擎列表 14.1.3.1 Unreal Engine 14.1.3.2 Unity 14.1.3. ...

  3. 剖析虚幻渲染体系(06)- UE5特辑Part 1(特性和Nanite)

    目录 6.1 本篇概述 6.1.1 本篇内容 6.1.2 基础概念 6.2 UE5新特性 6.2.1 UE5编辑器 6.2.1.1 下载编辑器及资源 6.2.1.2 启动示例工程 6.2.1.3 编辑 ...

  4. 剖析虚幻渲染体系(08)- Shader体系

    目录 8.1 本篇概述 8.2 Shader基础 8.2.1 FShader 8.2.2 Shader Parameter 8.2.3 Uniform Buffer 8.2.4 Vertex Fact ...

  5. 剖析虚幻渲染体系(10)- RHI

    目录 10.1 本篇概述 10.2 RHI基础 10.2.1 FRenderResource 10.2.2 FRHIResource 10.2.3 FRHICommand 10.2.4 FRHICom ...

  6. 剖析虚幻渲染体系(11)- RDG

    目录 11.1 本篇概述 11.2 RDG基础 11.2.1 RDG基础类型 11.2.2 RDG资源 11.2.3 RDG Pass 11.2.4 FRDGBuilder 11.3 RDG机制 11 ...

  7. 剖析虚幻渲染体系(12)- 移动端专题Part 1(UE移动端渲染分析)

    目录 12.1 本篇概述 12.1.1 移动设备的特点 12.2 UE移动端渲染特性 12.2.1 Feature Level 12.2.2 Deferred Shading 12.2.3 Groun ...

  8. 剖析虚幻渲染体系(12)- 移动端专题Part 2(GPU架构和机制)

    目录 12.4 移动渲染技术要点 12.4.1 Tile-based (Deferred) Rendering 12.4.2 Hierarchical Tiling 12.4.3 Early-Z 12 ...

  9. 剖析虚幻渲染体系(12)- 移动端专题Part 3(渲染优化)

    目录 12.6 移动端渲染优化 12.6.1 渲染管线优化 12.6.1.1 使用新特性 12.6.1.2 管线优化 12.6.1.3 带宽优化 12.6.2 资源优化 12.6.2.1 纹理优化 1 ...

随机推荐

  1. sem信号量与死锁的边缘

    1. 演示一个例子,出现死锁,用strace debug得到 #include<stdio.h> #include<pthread.h> #include<stdlib. ...

  2. 一个关于wait/notify与锁关系的探究

    wait/notify 机制是解决生产者消费者问题的良药.它的核心逻辑是基于条件变量的锁机制处理.所以,它们到底是什么关系?wait()时是否需要持有锁? notify()是否需要持有锁?先说答案:都 ...

  3. Zwibbler—前端Canvas绘图工具使用记录

    本人第一次发博客,用意在于记录自己在开发过程中用到的实用工具并分享出来,写的可能不好,请大家多多包涵!!! 工具官网:https://www.zwibbler.com 基于Canvas的一个前端绘画工 ...

  4. 简述synchronized和java.util.concurrent.locks.Lock的异同 ?

    主要相同点:Lock能完成synchronized所实现的所有功能 主要不同点:Lock有比synchronized更精确的线程语义和更好的性能.synchronized会自动释放锁,而Lock一定要 ...

  5. Ajax的乱码解决问题?

    Javascript是使用UTF-8国际编码,即每个汉字用4个字节来存储,这就造成了用AJAX来send数据的时候出现会乱码. Ajax乱码产生主要有2个原因 1. XMLHttpRequest返回的 ...

  6. Anonymous Inner Class(匿名内部类)是否可以继承其它类?是否可以实现接口?

    可以继承其他类或实现其他接口,在 Swing 编程和 Android 开发中常用此方式来 实现事件监听和回调.

  7. 什么是 AQS ?

    AQS 是 AbustactQueuedSynchronizer 的简称,它是一个 Java 提高的底层同步工具类,用一个 int 类型的变量表示同步状态,并提供了一系列的 CAS 操作来管理这个同步 ...

  8. Hashtable 与 HashMap 有什么不同之处?

    这两个类有许多不同的地方,下面列出了一部分: a) Hashtable 是 JDK 1 遗留下来的类,而 HashMap 是后来增加的. b)Hashtable 是同步的,比较慢,但 HashMap ...

  9. 学习zabbix(六)

    实验环境 实验用2到2台机器,实验所用机器系统环境如下,可以看到2台机器的主机名和IP地址 ? 1 2 3 4 5 6 7 8 9 10 [root@linux-node1 ~]# cat /etc/ ...

  10. MOS管驱动电路,看这里就啥都懂了

    一.MOS管驱动电路综述在使用MOS管设计开关电源或者马达驱动电路的时候,大部分人都会考虑MOS的导通电阻,最大电压等,最大电流等,也有很多人仅仅考虑这些因素.这样的电路也许是可以工作的,但并不是优秀 ...