UE4 World, Level, LevelStreaming从入门到深入
前言
在《塞尔达传说:旷野之息》中,玩家攀上初始高塔的瞬间,目光所及的山川湖泊皆可抵达;在《艾尔登法环》中,黄金树的辉光始终悬于地平线之上,指引玩家穿越无缝衔接的史诗战场。这些现代游戏杰作背后的核心挑战之一,是如何将庞大的虚拟世界“装入”有限的内存与算力中,同时保持玩家沉浸感不被加载黑屏或性能卡顿打破。
虚幻引擎4(Unreal Engine 4, UE4)作为开放世界开发的主流工具,其 World(世界) 与 Level(关卡) 系统正是为解决这一矛盾而生。从《堡垒之夜》的动态战场到《地狱之刃》的线性叙事,开发者们通过灵活组合Persistent Level、Streaming Levels与World Composition,在引擎底层构建起一套“空间即代码”的规则体系——每一块地形、每一栋建筑不仅是美术资源,更是被精确计算的时空容器,按需加载、动态拼接,最终在玩家眼前编织成无垠的幻想之境。
世界(UWorld)
UWorld是UE里面最顶层UObject对象,代表了一个地图,里面存放各种UObject, AActor对象.
UWorld存在哪些地方
在游戏里,大多数时候只存在一个UWorld对象。而在UE引擎编辑器里, 许多UWorld存在。比如当前正在编辑的关卡是一个UWorld, PIE模式存在一个独立的UWorld, 带着独立渲染Viewport窗口的编辑器工具也存在一个UWorld.

C++访问UWorld
Actor获取所在的主World
UWorld* World = GetWorld()
这里获取的World是间接通过访问Actor所在的Level, 获取Level所在的World.

Level获取所在的主World
Level->OwningWorld
引擎编辑器获取当前的World
UWorld* World = GEditor->GetEditorWorldContext().World();
关卡Level
可以这么理解, World是由一个个Level组成,World容纳各种Actor的实际承载是Level.
关卡的创建


文件格式是umap

世界和关卡的关系
在双击点击一个Level进新的地图后, 代表了进入了一个新OwningWorld或者说是OwningWorld的持续性关卡(PersistentLevel, OwningWorld的PersistentLevel一直不会卸载). 这里比较注意的是每个关卡的默认名都叫“PersistentLevel”,都有自己的World,GetOuter()可以得到关卡GC引用链的World, 这和OwningWorld是两个概念。一般情况关卡的GC引用链的World很少使用)。



比如上图的当前世界的PersistentLevel就是ThirdPersonExampleMap.
关卡管理器(LevelManaer)
打开Window->Level可以打开关卡管理器可以查看当前存在哪些关卡.

图中挂在PersistentLevel下的是子关卡, 也是组成整个World的一部分, 不过子关卡和主关卡不一样的是, 可以随时从整个World关卡列表里面移除,加入, 加载,卸载等操作。
子关卡流程和操作
创建一个子关卡, 像上面已经写有

拖拽关卡到LevelManager


目前蓝色高亮的代表是当前编辑的关卡,放置到场景世界的Actor默认加入到这个关卡中。
C++访问 && 操作ULevel

获取主世界和主关卡(PersistentLevel)
UWorld* MainWorld = GetWorld();
ULevel* MainLevel = GetWorld()->PersistentLevel;
UWorld* TestWorld = Cast<UWorld>(MainLevel->GetOuter());
if(MainWorld == TestWorld)
{
}
获取一个关卡对应的GCWorld
//ULevel* TestLevel;TestLevel->GetOuter();
获取当前编辑关卡
// 获取编辑器世界的UWorld指针(仅在编辑器模式下有效)UWorld* EditorWorld = GEditor->GetEditorWorldContext().World();if (EditorWorld){// 获取当前关卡(Persistent Level)ULevel* CurrentLevel = EditorWorld->GetCurrentLevel();if (CurrentLevel){UE_LOG(LogTemp, Warning, TEXT("Current Level: %s"), *CurrentLevel->GetOuter()->GetName());}}
加载关卡资源并加入当前主世界(Level资源路径加载)


// 关卡路径FString LevelPackagePath = TEXT("/Game/Maps/C4");UEditorLevelUtils::AddLevelsToWorld(MainWorld, {LevelPackagePath}, ULevelStreamingDynamic::StaticClass());
其他关卡操作相关参考UEditorLevelUtils库

