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

實時陰影繪制技術研究

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 苦行僧 閱讀(3882) 評論(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>
            国产伦精品一区| 一区二区三区欧美在线观看| 欧美日本精品| 久久黄色网页| 久久精品亚洲乱码伦伦中文| 欧美专区亚洲专区| 欧美在线视频播放| 久久国产欧美日韩精品| 久久久久久久性| 老司机一区二区三区| 欧美福利视频网站| 欧美日韩一级视频| 国产日韩精品一区二区浪潮av| 国产精品色婷婷| 国产一区二区三区久久精品| 亚洲国产成人久久综合| 日韩午夜电影在线观看| 性娇小13――14欧美| 久久综合伊人77777麻豆| 亚洲第一色在线| 亚洲美女在线看| 午夜精品国产精品大乳美女| 久久先锋资源| 国产精品久久久久久久免费软件 | 夜夜精品视频| 欧美一区二区三区视频免费播放 | 男女激情久久| 国产精品成人一区二区三区吃奶 | 亚洲区免费影片| 午夜伦欧美伦电影理论片| 久久在线免费| 日韩一区二区福利| 久久一区激情| 国产美女精品视频免费观看| 亚洲人成网在线播放| 久久成人国产精品| 日韩一区二区精品| 久久人91精品久久久久久不卡| 欧美视频一区二区三区四区| 亚洲国产日韩一区二区| 性欧美video另类hd性玩具| 亚洲国产欧美在线人成| 久久成人免费网| 国产精品乱子乱xxxx| 99视频在线观看一区三区| 欧美 日韩 国产 一区| 午夜精品久久久久久久99黑人 | 国产亚洲一区在线| 国产一级揄自揄精品视频| 亚洲高清电影| 久久久久国内| 亚洲一区免费看| 欧美日韩亚洲国产精品| 最新国产成人在线观看| 可以看av的网站久久看| 欧美伊人精品成人久久综合97 | 久久久久久综合| 国产日韩欧美一区二区三区在线观看| 一本色道88久久加勒比精品| 欧美成人一品| 久久一区二区视频| 亚洲大片免费看| 麻豆精品视频在线| 久久人人爽人人爽爽久久| 国产真实乱偷精品视频免| 性视频1819p久久| 亚洲欧美激情一区| 国产视频一区在线观看| 欧美中文字幕在线观看| 亚洲欧美日韩直播| 国产综合网站| 久久综合九色综合久99| 久久激情视频久久| 亚洲高清资源综合久久精品| 亚洲电影免费在线| 欧美国产日韩在线观看| 99精品国产福利在线观看免费| 亚洲片在线资源| 欧美日本一区二区三区| 亚洲午夜国产成人av电影男同| 中国成人在线视频| 国产一区二区观看| 亚洲福利视频一区| 国产精品福利av| 久久青草久久| 欧美日韩国产在线播放| 欧美亚洲免费电影| 久久久精品日韩欧美| 亚洲伦理精品| 艳女tv在线观看国产一区| 国产视频一区二区在线观看| 欧美激情精品| 国产精品久久综合| 久久视频在线看| 欧美日韩大片| 久久免费视频在线观看| 欧美母乳在线| 久久亚洲精品欧美| 欧美日韩国产精品自在自线| 久久gogo国模啪啪人体图| 欧美成年人网| 久久人人爽人人爽爽久久| 欧美日韩在线三级| 欧美ed2k| 国产日本亚洲高清| 亚洲精选久久| 在线日韩日本国产亚洲| 亚洲视频在线观看一区| 亚洲图片欧洲图片av| 亚洲一级一区| 美女91精品| 欧美三级日韩三级国产三级 | 欧美v亚洲v综合ⅴ国产v| 欧美日韩国产三级| 麻豆国产精品一区二区三区| 国产精品成人国产乱一区| 亚洲第一福利视频| 韩国一区二区三区在线观看 | av成人福利| 在线日韩欧美视频| 久久国产日本精品| 欧美夜福利tv在线| 欧美日韩在线观看一区二区三区| 鲁大师影院一区二区三区| 欧美日韩国产黄| 亚洲国产一区二区视频| 在线不卡欧美| 久久久久久网站| 久久色中文字幕| 国产偷国产偷亚洲高清97cao| 一本久久a久久免费精品不卡| 亚洲激情午夜| 麻豆亚洲精品| 亚洲国产二区| 亚洲人成网站999久久久综合| 久久久精品动漫| 久久久久一区二区| 国产三级精品三级| 欧美亚洲一区二区在线| 先锋资源久久| 国产精品自在在线| 午夜国产欧美理论在线播放| 欧美亚洲在线播放| 国产日韩欧美另类| 欧美影院一区| 麻豆成人精品| 亚洲丰满在线| 欧美成人有码| 99ri日韩精品视频| 亚洲综合999| 国产欧美一区二区精品仙草咪| 午夜亚洲性色福利视频| 久久综合免费视频影院| 亚洲国产精品久久91精品| 欧美成人免费大片| 99在线热播精品免费| 欧美一级免费视频| 激情一区二区| 欧美精品综合| 亚洲制服欧美中文字幕中文字幕| 亚洲欧美国产精品桃花| 国产午夜精品理论片a级大结局 | 久久av免费一区| 在线播放豆国产99亚洲| 欧美大秀在线观看| 中文有码久久| 久久综合狠狠综合久久激情| 亚洲国产欧美一区| 欧美日韩欧美一区二区| 麻豆精品精华液| 亚洲一区二区三区在线视频| 国产精品高清一区二区三区| 亚洲一区视频在线观看视频| 久久久久久久一区二区| 亚洲高清在线| 国产精品欧美久久久久无广告| 久久精品亚洲国产奇米99| 亚洲精品婷婷| 久久久中精品2020中文| 亚洲天堂成人| 一区二区在线视频| 国产精品成人一区二区网站软件| 久久九九免费| 在线亚洲激情| 欧美高清一区二区| 久久精品国产亚洲精品| 一区二区免费在线视频| 国产一级久久| 在线亚洲电影| 国产深夜精品| 女仆av观看一区| 亚洲视频一区在线观看| 欧美国产亚洲视频| 欧美制服丝袜第一页| 一本色道久久综合| 亚洲第一天堂无码专区| 国产精品老牛| 欧美日韩国产在线播放网站| 久久九九99视频| 午夜精品视频|