UE引擎 LandscapeGrass 實現機制分析(UE5.2)

前言

隨著電腦和手機硬件性能越來越高,游戲越來越追求大世界,而大世界非常核心的一環是植被,目前UE5引擎提供給植被生成的主流兩種方式為 手刷植被LandscapeGrass(WeightMap程序化植被)。當然UE5.3推出新一代PCGFramework 節點程序化生成框架,也可以用于植被生成。(本文暫不涉及到PCGFramework), 主要分析LandscapeGrass方案

手刷植被

手刷植被是比較傳統的植被生成方式,基本各種引擎都會提供植被編輯器讓美術人力刷植被,這里倒是沒什么好分析的。UE5提供了手刷植被模式FoliageMode, 工具比較齊全,比較易用,能讓場景美術高效率手工刷植被。FoliageMode生成的植被是用HISM組件管理,不明白的可以看看我的另外一篇博客(UE4 4.27) UHierarchicalInstancedStaticMesh(HISM)原理分析

LandscapeGrass(WeightMap程序化植被)

背景

weightmap程序化植被, 顧名思義: 由地形weightmap程序化生成的植被。首先地形WeightMap的概念,說白了就是地形材質混合的權重圖,不懂的可以看下UE地形系統材質混合實現和Shader生成分析(UE5 5.2)。場景美術在地形上頻繁刷了各種材質,比如草原或者沙漠,然后需要再相應的地貌上種植相應植被,比如草原種綠草,沙漠種仙人掌,因為地形的材質層是頻繁改動,每次刷完草或者沙漠后,又得用FoliageMode 在相應地貌刷植被,兩重工作量,而且容易遺忘,這時候就非常需要一種工具:? 在相應的WeightMap上程序化鋪滿一種或許多種植被,每次刷完WeightMap后地形可以自動生成。UE引擎?就有這樣一套方案,叫LandscapeGrass

LandscapeGrass使用簡介

配置LandscapeGrassType

材質Grass采樣層配置

顯示結果

LandscapeGrass生成分析

LandscapeGrass UML圖

LandscapeGrass執行流程圖

這里重點介紹RenderGrassMap,GrassInstancedStaticMeshComponent, FAsyncGrassTask.

這里的三個過程都是逐組件的,針對單獨一個Landscapecomponent進行

RenderGrassMap(Per LandscapeComponent)

GrassMap本質就是一張圖集(TextureAltas)

這里是將LandscapeComponent的HeightMap和Grass用到的所有WeightMap(也就是上面的L2,L3,L4,L5)合并到一張圖集里,格式為PF_B8G8R8A8,也就是所謂的RenderGrassMap。

假設一個Landscapecomponent 分辨率為128,一張HeightMap占16位,一張WeightMap占8位, 由于上面使用了L2,L3,L4,L5四個草權重層,則 (2 + 4)/ 4 = 1.5, 得使用兩張128 * 128,合起來(128 * 2)* 128 = 256 * 128,這就是RenderGrassMap圖集。

GrassMap創建

Render GrassMap

通過DrawLandscapeComponentMesh,設置Ortho正交相機, 進行多次RenderPass, 將HeightMap和WeightMap寫入到GrassMap圖集里。一次RenderPass寫入4個8位通道,6個8位通道就是需要兩次RenderPass.?

核心代碼:

FLandscapeGrassWeightVS,FLandscapeGrassWeightPS,?FLandscapeGrassWeightMeshProcessor等文件

"?grass.CaptureNextGrassUpdate 1 "?可以對RenderGrassMap進行Renderdoc抓幀

GrassMap fetch成cpu數據

上一步生成了GrassMap 圖集,里面存儲了LandscapeComponent地塊的HeightMap數據和所有的Grass相關的WeightMap數據。最終直接對GrassMap進行CPU ReadBack,讀取數據出來,合并到FLandscapeComponentGrassData的 TArray<uint8> HeightWeightData里。HeightWeightData按順序分段存儲了高度數據和所有的Grass各層權重數據。

為什么需要Render GrassMap

回過頭來看RenderGrassMap存在的意義是因為UE引擎地形的各個LandscapeComponent共用了HeightMap和WeightMap,?RenderGrassMap就是把每個組件的HeightData和GrassWeightData從公用紋理抽離出來,存到LandscapeComponent里,方便每個LandscapeComponent生成自己的GrassInstancedStaticMeshComponent.

GrassInstancedStaticMeshComponent

GrassInstancedStaticMeshComponent繼承于HISM組件,兩者基本沒什么區別。這里需要強調的是一個GSMC組件針對一個LandcapeComponent的LandscapeGrassType的GrassVariety來創建的。

FAsyncGrassTask(隨機撒點和HISM構建)

LandscapeComponent已經獲取高度和權重數據,下面就是進行隨機撒點。FAsyncGrassTask

隨機撒點

撒點密度由LandscapeComponent地塊大小和GrassVariety的密度決定

FAsyncGrassBuilder封裝了隨機撒點的核心算法, 目前一共提供了兩種隨機撒點算法: JitterGrid和?Halto序列

