您好,登錄后才能下訂單哦!
本篇內容介紹了“Unity渲染管線流程是怎樣的”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
下圖是《Unity Shader 入門精要》一書中的渲染流程圖;
ApplicationStage階段:準備場景信息(視景體,攝像機參數)、粗粒度剔除、定義每個模型的渲染命令(材質,shader)——由開發者定義,不做討論;
GemetryStage階段:頂點著色器、曲面細分著色器、幾何著色器、裁剪、屏幕映射;
RasterizerStage階段:三角形設置遍歷,片元著色器、逐片元操作;
每個階段具體操作如下圖(虛線框是可選階段):
模型空間——矩陣變換——齊次裁剪空間——透視除法——NDC標準設備坐標——屏幕映射
齊次裁剪空間是視景體空間(臺體);
CVV:標準視體-也就是NDC坐標系對應的空間;
透視除法:頂點坐標除以w分量,將當前z深度所在的截面縮放為(2,2,2)的截面坐標;所以w分量記錄了z深度信息;
硬件做透視除法獲得NDC歸一化設備坐標——再經過屏幕映射獲得屏幕坐標系下頂點坐標;
Unity使用OpenGL的NDC,z分量在[-1,1];
OpenGL和DirectX差異
NDC空間——OpenGL為[-1,1],DirectX為[0,1],深度z范圍不同;
窗口坐標系——DirectX左上角原點,OpenGL左下角原點;
投影平面——DirectX投影平面就是視景體近截面,OpenGL有視平面;
左右手坐標系——DirectX左手,OpenGL右手,叉乘順序;
為什么片元不叫像素?
片元是很多狀態的集合,記錄了該像素的屏幕坐標,深度信息,法線,UV等;
DrawCall為什么會影響性能?
DrawCall是CPU向GPU添加渲染命令的過程,過程會由CPU向GPU發送數據(模型信息),DrawCall的次數越多CPU消耗性能就越大,DrawCall次數過多會導致每一幀CPU來不及發送全部數據給GPU渲染;
GPU有一個命令緩存區(Command Buffer),CPU的渲染命令都會存儲在這里,GPU從命令緩存區依次執行渲染命令;
兩種渲染命令:渲染模型(CPU提交模型信息也就是DrawCall)和改變渲染狀態(著色器紋理狀態改變,更耗時);
一般情況都是GPU渲染完成等待CPU發渲染命令;
“Unity渲染管線流程是怎樣的”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。