• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            posts - 94, comments - 250, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            Nebula3渲染層: Graphics

            Posted on 2008-12-14 22:02 Condor 閱讀(614) 評論(0)  編輯 收藏 引用

            圖形子系統(tǒng)是渲染層中圖形相關子系統(tǒng)的最高層. 它基本上是Mangalore圖形子系統(tǒng)的下一個版本, 但是現(xiàn)在整合進了Nebula, 并且與低層的渲染代碼結合得更加緊密. 最基本的思想是實現(xiàn)一個完全自治的圖形”世界”, 它包含模型, 燈光, 還有攝像機實體, 而且只需要與外部世界進行最少的通信. 圖形世界的最主要操作是加入和刪除實體, 還有更新它們的位置.
            因為Mangalore的圖形子系統(tǒng)跟Nebula2的完全分界線從Nebula3中移除了, 很多設想都可以用更少的代碼和交互來實現(xiàn).
            圖形子系統(tǒng)也會為了異步渲染而多線程化, 它和所有的底層渲染子系統(tǒng)都會生存在它們自己的fat-thread中. 這本應是Nebula3層次結構中更高級的東西, 但是我選擇了這個位置, 因為這是游戲跟渲染相關通信最少的一部分代碼. 正是因為圖形代碼有了更多的”自治權”, 游戲相關的代碼可以跟圖形以完全不同的幀率來運行, 不過這需要實踐來證明一下. 但是我一定會嘗試, 因為完全沒有必要讓游戲邏輯代碼運行在10幀以上(格斗游戲迷們可能會反對吧).
            圖形子系統(tǒng)中最重要的公有類有:

            • ModelEntity
            • CameraEntity
            • LightEntity
            • Stage
            • View

            一個ModelEnity表示了一個可見的圖形對象, 它包括位置, 包圍體和內(nèi)嵌的Model資源. 一個Model資源是一個完全的3D模型, 包括幾何體, 材質(zhì), 動畫, 層級變換等…(后面會提到).
            一個CameraEntity描述了圖形世界中的一個視景體, 為渲染提供View和Project矩陣.
            一個LightEntity描述了一個動態(tài)光源. Nebula3的光源屬性還沒有最終確定, 但是我的目標是一個相對靈活地近似(最后一個光源不會超過幾個shader參數(shù)).
            Stage和View是Nebula3圖形子系統(tǒng)新增的內(nèi)容. 在Mangalore中, 圖形實體是生存在一個單獨的圖形Level類里, 任何時候只能有一個Level和一個攝像機. 這對于只需要渲染一個世界到幀緩存(frame buffer)的情況來說還是不錯的. 但許多游戲程序需要更復雜的渲染, 如在GUI中渲染一個使用單獨燈光的3D對象, 而它又跟其它的圖形世界是隔離的. 還有反射或像監(jiān)視器之類的東西都需要一個額外的視口, 諸如此類. 在Mangalore中, 這個問題通過OffscreenRenderer類得到解決, 雖說比較容易使用, 但是具有一些使用限制并且需要更多事后的思考.
            Nebula3提供了一個基于State和View的更加簡潔的解決方案. 一個Stage就是一個圖形實體的容器, 表示一個圖形世界. 同一時間可能存在多個Stage, 但是它們之間是互相隔絕的. 每個實體在一個時刻只連接到了一個Stage(雖說克隆一個已有實體是一件很簡單的事情). 除了簡單地把實體組織到一起外, Stage的主要工作是根據(jù)它們之間的關系來加速可見性查詢. 應用程序可以派生Stage的子類來實現(xiàn)完全不同的可見性查詢方案.
            一個View對象通過一個CameraEnity渲染stage到一個RenderTarget. 任何stage都可以連接任意數(shù)量的View對象. View對象可能會互相依賴(也可能是連接到不同stage的View), 所以更新一個View會首先強制更新另一個View的RenderTarget(這在一個View渲染需要使用另一個View的RenderTarget做為紋理時很方便). View對象完全實現(xiàn)了自己的渲染循環(huán). 應用程序可以在View的子類中方便地實現(xiàn)它自己的渲染策略(如每個light一個pass VS 每個pass多個light, 渲染到cubemap, 等等).
            總而言之, 一個Stage完全控制了可見性查詢流程, 而一個View則完全控制了渲染流程.
            圖形子系統(tǒng)的一個最主要的工作就是根據(jù)可見性查詢的結果來決定哪些實體需要被渲染. 一個可見性查詢在實體間建立了一個雙向的鏈接, 它有兩種形式: 攝像機鏈接和燈光鏈接. 攝像機鏈接把一個攝像機和在它視景體內(nèi)的模型連接到了一起. 因為鏈接是雙向的, 所以攝像機知道所有的在它視景體范圍內(nèi)的模型, 而模型也知道所有可以看到它的攝像機. 燈光鏈接在燈光與模型之間建立了相似的關系, 一個燈光具有所有受它影響的模型的鏈接, 一個模型也知道所有影響它的燈光.
            加速可見性查詢最重要的類就是Cell類. 一個Cell是一個圖形實體和子Cell的可見性容器, 它必須遵循2條簡單的規(guī)則:

            1. 如果一個Cell是完全可見的, 那么它所有的圖形實體和子Cell都必須可見.
            2. 如果一個Cell是完全不可見的, 那么它所有的圖形實體和子Cell都必須不可見.

            Cell是附屬于Stage的, 它們形成了一棵有根Cell的樹形層次結構. 標準的Cell支持簡單的空間劃分方案, 如四叉樹和八叉樹, 但如果像其它的可見性方案, 如portal, 就需要派生Cell的子類來實現(xiàn)了. 子類唯一的功能限制就是上面標出的那兩條規(guī)則.
            當一個圖形體連接到一個Stage時, 它會被插入”接受” (通常僅僅是容納)它的最低級的Cell中. 當更新圖形實體的變換信息或改變包圍體時, 它會根據(jù)需要改變在Cell層次中的位置.
            Stage居住在StageBuilder類當中, 應用程序應當派生StageBuilder來創(chuàng)建一個Stage的初始狀態(tài)(通過加入Cell和實體). Nebula3會提供一些標準的StageBuilder集合, 這應該能夠滿足大多數(shù)應用程序的需要了.
            這只是圖形子系統(tǒng)的一個粗略的概述. 因為當前只有一個最基本的實現(xiàn), 很多細節(jié)接下來可能會有所更改.

            97精品依人久久久大香线蕉97 | 精品久久久久久无码国产| 精品久久久无码人妻中文字幕豆芽 | 99精品国产综合久久久久五月天| 久久精品亚洲AV久久久无码| 亚洲国产精品久久久久婷婷软件| 久久婷婷午色综合夜啪| 久久精品国产免费| 久久精品麻豆日日躁夜夜躁| 伊色综合久久之综合久久| 久久亚洲春色中文字幕久久久| 国内精品久久久久影院亚洲| 久久国产精品免费一区| 久久精品国产久精国产果冻传媒 | 一本一道久久精品综合| 久久久亚洲欧洲日产国码是AV| 国产精品久久久久久久久| 天天爽天天狠久久久综合麻豆| 亚洲欧洲精品成人久久奇米网| 久久久久国产一区二区| 久久精品亚洲福利| 久久AV高清无码| 国产99久久久国产精品小说| 久久国产精品偷99| 99久久久精品免费观看国产| 偷偷做久久久久网站| 国产免费久久久久久无码| 久久久久这里只有精品 | 久久午夜福利电影| 久久天天躁狠狠躁夜夜96流白浆 | 久久国产成人午夜AV影院| 久久99精品久久只有精品| 久久久久av无码免费网| 久久亚洲精品国产亚洲老地址| 亚洲美日韩Av中文字幕无码久久久妻妇 | 欧美精品一本久久男人的天堂| 国内精品免费久久影院| 久久99精品久久久久久9蜜桃| 91精品国产综合久久久久久| 久久人人爽人人爽人人AV| 狠狠色丁香久久婷婷综合|