勾選了UseGrid就是使用了JitterGrid隨機撒點,反之使用Halto隨機撒點。

JitterGrid

JitterGrid也就是根據密度把整個地形塊均分切成多個塊,每個塊內隨機生成一個二維點,并且加上一定的旋轉和位置偏移,最終得到一個隨機點。具體算法參考我之前一篇博客:?程序化物件放置(procedural placement)之泊松硬盤采樣(poisson disk sampling)

一個隨機點雖然生成出來了,但是是否存活得滿足一定條件:

可以看出當權重為0,百分百不通過。權重為1時,通過率是百分百,如果權重為其它,那就看隨機的運氣了。

Halto序列

Halto隨機數生成參考?應用halton序列生成均勻散點圖

Halto序列生成的隨機點存活條件判斷和JitterGrid是一樣的。比較注意的是,JitterGrid和Halto序列生成的隨機點都是二維的,都需要進行一次SampleHeight來得到高度位置Z,Sample方法是?Bilinear interpolates。

撒完點后最終進行HISM構建。

FoliageModeLandscapeGrass的區別

未完待續

參考文章

[1]?UE地形系統材質混合實現和Shader生成分析(UE5 5.2)

[2]?(UE4 4.27) UHierarchicalInstancedStaticMesh(HISM)原理分析

[3]?應用halton序列生成均勻散點圖

[4] 源碼文件:LandscapeGrass.cpp

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/215266.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/215266.shtml
英文地址,請注明出處:http://en.pswp.cn/news/215266.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

MyBatis:緩存

MyBatis 緩存一級緩存二級緩存注 緩存 緩存&#xff0c;是數據交換的緩沖區&#xff08;臨時保存數據的地方&#xff09;。即將數據&#xff08;數據一般為頻繁查詢且不易改變&#xff09;保存在計算機內存中&#xff0c;下次讀取數據時直接從內存中獲取&#xff0c;以避免頻繁…

OpenAI接口調用示例

最近為公司做了一個ChatGPT工具&#xff0c;這里展示一下OpenAI接口的調用 前提條件 訪問OpenAI官網&#xff08;國內需要翻墻&#xff09;的賬號&#xff0c;需要sk 地址&#xff1a;https://platform.openai.com 依賴 使用開源工具調用OpenAI接口&#xff0c;依賴如下&am…

js中箭頭函數簡單介紹

1.箭頭函數是 ES6 中新增的一種函數定義方式&#xff0c; 簡單舉例為 var nameA function(a){return a} 可以用箭頭函數簡化為 var nameA a >a; 返回的是你輸入的值 比如 nameA(5) 返回的就是5 nameA(2) 返回的就是2 以上兩個表達的含義是一樣的。nameA為名字 2.…

Vue3封裝一個輪播圖組件

