91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

一文梳理LWRP渲染流程

電子設計 ? 來源:電子設計 ? 作者:電子設計 ? 2021-01-20 23:04 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

渲染應用階段

LWRP現(xiàn)在再unity2019已經(jīng)成為默認的管線了,替代了原來的builtin管線,我當前項目用的還是2018.4的lwrp,使用了一段時間,覺得還是想總結(jié)下lwrp的渲染流程??偨Y(jié)過程中也學到了不少東西,所以想在這里分享下我了解的lwrp管線

執(zhí)行應用階段流程順序如下:

pIYBAGAIReWAKyi-AACfdwZ_mIg724.png

o4YBAGAIRi2Aepe2AAC4oK-Sqo8957.png

pIYBAGAIRmuASPEGAAARGfP7fTs383.png

lwrp從結(jié)果來看就是前向渲染的流程,沒有gbuffer保存幾何信息。他實現(xiàn)原理是將不透明渲染,天空盒渲染,透明渲染加入CommandBuffer里,最終一次性提交渲染。其中如果需要Depth或Opaque圖片則可以拷貝到rt輸出到指定全局變量給開發(fā)用。

下面我想說下我了解的lwrp的詳細流程,設計的東西會比較多。也是看代碼的過程中學習了很多東西。

下面分享下:

lwrp整個渲染的主入口在LightweightRenderPipeline,他繼承的RenderPipeline,是rsp的渲染流程關鍵類

首先是構造函數(shù)

PipelineSettings:這里會獲取LightweightRenderPipelineAsset(也就是我們外部傳入的管線的參數(shù))

ScriptableRenderer:srp渲染器,需要把LightweightRenderPipelineAsset傳給他。他是渲染核心,他會收集所有當前幀要渲染的pass,以及他會擁有渲染相關的燈光和后處理等執(zhí)行方法。

PerFrameBuffer:每幀設置的緩存數(shù)據(jù)

_GlossyEnvironmentColor:主要用于PBR這塊的全局光照的顏色,在Lighting.hlsl的GlossyEnvironmentReflection,可以看到他主要是全局光照的高光部分顏色。

_SubtractiveShadowColor:主要用在除了主光源外的lightmap計算的陰影顏色。在SubtractDirectMainLightFromLightmap里使用

PerCameraBuffer:每幀攝像機的緩存數(shù)據(jù)

_InvCameraViewProj:視圖空間到投影空間的轉(zhuǎn)置矩陣,如果用原始矩陣乘以反向矩陣結(jié)果為identity矩陣。如果一些矩陣以一個特定的方式變換向量,反向矩陣可以將他們變換回去。例如worldToLoclaMatrix和localToWorldMatrix是互逆的。

_ScaledScreenParams:屏幕縮放參數(shù)

antiAliasing從asset中獲取msaaSampleCount

Shader.globalRenderPipeline = "LightweightPipeline";設置全局管線為LightweightPipeline

lightsDelegate:全局光照的回調(diào)

執(zhí)行到Render中執(zhí)行具體渲染流程:

SetupPerFrameShaderConstants:設置全局光照的數(shù)據(jù),設置PerFrameBuffer中的_GlossyEnvironmentColor和_SubtractiveShadowColor。

其中_GlossyEnvironmentColor是通過球形諧波方程決定顏色的,最后要轉(zhuǎn)到當前顏色空間(gamma空間或線性空間)

_SubtractiveShadowColor則是直接賦值具體的除去主光源后的陰影顏色,只是也有最后轉(zhuǎn)到當前顏色空間的轉(zhuǎn)換。

對當前Render給過來當前有哪些相機渲染的數(shù)據(jù)來進行每個相機的渲染RenderSingleCamera。

每個相機中的渲染步驟如下:

CullResults.GetCullingParameters:獲取相機下的裁剪參數(shù),如果返回false說明沒有聶榮,不需要渲染這個相機。如果需要考慮到類似vr等情況需要區(qū)分左右眼的攝像機時需要把stereoAware設置為true。