Level的应用方案
基于 Persistent Level + Streaming Levels 的传统关卡流送
Persistent Level(持久关卡)
作为World的核心,持久关卡是始终加载的主关卡,负责管理其他子关卡的动态加载和卸载。它通常包含基础场景元素(如光照环境、天空盒等),且在运行时无法被卸载
Streaming Levels(流送关卡)
通过流送体积(Level Streaming Volumes)、蓝图或代码动态加载的子关卡。例如:
流送体积:当玩家进入体积区域时触发加载,离开时卸载
蓝图/C++控制:使用Load Stream Level和Unload Stream Level函数实现精确控制,可设置加载后是否可见、是否阻塞主线程等
固定加载(Always Loaded):某些子关卡可能与持久关卡同时加载,常用于多人协作开发的分层设计
技术特点
- 适用于中小型场景或需要手动控制加载逻辑的项目。
- 所有流送体积必须存在于持久关卡中
基于 World Composition 的大世界管理
针对开放世界等超大规模场景,World Composition通过自动化层级管理优化关卡流送.
核心机制
主关卡(Persistent Level)不存储流送信息,而是通过扫描指定目录自动识别子关卡(.umap文件)
子关卡按图层(Layer)分类,每个图层定义统一的流送距离。当玩家与关卡边界的距离小于该值时,自动加载对应关卡
层级管理优势
自动流送:根据摄像机位置动态加载/卸载,无需手动设置体积域
图层过滤:可创建自定义图层(如“森林层”“城市层”),并独立设置流送参数
无缝拼接:通过精确对齐关卡边界(需整数倍坐标),实现地形和物件的无缝衔接
两种技术对比
- 传统流送需要手动维护关卡列表,而World Composition通过目录扫描自动管理。
- 支持运行时动态调整流送策略(如
stat levels命令查看加载状态)
两种模式的应用场景
| 模式 | 适用场景 | 技术优势 |
|---|---|---|
| Persistent+Streaming | 中小型场景、线性流程 | 精确控制加载时机,适合剧情关卡切换 |
| World Composition | 开放世界、超大地图 | 自动化管理,减少手动配置,支持动态分层流送 |
两种方案总结
两种模式本质都属于关卡流送技术,但实现逻辑不同:传统流送依赖显式的手动配置,而World Composition通过层级化和自动化简化了大世界管理。开发者可根据项目规模选择,甚至混合使用(如在大世界中嵌套局部手动流送)以实现灵活的场景构建
参考资料
[1]World Composition in Unreal Engine | Unreal Engine 5.5 Documentation | Epic Developer Community
[2]Level Streaming in Unreal Engine | Unreal Engine 5.5 Documentation | Epic Developer Community
[3]腾讯元宝: "写一篇关于UE4 World, Level的技术博客"
相关文章:
UE4 World, Level, LevelStreaming从入门到深入
前言 在《塞尔达传说:旷野之息》中,玩家攀上初始高塔的瞬间,目光所及的山川湖泊皆可抵达;在《艾尔登法环》中,黄金树的辉光始终悬于地平线之上,指引玩家穿越无缝衔接的史诗战场。这些现代游戏杰作背后的核…...
3月8日实验
拓扑: 需求: 1.学校内部的HTTP客户端可以正常通过域名www.baidu.com访问到白度网络中的HTTP服务器 2.学校网络内部网段基于192.168.1.0/24划分,PC1可以正常访问3.3.3.0/24网段,但是PC2不允许 3.学校内部路由使用静态路由&#…...
IO多路复用实现并发服务器
一.select函数 select 的调用注意事项 在使用 select 函数时,需要注意以下几个关键点: 1. 参数的修改与拷贝 readfds 等参数是结果参数 : select 函数会直接修改传入的 fd_set(如 readfds、writefds 和 exceptfds…...
【漫话机器学习系列】122.相关系数(Correlation Coefficient)
深入理解相关系数(Correlation Coefficient) 1. 引言 在数据分析、统计学和机器学习领域,研究变量之间的关系是至关重要的任务。我们常常想知道:当一个变量变化时,另一个变量是否也会随之变化?如果会&…...
控制系统分类
文章目录 定义与特点1. 自治系统(Autonomous System)与非自治系统(Non-Autonomous System)自治系统非自治系统 2. 线性系统(Linear System)与非线性系统(Nonlinear System)线性系统非…...
文档操作方法得合理使用
博主介绍:✌全网粉丝5W,全栈开发工程师,从事多年软件开发,在大厂呆过。持有软件中级、六级等证书。可提供微服务项目搭建与毕业项目实战,博主也曾写过优秀论文,查重率极低,在这方面有丰富的经验…...
Python asyncIO 面试题及参考答案 草
目录 如何正确定义一个协程函数?直接调用协程会引发什么问题? 使用 async def 定义的协程与普通函数执行流程有何本质区别? 解释 asyncio.run () 的作用及与手动管理事件循环的差异 为什么协程中必须使用 await 而非 yield 挂起操作? 写出通过 async for 实现异步迭代器…...
计算机网络——交换机
一、什么是交换机? 交换机(Switch)是局域网(LAN)中的核心设备,负责在 数据链路层(OSI第二层)高效转发数据帧。它像一位“智能交通警察”,根据设备的 MAC地址 精准引导数…...
matlab和FPGA联合仿真时读写.txt文件数据的方法
在FPGA开发过程中,往往需要将MATLAB生成的数据作为原始激励灌入FPGA进行仿真。为了验证FPGA计算是否正确,又需要将FPGA计算结果导入MATLAB绘图与MATLAB计算结果对比。 下面是MATLAB“写.txt”、“读.txt”,Verilog“读.txt”、“写.txt”的代…...
解锁DeepSpeek-R1大模型微调:从训练到部署,打造定制化AI会话系统
目录 1. 前言 2.大模型微调概念简述 2.1. 按学习范式分类 2.2. 按参数更新范围分类 2.3. 大模型微调框架简介 3. DeepSpeek R1大模型微调实战 3.1.LLaMA-Factory基础环境安装 3.1大模型下载 3.2. 大模型训练 3.3. 大模型部署 3.4. 微调大模型融合基于SpirngBootVue2…...
【分布式】聊聊分布式id实现方案和生产经验
对于分布式Id来说,在面试过程中也是高频面试题,所以主要针对分布式id实现方案进行详细分析下。 应用场景 对于无论是单机还是分布式系统来说,对于很多场景需要全局唯一ID, 数据库id唯一性日志traceId 可以方便找到日志链&#…...
uniapp或者vue 使用serialport
参考https://blog.csdn.net/ykee126/article/details/90440499 版本是第一位:否则容易编译失败 node 版本 18.14.0 npm 版本 9.3.1 electron 版本 30.0.8 electron-rebuild 版本 3.2.9 serialport 版本 10.0.0 需要python环境 main.js // Modules to control app…...
机器学习12-视觉识别任务
机器学习12-视觉识别任务 分类语义分割滑动窗口滑动窗口的实现思路优点缺点现代替代方法 全卷积(Fully Convolutional Networks, FCN)FCN 的工作原理FCN 的性能优势FCN 的应用案例FCN 的局限性改进方向下采样可学习的上采样:转置卷积 目标检测区域建议Se…...
使用paramiko爆破ssh登录
一.确认是否存在目标主机是否存在root用户 重跑 CVE-2018-15473用户名枚举漏洞 检测: import paramiko from paramiko.ssh_exception import AuthenticationExceptiondef check_user(username, hostname, port):ssh paramiko.SSHClient()ssh.set_missing_host_key…...
游戏引擎学习第146天
音高变化使得对齐读取变得不可能,我们可以支持循环声音了。 我们今天的目标是完成之前一段时间所做的音频代码。这个项目并不依赖任何引擎或库,而是一个教育项目,目的是展示从头到尾运行一个游戏所需要的全部代码。无论你对什么方面感兴趣&a…...
装饰器模式--RequestWrapper、请求流request无法被重复读取
目录 前言一、场景二、原因分析三、解决四、更多 前言 曾经遇见这么一段代码,能看出来是把request又重新包装了一下,核心信息都不会改变 后面了解到这叫 装饰器模式(Decorator Pattern) :也称为包装模式(Wrapper Pat…...
【算法题】小鱼的航程
问题: 分析 分析题目,可以看出,给你一个开始的星期,再给一个总共天数,在这些天内,只有周六周日休息,其他全要游泳250公里。 那分支处理好啦 当星期为6时,需要消耗2天,…...
视频录像机视频通道是指什么
视频录像机的视频通道是指摄像机在监控矩阵或硬盘录像机设备上的视频输入的物理位置。 与摄像头数量关系:在视频监控系统中,有多少个摄像头就需要多少路视频通道,通道数量决定了视频录像机可接入摄像头的数量,一般硬盘录像机有4路…...
RISC-V医疗芯片工程师复合型转型的路径与策略
从RISC-V到医疗芯片:工程师复合型转型的路径与策略 一、引言 1.1 研究背景 在科技快速发展的当下,芯片技术已然成为推动各行业进步的核心驱动力之一。其中,RISC-V 架构作为芯片领域的新兴力量,正以其独特的优势迅速崛起,对整个芯片产业的格局产生着深远影响。RISC-V 架…...
《Gradio : AI awesome-demos》
《Gradio : AI awesome-demos》 This is a list of some wonderful demos & applications built with Gradio. Heres how to contribute yours! 🖊️ Natural language processing Demo name (link to demo)input type(s)output type(s)status badgeruDALL-ET…...
基于距离变化能量开销动态调整的WSN低功耗拓扑控制开销算法matlab仿真
目录 1.程序功能描述 2.测试软件版本以及运行结果展示 3.核心程序 4.算法仿真参数 5.算法理论概述 6.参考文献 7.完整程序 1.程序功能描述 通过动态调整节点通信的能量开销,平衡网络负载,延长WSN生命周期。具体通过建立基于距离的能量消耗模型&am…...
STM32F4基本定时器使用和原理详解
STM32F4基本定时器使用和原理详解 前言如何确定定时器挂载在哪条时钟线上配置及使用方法参数配置PrescalerCounter ModeCounter Periodauto-reload preloadTrigger Event Selection 中断配置生成的代码及使用方法初始化代码基本定时器触发DCA或者ADC的代码讲解中断代码定时启动…...
家政维修平台实战20:权限设计
目录 1 获取工人信息2 搭建工人入口3 权限判断总结 目前我们已经搭建好了基础的用户体系,主要是分成几个表,用户表我们是记录用户的基础信息,包括手机、昵称、头像。而工人和员工各有各的表。那么就有一个问题,不同的角色…...
五年级数学知识边界总结思考-下册
目录 一、背景二、过程1.观察物体小学五年级下册“观察物体”知识点详解:由来、作用与意义**一、知识点核心内容****二、知识点的由来:从生活实践到数学抽象****三、知识的作用:解决实际问题的工具****四、学习的意义:培养核心素养…...
Cloudflare 从 Nginx 到 Pingora:性能、效率与安全的全面升级
在互联网的快速发展中,高性能、高效率和高安全性的网络服务成为了各大互联网基础设施提供商的核心追求。Cloudflare 作为全球领先的互联网安全和基础设施公司,近期做出了一个重大技术决策:弃用长期使用的 Nginx,转而采用其内部开发…...
(转)什么是DockerCompose?它有什么作用?
一、什么是DockerCompose? DockerCompose可以基于Compose文件帮我们快速的部署分布式应用,而无需手动一个个创建和运行容器。 Compose文件是一个文本文件,通过指令定义集群中的每个容器如何运行。 DockerCompose就是把DockerFile转换成指令去运行。 …...
Redis数据倾斜问题解决
Redis 数据倾斜问题解析与解决方案 什么是 Redis 数据倾斜 Redis 数据倾斜指的是在 Redis 集群中,部分节点存储的数据量或访问量远高于其他节点,导致这些节点负载过高,影响整体性能。 数据倾斜的主要表现 部分节点内存使用率远高于其他节…...
【生成模型】视频生成论文调研
工作清单 上游应用方向:控制、速度、时长、高动态、多主体驱动 类型工作基础模型WAN / WAN-VACE / HunyuanVideo控制条件轨迹控制ATI~镜头控制ReCamMaster~多主体驱动Phantom~音频驱动Let Them Talk: Audio-Driven Multi-Person Conversational Video Generation速…...
Java求职者面试指南:计算机基础与源码原理深度解析
Java求职者面试指南:计算机基础与源码原理深度解析 第一轮提问:基础概念问题 1. 请解释什么是进程和线程的区别? 面试官:进程是程序的一次执行过程,是系统进行资源分配和调度的基本单位;而线程是进程中的…...
STM32HAL库USART源代码解析及应用
STM32HAL库USART源代码解析 前言STM32CubeIDE配置串口USART和UART的选择使用模式参数设置GPIO配置DMA配置中断配置硬件流控制使能生成代码解析和使用方法串口初始化__UART_HandleTypeDef结构体浅析HAL库代码实际使用方法使用轮询方式发送使用轮询方式接收使用中断方式发送使用中…...