先看效果 編寫組件代碼 CarouselChart.vue <template><div classimg-box><el-button clickpreviousImages v-ifprops.showBtn>←</el-button><div classimg><div styledisplay: flex;gap: 20px idmove><imgclassimg-item v-for(item…

centos7部署docker

文章目錄 &#xff08;1&#xff09;安裝前準備&#xff08;2&#xff09;卸載舊版Docker&#xff08;3&#xff09;安裝docker&#xff08;4&#xff09;配置鏡像加速 &#xff08;1&#xff09;安裝前準備 在開始安裝之前&#xff0c;首先需要檢查內核版本。使用 uname -r 命…

nodejs微信小程序+python+PHP個性化服裝搭配系統APP-計算機畢業設計推薦 android

目 錄 摘 要 I ABSTRACT II 目 錄 II 第1章 緒論 1 1.1背景及意義 1 1.2 國內外研究概況 1 1.3 研究的內容 1 第2章 相關技術 3 2.1 nodejs簡介 4 2.2 express框架介紹 6 2.4 MySQL數據庫 4 第3章 系統分析 5 3.1 需求分析 5 3.2 系統可行性分析 5 3.2.1技術可行性&#xff1a;…

redis(設置密碼)配置文件詳細

1.設置賬號密碼端口 config set requirepass 123456 設置密碼為123456 config get requirepass 查看賬號密碼 auth 123456 登入的時候輸入這個確定賬號密碼 1. 首先連接到Redis服務器: redis-cli 2. 然后使用CONFIG SET命令設置requirepass參數并指定密碼: CONFIG SET requi…

【PyTorch】現代卷積神經網絡

文章目錄 1. 理論介紹1.1. 深度卷積神經網絡&#xff08;AlexNet&#xff09;1.1.1. 概述1.1.2. 模型設計 1.2. 使用塊的網絡&#xff08;VGG&#xff09;1.3. 網絡中的網絡&#xff08;NiN&#xff09;1.4. 含并行連結的網絡&#xff08;GoogLeNet&#xff09; 2. 實例解析2.1…

家具制造ERP軟件包含哪些功能?家具制造業ERP系統哪個好

不同的家具有不同的用料、品質、制造工時、營銷渠道等&#xff0c;而有些家具制造企業采用傳統的管理方式在處理物料BOM、生產實際成本核算、庫存盤點、供應商選擇、班組計件核對、生產領用以及物料追溯等方面存在不少提升空間。 與此同時也有很多的皮具制造企業借助ERP軟件優…

Linux16 ftp文件服務區、vsftpd文件系統服務安裝、lftp客戶端安裝、NFS遠程共享存儲

目錄 一、FTP基礎ftp主動模式ftp被動模式 二、vsftpd配置共享目錄編輯配置文件使用windows 訪問 三、客戶端安裝 &#xff08;lftp&#xff09;匿名用戶的一些操作&#xff08;lftp {ip}&#xff09;ftp配置本地用戶登錄配置本地用戶ftp配置文件 lftp操作 NFS遠程共享存儲安裝n…

新的側通道攻擊可泄露處理器的 Root 密碼

阿姆斯特丹自由大學的一組科學家開發了一種名為 SLAM&#xff08;Spectre Linear Address Masking&#xff09;的側信道攻擊。 該攻擊利用旨在提高新型Intel、AMD 和 Arm 處理器安全性的硬件功能&#xff0c;從內核內存中提取根密碼哈希。 重現 SLAM 攻擊所需的代碼和所有數據…

dockerfile:創建鏡像的方式,船艦自定義的鏡像

dockerfile&#xff1a;創建鏡像的方式&#xff0c;船艦自定義的鏡像 包括配置文件&#xff0c;掛載點&#xff0c;對外暴露的端口&#xff0c;設置環境變量 docker創建鏡像的方式 1、基于已有鏡像進行創建。 根據官方提供的鏡像源&#xff0c;創建鏡像&#xff0c;然后拉起…

IP與以太網的轉發操作

TCP模塊在執行連接、收發、斷開等各階段操作時&#xff0c;都需要委托IP模塊將數據封裝成包發送給通信對象。 網絡中有路由器和集線器兩種不同的轉發設備&#xff0c;它們在傳輸網絡包時有著各自的分工。 (1)路由器根據目標地址判斷下一個路由器的位置 (2)集線器在子網中將網…

docker的鏡像創建 dockerfile

dockerfile Dokcer鏡像的創建 創建鏡像有三種方法&#xff0c;分別為【基于已有鏡像創建】、【基于本地模板創建】以及【基于Dockerfile創建】。 &#xff08;1&#xff09;首先啟動一個鏡像&#xff0c;在容器里做修改 docker run -itd --name web centos:7 /bin/bash …

k8s pod日志寫入ELK的具體實現

shigen堅持更新文章的博客寫手&#xff0c;擅長Java、python、vue、shell等編程語言和各種應用程序、腳本的開發。記錄成長&#xff0c;分享認知&#xff0c;留住感動。 在上一部分&#xff0c;shigen講到了k8spod的日志寫入ELK的三種技術方案&#xff0c;并在最后展示了一下我…

QMainWindow和QWidget有什么區別

2023年12月12日&#xff0c;周二上午 QMainWindow 和 QWidget 是 Qt 框架中兩個不同的類&#xff0c;用于創建用戶界面的窗口部件。它們之間的主要區別在于它們的設計和用途。 QMainWindow: QMainWindow 是用于創建主窗口的類&#xff0c;通常包含了一個應用程序的主要界面。…

NFR 數字權益開發流程

NFR 在技術開發領域通常指的是“非功能性需求”&#xff08;Non-Functional Requirements&#xff09;&#xff0c;這些是描述系統屬性如安全性、性能、可用性、兼容性等方面的需求。然而&#xff0c;如果在這里 NFR 被用來指代與數字權益或非同質化代幣&#xff08;NFT&#x…

C++ 構造函數 調用方法

構造函數 調用方法 //括號法&#xff08;常用&#xff09; Person p1(100); //有參構造 Person p2(p1); //拷貝構造//注意&#xff1a;不要用括號法調用無參構造&#xff0c;會和 函數聲明 混淆。//顯示法 Person p3 Person(); //無參構造 Person p4 Person(100); //有參構…

【USRP】LFTX / LFRX

LFTX/LFRX 設備概述 LFTX 子板利用兩個高速運算放大器來允許 0-30 MHz 的傳輸。該板僅接受實模式信號。LFTX 非常適合 HF 頻段的應用&#xff0c;或使用外部前端來上變頻和放大中間信號的應用。LFTX 的輸出可以獨立處理&#xff0c;也可以作為單個 I/Q 對進行處理。 主要特征…

Python - 搭建 Flask 服務實現圖像、視頻修復需求

目錄 一.引言 二.服務構建 1.主函數 upload_gif 2.文件接收 3.專屬目錄 4.圖像修復 5.gif2mp4 6.mp42gif 7.圖像返回 三.服務測試 1.服務啟動 2.服務調用 四.總結 一.引言 前面我們介紹了如何使用 Real-ESRGAN 進行圖像增強并在原始格式 jpeg、jpg、mp4 的基礎上…