• <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>

            實(shí)時(shí)陰影繪制技術(shù)研究

            C++博客 首頁 新隨筆 聯(lián)系 聚合 管理
              48 Posts :: 20 Stories :: 57 Comments :: 0 Trackbacks
            英文原文:http://www.gamedev.net/reference/articles/article2193.asp

            在我的前邊文章中有這樣一篇文章,是轉(zhuǎn)載gameres的文章,一直也沒有好好看看。昨天偶然間看到,仔細(xì)研究了一下,讀了一下代碼。

            四遍的繪制過程如下:
            • pass 1:從光源看過去,繪制場景深度,寫入最后的COLOR,這個(gè)COLOR最終被繪制到g_pShadowSurf這個(gè)RenderTarget,深度模板表面保存在g_pShadowDepth(這個(gè)暫時(shí)不知道怎么用)
            • Pass 2:
            1. 不計(jì)算光照,利用VS繪制從視點(diǎn)看過去的場景z值深度,輸出一個(gè)POSITION和一個(gè)TEXTURE0,其中TEXTURE0保存了從光源到該點(diǎn)的深度(使用了紋理矩陣來處理從視點(diǎn)可見的點(diǎn)即可得到),此紋理輸出給PS使用。
            2. 在PS中,為每一個(gè)紋理g_pShadowMap上的像素點(diǎn),構(gòu)造它周圍的3*3的表示的紋理坐標(biāo)數(shù)組,并遍歷該數(shù)組取得紋理顏色值(也就是從光源看到的場景深度值),同從視點(diǎn)看到的點(diǎn)的對應(yīng)深度值,逐一進(jìn)行比較。使得周圍8個(gè)點(diǎn)中看到光源的點(diǎn)越多,最后輸出的Color的值就越大,最小為0.1,最大為1。
            3. 該pass的顏色輸出到紋理g_pSceneSurf,深度模板表面保存在g_pNewDetphSurf中。
            • Pass 3:
            1. 利用高斯函數(shù)pass2中得到的shadow mask進(jìn)行模糊,這一遍做水平模糊
            2. //
              // Gaussian functions(高斯函數(shù))
              //
              float GetGaussianDistribution( float x, float y, float rho ) {
              ??? float g = 1.0f / sqrt( 2.0f * 3.141592654f * rho * rho );
              ??? return g * exp( -(x * x + y * y) / (2 * rho * rho) );
              }

              void GetGaussianOffsets( bool bHorizontal, D3DXVECTOR2 vViewportTexelSize,
              ??? ??? ??? ??? ??? ??? ?D3DXVECTOR2* vSampleOffsets, float* fSampleWeights ) {
              ??? // Get the center texel offset and weight
              ??? fSampleWeights[0] = 1.0f * GetGaussianDistribution( 0, 0, 2.0f );
              ??? vSampleOffsets[0] = D3DXVECTOR2( 0.0f, 0.0f );
              ???
              ??? // Get the offsets and weights for the remaining taps
              ??? if( bHorizontal ) {
              ??? ??? for( int i = 1; i < 15; i += 2 ) {
              ??? ??? ??? vSampleOffsets[i + 0] = D3DXVECTOR2(? i * vViewportTexelSize.x, 0.0f );
              ??? ??? ??? vSampleOffsets[i + 1] = D3DXVECTOR2( -i * vViewportTexelSize.x, 0.0f );

              ??? ??? ??? fSampleWeights[i + 0] = 2.0f * GetGaussianDistribution( float(i + 0), 0.0f, 3.0f );
              ??? ??? ??? fSampleWeights[i + 1] = 2.0f * GetGaussianDistribution( float(i + 1), 0.0f, 3.0f );
              ??? ??? }
              ??? }

              ??? else {
              ??? ??? for( int i = 1; i < 15; i += 2 ) {
              ??? ??? ??? vSampleOffsets[i + 0] = D3DXVECTOR2( 0.0f,? i * vViewportTexelSize.y );
              ??? ??? ??? vSampleOffsets[i + 1] = D3DXVECTOR2( 0.0f, -i * vViewportTexelSize.y );
              ??? ??? ???
              ??? ??? ??? fSampleWeights[i + 0] = 2.0f * GetGaussianDistribution( 0.0f, float(i + 0), 3.0f );
              ??? ??? ??? fSampleWeights[i + 1] = 2.0f * GetGaussianDistribution( 0.0f, float(i + 1), 3.0f );
              ??? ??? }
              ??? }
              }
              具體的數(shù)學(xué)公式我沒有查,大概看不懂,還望高手指點(diǎn)。
            • Pass4:這二遍做垂直模糊。
            • Pass 5:繪制場景,逐像素的計(jì)算光照,并將模糊后的shadow mask信息和聚光燈貼圖應(yīng)用到場景中。

            posted on 2006-06-02 14:02 苦行僧 閱讀(3865) 評論(1)  編輯 收藏 引用 所屬分類: shadow

            Feedback

            # re: 基于shadow map的軟陰影生成過程祥解 2006-12-05 16:46 wu_chung_tang
            利用高斯函數(shù)pass2中得到的shadow mask進(jìn)行模糊
            you can do this in PS not in C++ code, can be fast  回復(fù)  更多評論
              

            69久久精品无码一区二区| 性欧美大战久久久久久久久| 免费观看久久精彩视频| 色综合久久精品中文字幕首页| 久久噜噜电影你懂的| 日韩电影久久久被窝网| 7777久久久国产精品消防器材| 久久影院综合精品| 欧美激情一区二区久久久| 久久91精品国产91| 国产精品视频久久久| 精品国产青草久久久久福利| 99精品国产免费久久久久久下载| 久久国产亚洲精品无码| 思思久久99热免费精品6| 久久精品中文字幕无码绿巨人| 久久久WWW免费人成精品| 奇米影视7777久久精品| 亚洲а∨天堂久久精品| 99国产精品久久久久久久成人热| 久久精品不卡| 94久久国产乱子伦精品免费| 色狠狠久久AV五月综合| 久久久久国产精品麻豆AR影院| …久久精品99久久香蕉国产| 久久免费看黄a级毛片| 色诱久久av| 精品久久久久久久中文字幕| 99精品久久精品| 久久99国产乱子伦精品免费| 伊人久久大香线蕉综合Av| 少妇久久久久久被弄到高潮| 久久精品国产一区二区三区不卡 | 无码人妻少妇久久中文字幕 | 久久久久99精品成人片| 97久久天天综合色天天综合色hd | 狠狠精品久久久无码中文字幕| 99久久人妻无码精品系列| 久久人妻少妇嫩草AV无码专区| 伊人久久综合成人网| 欧洲成人午夜精品无码区久久|