青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

實時陰影繪制技術研究

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

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

四遍的繪制過程如下:
  • pass 1:從光源看過去,繪制場景深度,寫入最后的COLOR,這個COLOR最終被繪制到g_pShadowSurf這個RenderTarget,深度模板表面保存在g_pShadowDepth(這個暫時不知道怎么用)
  • Pass 2:
  1. 不計算光照,利用VS繪制從視點看過去的場景z值深度,輸出一個POSITION和一個TEXTURE0,其中TEXTURE0保存了從光源到該點的深度(使用了紋理矩陣來處理從視點可見的點即可得到),此紋理輸出給PS使用。
  2. 在PS中,為每一個紋理g_pShadowMap上的像素點,構造它周圍的3*3的表示的紋理坐標數組,并遍歷該數組取得紋理顏色值(也就是從光源看到的場景深度值),同從視點看到的點的對應深度值,逐一進行比較。使得周圍8個點中看到光源的點越多,最后輸出的Color的值就越大,最小為0.1,最大為1。
  3. 該pass的顏色輸出到紋理g_pSceneSurf,深度模板表面保存在g_pNewDetphSurf中。
  • Pass 3:
  1. 利用高斯函數pass2中得到的shadow mask進行模糊,這一遍做水平模糊
  2. //
    // Gaussian functions(高斯函數)
    //
    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 );
    ??? ??? }
    ??? }
    }
    具體的數學公式我沒有查,大概看不懂,還望高手指點。
  • Pass4:這二遍做垂直模糊。
  • Pass 5:繪制場景,逐像素的計算光照,并將模糊后的shadow mask信息和聚光燈貼圖應用到場景中。

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