CommandBuffer cmd = CommandBufferPool.Get(k_RenderCameraTag):這里從命令緩存池中獲取一個gl命令緩存,CommandBuffer主要用于收集一系列gl指令,然后之后執(zhí)行。

ProfilingSample是對指定名字做性能采樣。

InitializeCameraData:初始化攝像機數(shù)據(jù)。

cameraData.msaaSamples:如果數(shù)量大于1說明需要多重采樣

cameraData.isSceneViewCamera:這個是查看當前要渲染的是否在unity的scene視圖

cameraData.isOffscreenRender:屏幕外渲染,如果攝像機的targettexture存在并且不是scene視圖則這個為true。

cameraData.isStereoEnabled:就是左右眼做區(qū)別的攝像機,用于vr等

cameraData.isHdrEnabled:是否支持hdr,也就是高動態(tài)范圍圖像,就是可以在高光情況下能看清一些光照細節(jié),提高細節(jié)渲染。

cameraData.postProcessLayer:后處理

cameraData.postProcessEnabled:是否開啟后處理

cameraData.renderScale:渲染縮放比例

cameraData.opaqueTextureDownsampling:降采樣

cameraData.isDefaultViewport:如果是正常的(0,0,1,1)則是默認的

cameraData.maxShadowDistance:最大陰影范圍

cameraData.requiresDepthTexture:是否啟用深度紋理

cameraData.requiresOpaqueTexture:是否保存非透明顏色信息

cameraData.defaultOpaqueSortFlags:默認的非透明渲染順序

SetupPerCameraShaderConstants

PerCameraBuffer._ScaledScreenParams:是一個vector4,包括相機像素的長寬和紋素

PerCameraBuffer._InvCameraViewProj:設置攝像機視角的逆矩陣,通過GL.GetGPUProjectionMatrix獲取到當前gpu正確坐標系的投影矩陣,再跟camera.worldToCameraMatrix視圖矩陣相乘得到視圖到投影的矩陣,再用Matrix4x4.Inverse獲取逆矩陣。

cullingParameters.shadowDistance:設置陰影距離,這里會根據(jù)攝像機最遠渲染距離來獲得最遠可達到的距離。

ScriptableRenderContext.ExecuteCommandBuffer(cmd):執(zhí)行命令緩存

cmd.Clear();清除緩存數(shù)據(jù)

CullResults.Cull:根據(jù)裁剪的參數(shù)cullingParameters和context指定的渲染指令得到裁剪的燈光,物體等。

InitializeRenderingData:初始化渲染相關數(shù)據(jù)

GetMainLight:獲取主光源,如果是直線光并且mainLightRenderingMode不為LightRenderingMode.PerPixel就是主光源

mainLightCastShadows:如果可見光存在而且陰影設置存在則為true

additionalLightsCastShadows:如果additionalLightsRenderingMode是LightRenderingMode.PerPixel并且可見光存在并且lightType是LightType.Spot且陰影存在則為true

InitializeLightData:初始化燈光數(shù)據(jù),這里設置了mainLightIndex(也就是GetMainLight獲取的),設置additionalLightsCount獲取疊加光源的數(shù)量,maxPerObjectAdditionalLightsCount最大疊加光源數(shù)量,shadeAdditionalLightsPerVertex就是是否是疊加光源,visibleLights可視光源,supportsMixedLighting支持混合光源

InitializeShadowData:初始化陰影數(shù)據(jù),如果有多光源會添加LWRPAdditionalLightData到光源的gameobject上,m_ShadowBiasData會設置陰影偏移和陰影發(fā)現(xiàn)偏移,主要用于解決自陰影的問題。supportsMainLightShadows支持主光源陰影 。mainLightShadowCascadesCount是陰影的級聯(lián)個數(shù),(mainLightShadowmapWidth、mainLightShadowmapHeight)主光源陰影貼圖的寬高。mainLightShadowCascadesSplit是陰影的級聯(lián)分割,supportsAdditionalLightShadows是否支持多光源陰影。additionalLightsShadowmapWidth、additionalLightsShadowmapHeight是多光源陰影貼圖的寬和高都是additionalLightsShadowmapResolution。supportsSoftShadows支持軟陰影

