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

實時陰影繪制技術研究

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>
            欧美成人一区二区在线 | 欧美一级二级三级蜜桃| 亚洲第一伊人| 久久精品一区二区三区四区| 国产麻豆精品theporn| 亚洲七七久久综合桃花剧情介绍| 亚洲午夜一区二区三区| 国产精品久久久久久久久免费樱桃| 一本一本久久a久久精品综合妖精| 亚洲激情成人在线| 欧美日韩三区四区| 性色av一区二区三区在线观看| 亚洲欧美日韩精品一区二区| 国产一区二区毛片| 久久久777| 欧美成人久久| 在线一区二区日韩| 亚洲欧美日韩精品久久久| 国产一区二区中文字幕免费看| 欧美国产一区二区在线观看| 欧美日韩国产小视频| 午夜精品一区二区三区四区| 久久精品成人一区二区三区蜜臀 | 免费在线看成人av| 一本色道久久综合| 亚洲欧美卡通另类91av| 亚洲国产毛片完整版| 日韩视频欧美视频| 激情欧美日韩一区| 亚洲精品综合精品自拍| 国产在线视频欧美一区二区三区| 亚洲国产精品成人| 国产毛片精品国产一区二区三区| 免费观看成人www动漫视频| 欧美人与性动交a欧美精品| 久久激情综合| 欧美老女人xx| 免费观看久久久4p| 国产精品免费福利| 亚洲黄色免费| 在线欧美亚洲| 欧美一区二区视频网站| 一区二区成人精品| 久久这里只精品最新地址| 日韩午夜在线视频| 欧美日韩亚洲在线| 蜜桃av久久久亚洲精品| 国产伦精品一区二区三区高清版| 亚洲第一在线| 亚洲国产精品久久久久婷婷884 | 久久激情一区| 国产精品视频专区| 亚洲精品一区久久久久久| 在线精品视频一区二区| 亚洲天堂av高清| 在线一区欧美| 欧美激情一区二区三区 | 亚洲日本中文字幕| 久久久久久久久久久久久女国产乱| 亚洲一区久久| 欧美三级在线视频| 99re8这里有精品热视频免费 | 老司机午夜精品视频| 国产精品乱码妇女bbbb| 亚洲国产免费| 亚洲黄色片网站| 久久久久久久综合狠狠综合| 欧美在线日韩精品| 国产偷国产偷亚洲高清97cao| 一区二区三区www| 亚洲色在线视频| 欧美日韩高清一区| 亚洲色无码播放| 亚洲欧美一区二区激情| 国产麻豆日韩| 久久精品日产第一区二区三区| 久久精品国产一区二区电影| 国产亚洲欧美一区二区| 久久精品夜色噜噜亚洲a∨| 免费欧美日韩| 日韩视频免费在线观看| 欧美精品123区| 日韩性生活视频| 亚洲欧美另类在线观看| 国产精品永久免费| 欧美在线视频免费观看| 美女精品在线| 亚洲精品一区二区在线| 欧美日韩国产丝袜另类| 亚洲影院在线观看| 美女精品在线观看| 99这里有精品| 国产日韩欧美制服另类| 久久久久久色| 一本色道久久加勒比88综合| 午夜日本精品| 在线免费观看日本欧美| 欧美日韩色综合| 欧美在线观看视频一区二区三区 | 久久疯狂做爰流白浆xx| 国内精品免费在线观看| 欧美高清在线一区| 欧美精品一区二区三区久久久竹菊| 伊人成人在线视频| 欧美大片免费看| 亚洲视频图片小说| 玖玖综合伊人| 亚洲网站视频| 国产综合久久久久久| 欧美伦理影院| 午夜性色一区二区三区免费视频| 农村妇女精品| 性久久久久久久久久久久| 亚洲高清自拍| 国产欧美亚洲日本| 欧美激情第4页| 久久精品青青大伊人av| 亚洲视频你懂的| 亚洲第一综合天堂另类专| 欧美一区二区三区在线视频| 亚洲激情在线观看| 国产一区二区精品久久99| 欧美日韩国产成人高清视频| 久久久综合香蕉尹人综合网| 亚洲一本视频| 亚洲精品一区在线| 亚洲电影在线| 麻豆国产精品一区二区三区| 亚洲欧美清纯在线制服| 一区二区三区成人精品| 亚洲黄色在线视频| 亚洲电影自拍| 在线观看亚洲精品视频| 国产午夜精品久久久| 国产精品高潮粉嫩av| 欧美精品亚洲精品| 欧美xx视频| 老司机免费视频一区二区三区| 欧美专区一区二区三区| 亚洲欧美另类在线| 午夜精品久久一牛影视| 午夜精品久久久久久99热| 99视频精品全国免费| 亚洲国产精品一区二区三区| 蜜桃av综合| 免费成人你懂的| 免费毛片一区二区三区久久久| 久久日韩精品| 麻豆成人在线观看| 欧美高清视频www夜色资源网| 美女视频黄免费的久久| 免费一区二区三区| 美女视频黄a大片欧美| 欧美激情91| 亚洲激情一区二区| 99国内精品久久| 一区二区三区国产在线观看| 国产精品99久久久久久久久| 亚洲午夜久久久久久久久电影网| 夜夜嗨一区二区| 性欧美精品高清| 欧美在线不卡| 欧美风情在线| 欧美日韩在线高清| 国产精品女人久久久久久| 国产精品久久久对白| 国产精品裸体一区二区三区| 国产日韩欧美中文在线播放| 国语精品中文字幕| 亚洲国产一区二区a毛片| 在线视频亚洲欧美| 午夜精品网站| 欧美a级片网| 亚洲欧洲在线观看| 亚洲伊人观看| 久久综合给合久久狠狠狠97色69| 欧美护士18xxxxhd| 国产精品视频一二三| 在线观看欧美| 亚洲欧美日韩国产一区二区| 免费国产一区二区| 欧美不卡视频一区| 国产视频在线观看一区 | 久久精品国产综合精品| 欧美人与禽猛交乱配视频| 国产乱理伦片在线观看夜一区| 加勒比av一区二区| 亚洲性线免费观看视频成熟| 久久福利精品| 一区二区三区视频在线| 久久久噜噜噜久久| 国产精品a久久久久| 1024成人| 欧美中文字幕在线视频| 亚洲精品久久久久久久久| 欧美一级大片在线免费观看| 欧美精品免费视频| 精品999日本| 欧美在线网站| 宅男在线国产精品|