Feedback

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

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲国产成人久久综合| 久久精品日韩欧美| 久久久久.com| 亚洲欧美日韩视频二区| 亚洲一区三区在线观看| 亚洲在线不卡| 欧美亚洲一区| 久久综合中文色婷婷| 嫩模写真一区二区三区三州| 免费美女久久99| 亚洲国产精品福利| 亚洲激情亚洲| 一本色道久久综合狠狠躁篇的优点| 一区二区三区欧美成人| 中日韩美女免费视频网站在线观看 | 久久久久久久久一区二区| 久久久久国产精品一区三寸| 久热国产精品视频| 欧美日韩网址| 国产在线麻豆精品观看| 亚洲高清三级视频| 中文高清一区| 久久国产精品亚洲77777| 裸体一区二区| 亚洲日本无吗高清不卡| 午夜精品一区二区在线观看 | 久久久xxx| 欧美v国产在线一区二区三区| 亚洲第一主播视频| 亚洲欧美日韩国产一区| 久久男人资源视频| 欧美日韩中文在线| 黑人操亚洲美女惩罚| 99这里只有久久精品视频| 久久国产一二区| 亚洲欧洲日产国产综合网| 香蕉乱码成人久久天堂爱免费| 裸体歌舞表演一区二区| 亚洲欧洲一区二区三区在线观看| 一区二区日韩伦理片| 久久久精品日韩欧美| 欧美性猛交99久久久久99按摩| 国产亚洲va综合人人澡精品| 亚洲精品视频在线观看网站| 欧美一区激情| 一区二区三区国产在线| 理论片一区二区在线| 国产亚洲精品高潮| 亚洲一区免费观看| 亚洲黄色天堂| 久久婷婷人人澡人人喊人人爽| 国产区亚洲区欧美区| 在线一区欧美| 亚洲国产日韩欧美在线动漫| 久久美女艺术照精彩视频福利播放| 国产精品欧美日韩久久| 亚洲深夜福利在线| 亚洲精品一区二区三区婷婷月 | 午夜在线精品偷拍| 国产精品国产三级国产普通话三级| 亚洲黄网站黄| 欧美国产一区二区三区激情无套| 欧美在线视频播放| 国产欧美一区二区在线观看| 亚洲一区免费网站| 日韩一级免费观看| 欧美色123| 亚洲欧美国产毛片在线| 亚洲一级一区| 国产精品久久久久77777| 亚洲视频在线二区| 一区二区三区**美女毛片| 欧美日韩亚洲91| 午夜久久一区| 午夜一区不卡| 一色屋精品视频在线看| 欧美成人精品福利| 欧美黄色成人网| 亚洲一区二区三区四区中文 | 欧美大片国产精品| 日韩一级黄色大片| 在线视频你懂得一区二区三区| 欧美日韩不卡在线| 亚洲欧美日韩一区二区| 亚洲欧美一区二区激情| 狠狠久久五月精品中文字幕| 欧美国产精品v| 欧美精品久久久久久久久老牛影院| 亚洲精品综合| 中文无字幕一区二区三区| 国产精品免费视频xxxx| 久久狠狠一本精品综合网| 久久综合九色99| 亚洲视频成人| 欧美亚洲一区二区在线| 尤物视频一区二区| 日韩午夜电影| 久久久久综合| av成人老司机| 久久国产一区二区| 99视频有精品| 午夜一区二区三视频在线观看| 在线欧美电影| 亚洲视频一区在线观看| 国产一区免费视频| 亚洲黄色成人网| 国产亚洲欧美在线| 日韩视频在线观看一区二区| 国产精品一区=区| 亚洲国产日韩一区二区| 国产午夜精品全部视频在线播放| 亚洲国产精品成人| 国产在线高清精品| 日韩一级欧洲| 亚洲人成在线影院| 性久久久久久久久| 亚洲少妇自拍| 欧美高清在线播放| 久久中文精品| 国产精品美女一区二区在线观看| 六十路精品视频| 欧美视频日韩视频| 亚洲黄一区二区三区| 国内不卡一区二区三区| 99热在线精品观看| 亚洲精品乱码久久久久久日本蜜臀| 香港成人在线视频| 亚洲一区久久久| 欧美激情视频网站| 欧美高清视频在线观看| 国产精品色午夜在线观看| 亚洲欧洲在线看| 亚洲日韩欧美一区二区在线| 久久久中精品2020中文| 久久久夜夜夜| 国产亚洲成av人片在线观看桃| 一本色道久久综合亚洲精品按摩| 91久久国产综合久久蜜月精品| 久久久噜噜噜久久狠狠50岁| 欧美一站二站| 国产在线精品一区二区夜色| 香蕉乱码成人久久天堂爱免费 | 亚洲欧美中日韩| 欧美日韩一区二区三区在线观看免| 亚洲第一精品福利| 亚洲国产裸拍裸体视频在线观看乱了中文 | 亚洲欧美精品在线观看| 欧美日韩一二三区| 亚洲区欧美区| 国产精品99久久久久久久久| 欧美日本国产精品| 亚洲一区二区免费视频| 欧美三级视频在线播放| 99riav国产精品| 亚洲视频日本| 国产精品久久久久免费a∨大胸| 一区二区三区久久网| 亚洲专区在线| 国产欧美日韩精品一区| 午夜电影亚洲| 欧美jizz19性欧美| 亚洲麻豆视频| 国产精品久久激情| 欧美一区综合| 亚洲电影在线播放| 亚洲免费影院| 精品不卡一区| 欧美日韩在线播放三区四区| 亚洲女人天堂av| 欧美插天视频在线播放| 99国产精品99久久久久久粉嫩| 国产精品国产三级国产aⅴ浪潮| 先锋影院在线亚洲| 亚洲精品黄色| 久久精品国产91精品亚洲| 亚洲第一天堂av| 欧美婷婷久久| 久久久免费av| 亚洲视频导航| 欧美成人精品激情在线观看| av成人免费在线观看| 国产亚洲成精品久久| 欧美.www| 先锋影音网一区二区| 亚洲日韩视频| 免费h精品视频在线播放| 99国产精品| 韩国女主播一区| 欧美日韩精品一本二本三本| 欧美呦呦网站| 日韩亚洲欧美在线观看| 久久久99免费视频| 亚洲欧美日韩在线| 亚洲精品久久久久久下一站| 国产毛片一区二区| 欧美日韩八区| 美玉足脚交一区二区三区图片| 亚洲欧美另类国产| 日韩视频精品在线| 欧美成人亚洲成人|