supportsDynamicBatching:是否支持動態(tài)批處理,這個是lwrp的動態(tài)批處理

設置完渲染數(shù)據(jù)后就是開始設置渲染的順序了:

renderer.Clear():再設置之前需要清理renderer的數(shù)據(jù),不然前一幀渲染的dc是不會清掉的,dc就會越來越高。

setupToUse.Setup(renderer, ref renderingData):默認lwrp是用DefaultRendererSetup來設置的,當然你也可以實現(xiàn)IRendererSetup然后傳入Render來自己實現(xiàn)。

DefaultRendererSetup:lwrp默認會有一系列渲染過程。會再Setup中確定渲染的先后。

SetupPerObjectLightIndices設置每個對象光照信息

CreateRenderTextureDescriptor創(chuàng)建rt數(shù)據(jù)信息

GetCameraClearFlag獲取當前攝像機清理方式,lwrp對這層做了一些處理,主要是對深度剔除做了一些選項

如果是渲染到紋理則用CreateLightweightRenderTexturesPass這個pass執(zhí)行一次渲染。

如果有渲染前要執(zhí)行的pass要實現(xiàn)IBeforeRender接口,并且可以多個pass

如果支持主光源陰影投放則執(zhí)行MainLightShadowCasterPass的pass

如果支持多光源陰影投放則執(zhí)行AdditionalLightsShadowCasterPass

之后執(zhí)行SetupForwardRenderingPass,這個pass是必然執(zhí)行的,設置攝像機到context里

如果支持深度貼圖獲取的話會執(zhí)行DepthOnlyPass(requiresDepthPrepass決定是否執(zhí)行他),這里會用一個rt保存深度貼圖新消息

如果支持屏幕空間陰影獲取,則會執(zhí)行ScreenSpaceShadowResolvePass,這里會用一個rt記錄屏幕空間中的陰影貼圖

然后執(zhí)行SetupLightweightConstanstPass,主要設置主光源和其他光源的顏色,位置以及其他屬性。如果不設置則會是默認顏色和位置等信息。

然后執(zhí)行RenderOpaqueForwardPass,這個pass定義了兩個pass名,LightweightForward和SRPDefaultUnlit。然后再Execute申請cmd來做不透明渲染。

如果支持后處理則會執(zhí)行OpaquePostProcessPass,里面是申請一個臨時rt做相關不透明的后處理。

如果是相機是天空盒清除方式的話并且天空盒不是空的話則執(zhí)行DrawSkyboxPass,里面會繪制天空盒

如果需要天空盒處理之后執(zhí)行的話需要繼承IAfterSkyboxPass實現(xiàn)相關pass

如果是支持深度貼圖的話并且沒有執(zhí)行requiresDepthPrepass的話(就是前面執(zhí)行DepthOnlyPass的判斷)則會執(zhí)行CopyDepthPass,這里主要是拷貝深度貼圖到全局變量_CameraDepthAttachment中,shader可以直接獲取這個變量(如果有開深度貼圖獲取)

如果開啟了接收不透明貼圖的話則執(zhí)行CopyColorPass,這里主要是把不透明渲染后的顏色輸出到臨時rt中。

然后執(zhí)行RenderTransparentForwardPass,透明渲染方式

如果支持后處理則執(zhí)行TransparentPostProcessPass,也是一樣申請一個臨時rt做相關透明渲染的后處理。如果不需要并且不支持屏幕外渲染并且不是渲染到紋理的則要執(zhí)行FinalBlitPass,這里主要設置貼圖到全局變量_BlitTex,然后把顏色blit到內(nèi)置rt中

然后如果攝像機有IAfterRender的mono則會執(zhí)行pass中的GetPassToEnqueue方法。

最后還會有一個EndXRRenderingPass的渲染,這個是支持立體攝像機的情況下執(zhí)行的,主要是停止立體攝像機渲染

然后再到外面renderer.Execute(context, ref renderingData);也就是把所有pass都執(zhí)行一次。(前面只是加入到列表中,并沒有執(zhí)行每個pass的execute)

最后需要context.Submit來提交渲染,這時相應的gpu才會根據(jù)cmd來執(zhí)行所有的pass

這樣整個渲染流程的應用階段就算完成了,但是其實每個pass里面還有一些處理過程,我還是分到下一章再總結(jié)了!

來源:電子創(chuàng)新網(wǎng)

審核編輯黃昊宇

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 渲染
    +關注

    關注

    0

    文章

    79

    瀏覽量

    11388
  • Unity
    +關注

    關注

    1

    文章

    131

    瀏覽量

    23298
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    梳理氣體流量控制器(MFC)堵塞常見問題

    ,MFC通常因何堵塞?面對這種情況,有哪些通用的排查與處理思路?本文將為您梳理相關的常見知識與預防建議。 ? 、 探尋堵塞的常見誘因:可能阻塞MFC的幾種情況 MFC內(nèi)部流道精密,對污染較為敏感。以下是幾種導致其性能下降或堵
    的頭像 發(fā)表于 11-24 14:43 ?546次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b><b class='flag-5'>梳理</b>氣體流量控制器(MFC)堵塞常見問題

    E203 代碼結(jié)構梳理

    、隊伍介紹 本篇為蜂鳥E203系列分享第五篇,本篇介紹的內(nèi)容是E203 代碼結(jié)構梳理。 二、層次圖 三、模塊具體功能
    發(fā)表于 10-30 06:56

    詳解ROMA中復雜圖表的渲染實現(xiàn)

    、背景 ROMA承接很多復雜圖表的渲染需求,在京東金融APP內(nèi),特別是首頁首屏的圖表,對圖表渲染的及時性要求很高。近期業(yè)務反饋頻繁重啟時,首頁的黃金走勢圖偶現(xiàn)渲染不出的問題,通過
    的頭像 發(fā)表于 10-21 13:57 ?507次閱讀
    詳解ROMA中復雜圖表的<b class='flag-5'>渲染</b>實現(xiàn)

    掌握!探頭維修全流程詳解

    維修的全流程。 、維修前的準備工作 ()了解探頭類型與結(jié)構 不同用途的探頭,其結(jié)構和原理存在較大差異。例如,常見的探頭有示波器探頭、高壓探頭、電流探頭等。以示波器探頭為例,它通常由探針、補償電容、接地夾、
    的頭像 發(fā)表于 09-01 13:42 ?882次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b>掌握!探頭維修全<b class='flag-5'>流程</b>詳解

    從 CPU 到 GPU,渲染技術如何重塑游戲、影視與設計?

    渲染技術是計算機圖形學的核心內(nèi)容之,它是將三維場景轉(zhuǎn)換為二維圖像的過程。渲染技術直在不斷演進,從最初的CPU渲染到后來的GPU
    的頭像 發(fā)表于 09-01 12:16 ?982次閱讀
    從 CPU 到 GPU,<b class='flag-5'>渲染</b>技術如何重塑游戲、影視與設計?

    【匯思博SEEK100開發(fā)板試用體驗】開發(fā)環(huán)境安裝配置

    以下文字,基于SEEK100開發(fā)板試用經(jīng)驗,詳細梳理OpenHarmony開發(fā)環(huán)境搭建的關鍵步驟與避坑要點: 、開發(fā)工具部署:DevEco Studio精準安裝 ??核心版本選擇?? 必須下載
    發(fā)表于 08-20 21:43

    詳解晶圓加工的基本流程

    晶棒需要經(jīng)過系列加工,才能形成符合半導體制造要求的硅襯底,即晶圓。加工的基本流程為:滾磨、切斷、切片、硅片退火、倒角、研磨、拋光,以及清洗與包裝等。
    的頭像 發(fā)表于 08-12 10:43 ?4772次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b>詳解晶圓加工的基本<b class='flag-5'>流程</b>

    單片機開發(fā)流程包括什么?

    單片機開發(fā)是個系統(tǒng)性的工程,從需求明確到最終產(chǎn)品落地,需要經(jīng)歷多個相互關聯(lián)的流程環(huán)節(jié),每個環(huán)節(jié)都對最終產(chǎn)品的性能和質(zhì)量有著重要影響。 、需求分析與文檔梳理 開發(fā)
    的頭像 發(fā)表于 07-22 11:21 ?1007次閱讀

    通道渲染:釋放渲染的全部潛能!通道渲染的作用、類型、技巧

    在3D圖形創(chuàng)作中,渲染通道(RenderPasses)是項至關重要的技術,它通過將復雜的渲染圖像拆分為多個圖層,如陰影、光照、法線等,使藝術家能夠在后期制作中更精準地控制和調(diào)整畫面。我們常常驚嘆于
    的頭像 發(fā)表于 07-15 14:22 ?693次閱讀
    通道<b class='flag-5'>渲染</b>:釋放<b class='flag-5'>渲染</b>的全部潛能!通道<b class='flag-5'>渲染</b>的作用、類型、技巧

    看懂芯片的設計流程

    引言:前段時間給大家做了芯片設計的知識鋪墊(關于芯片設計的些基本知識),今天這篇,我們正式介紹芯片設計的具體流程。芯片分為數(shù)字芯片、模擬芯片、數(shù)?;旌闲酒榷喾N類別。不同類別的設計流程也存在
    的頭像 發(fā)表于 07-03 11:37 ?2577次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b>看懂芯片的設計<b class='flag-5'>流程</b>

    讀懂Allegro先進磁性開關和鎖存器

    開關或鎖存器器件。文中詳細闡釋了區(qū)分 Allegro 開關與鎖存器的關鍵參數(shù),以助力設計師精準定位符合需求的器件。結(jié)論部分總結(jié)了選型流程要點,并梳理了 Allegro 開關和鎖存器的常見應用場景。
    的頭像 發(fā)表于 06-12 17:26 ?1924次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b>讀懂Allegro先進磁性開關和鎖存器

    CPU渲染、GPU渲染、XPU渲染詳細對比:哪個渲染最快,哪個效果最好?

    動畫渲染動畫3D渲染技術需要應對復雜的計算任務和精細的圖像處理,作為渲染技術人員,選擇合適的渲染模式,會直接影響制作效率和成品質(zhì)量。在主流的渲染
    的頭像 發(fā)表于 04-15 09:28 ?1678次閱讀
    CPU<b class='flag-5'>渲染</b>、GPU<b class='flag-5'>渲染</b>、XPU<b class='flag-5'>渲染</b>詳細對比:哪個<b class='flag-5'>渲染</b>最快,哪個效果最好?

    2D圖形渲染緩慢怎么加快?

    我有個圖形應用程序,它似乎渲染屏幕的速度很慢。按下屏幕后,通常需要相當長的時間來更新,大約 50 或 100 毫秒。 在應用程序啟動時,我看到條錯誤消息“GDK 無法創(chuàng)建 GL 上下文,回退
    發(fā)表于 04-02 06:46

    HarmonyOS應用高負載場景分幀渲染

    ,可以采用分幀渲染技術,將原本在幀內(nèi)加載的數(shù)據(jù)分散到多幀中逐步加載,從而減輕單幀的渲染壓力。不過,分幀渲染需要開發(fā)者精確計算每幀加載的數(shù)據(jù)量,操作較為復雜,因此建議僅在性能瓶頸明顯且
    的頭像 發(fā)表于 03-25 10:28 ?1109次閱讀
    HarmonyOS應用高負載場景分幀<b class='flag-5'>渲染</b>

    探索物流CEO大屏及供應鏈大屏是如何做好雙11保障

    大屏的穩(wěn)定性。 ,供應鏈大屏全鏈路流程圖 保障的首要步驟是繪制供應鏈大屏全鏈路流程圖。在梳理出概覽圖之后,深入指標加工的各個細節(jié)去發(fā)現(xiàn)問題,然后是因地制宜的制定保障方案。 下邊是
    的頭像 發(fā)表于 03-12 16:35 ?806次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b>探索物流CEO大屏及供應鏈大屏是如何做好雙11保障