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

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

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

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

四遍的繪制過(guò)程如下:
  • pass 1:從光源看過(guò)去,繪制場(chǎng)景深度,寫(xiě)入最后的COLOR,這個(gè)COLOR最終被繪制到g_pShadowSurf這個(gè)RenderTarget,深度模板表面保存在g_pShadowDepth(這個(gè)暫時(shí)不知道怎么用)
  • Pass 2:
  1. 不計(jì)算光照,利用VS繪制從視點(diǎn)看過(guò)去的場(chǎng)景z值深度,輸出一個(gè)POSITION和一個(gè)TEXTURE0,其中TEXTURE0保存了從光源到該點(diǎn)的深度(使用了紋理矩陣來(lái)處理從視點(diǎn)可見(jiàn)的點(diǎn)即可得到),此紋理輸出給PS使用。
  2. 在PS中,為每一個(gè)紋理g_pShadowMap上的像素點(diǎn),構(gòu)造它周圍的3*3的表示的紋理坐標(biāo)數(shù)組,并遍歷該數(shù)組取得紋理顏色值(也就是從光源看到的場(chǎng)景深度值),同從視點(diǎn)看到的點(diǎn)的對(duì)應(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é)公式我沒(méi)有查,大概看不懂,還望高手指點(diǎn)。
  • Pass4:這二遍做垂直模糊。
  • Pass 5:繪制場(chǎng)景,逐像素的計(jì)算光照,并將模糊后的shadow mask信息和聚光燈貼圖應(yīng)用到場(chǎng)景中。

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

Feedback

# re: 基于shadow map的軟陰影生成過(guò)程祥解 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ù)  更多評(píng)論
  

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            在线播放豆国产99亚洲| 91久久午夜| 亚洲激情国产精品| 国语自产偷拍精品视频偷| 欧美精品二区三区四区免费看视频| 久久久蜜桃一区二区人| 久久久久免费视频| 免费视频一区| 欧美日韩一区二| 欧美日韩在线三区| 国产夜色精品一区二区av| 在线播放日韩专区| 亚洲乱码久久| 亚欧成人精品| 老司机免费视频一区二区| 欧美激情片在线观看| 一本大道久久a久久精品综合| 亚洲一区二区三| 久久久久久穴| 欧美日韩国产黄| 国产精品午夜电影| 亚洲国产成人不卡| 亚洲欧美制服中文字幕| 国产精品香蕉在线观看| 国一区二区在线观看| 亚洲精品极品| 欧美一区二区三区婷婷月色| 噜噜噜噜噜久久久久久91| 99热这里只有精品8| 久久精品亚洲| 国产精品福利片| 91久久精品国产91久久| 午夜精品视频在线观看一区二区| 欧美77777| 亚洲欧美色婷婷| 欧美色视频在线| 亚洲日本中文字幕| 久久躁狠狠躁夜夜爽| 亚洲免费观看视频| 毛片一区二区三区| 国模套图日韩精品一区二区| 亚洲一二三区视频在线观看| 欧美激情1区2区3区| 小黄鸭视频精品导航| 欧美日韩国产免费| 91久久久在线| 牛牛国产精品| 欧美在线视频观看免费网站| 国产精品日韩欧美一区二区三区| 亚洲精品欧美日韩专区| 免费日韩av| 久久精品国产免费观看| 国产偷久久久精品专区| 欧美一进一出视频| 中文在线资源观看视频网站免费不卡| 欧美激情2020午夜免费观看| 在线激情影院一区| 久久一二三四| 久久精品国产清自在天天线| 国产一区激情| 久久影音先锋| 久久精品三级| 在线观看欧美激情| 男女av一区三区二区色多| 久久精品中文字幕一区| 国产一区二区| 久久综合九色综合欧美就去吻| 亚洲天堂免费在线观看视频| 欧美日韩一级大片网址| 一区二区三区三区在线| 99视频日韩| 国产精品亚洲激情| 久久精品国产亚洲一区二区三区| 亚洲新中文字幕| 国产麻豆9l精品三级站| 性欧美暴力猛交69hd| 亚洲欧美日韩视频二区| 国产亚洲激情在线| 美女任你摸久久| 欧美国产三区| 亚洲欧美日韩在线综合| 亚洲欧美激情四射在线日| 国产亚洲一区二区三区在线观看| 影音先锋日韩资源| 欧美大片免费观看| 欧美激情在线狂野欧美精品| 亚洲一二三区视频在线观看| 午夜精品国产更新| 91久久精品国产91久久| 一级成人国产| 国产在线精品一区二区夜色| 亚洲二区精品| 国产精品爽爽爽| 欧美岛国激情| 国产精品久久久久久久第一福利| 久久九九热免费视频| 欧美国产国产综合| 欧美在线免费看| 欧美激情1区2区3区| 性感少妇一区| 欧美麻豆久久久久久中文| 久久精品在线观看| 欧美视频在线一区二区三区| 久久久久久久性| 欧美日韩精品欧美日韩精品一| 欧美一区二区在线免费播放| 老司机一区二区| 欧美在线免费视频| 欧美日本一区二区高清播放视频| 欧美在线视频免费| 欧美日本国产一区| 欧美成人在线影院| 国产精品综合| 亚洲理伦在线| 亚洲日本久久| 久久精品国产免费观看| 亚洲欧美成人网| 欧美精品久久久久久久| 免费在线观看日韩欧美| 国产精品美女www爽爽爽| 亚洲欧洲视频| 亚洲三级影片| 麻豆9191精品国产| 久久综合九色综合久99| 国产精品日本欧美一区二区三区| 亚洲黄色毛片| 亚洲高清色综合| 久久久久.com| 久久蜜桃av一区精品变态类天堂| 国产精品国产三级国产普通话三级 | 久久久亚洲高清| 午夜一区不卡| 欧美午夜精品久久久久免费视| 欧美黄色精品| 亚洲国产影院| 女女同性精品视频| 免费成人高清在线视频| 在线观看日产精品| 久久天天躁夜夜躁狠狠躁2022| 久久精品人人做人人综合| 国产麻豆午夜三级精品| 亚洲免费中文字幕| 国产一区二区高清| 欧美一区深夜视频| 久久这里有精品视频| 在线播放视频一区| 欧美电影在线免费观看网站| 亚洲国产成人在线播放| 91久久精品国产| 欧美岛国激情| 日韩午夜av在线| 午夜在线视频观看日韩17c| 国产麻豆日韩| 欧美在线日韩在线| 欧美bbbxxxxx| 亚洲久久一区| 国产精品第一区| 午夜免费在线观看精品视频| 久久久噜噜噜久噜久久| 亚洲国产日韩在线一区模特| 欧美激情影院| 亚洲一区久久| 欧美风情在线| 亚洲免费婷婷| 伊人成人在线| 欧美日韩一区三区四区| 午夜日韩在线| 欧美高清影院| 亚洲性色视频| 一区免费观看视频| 欧美日韩成人| 久久国产精品久久久久久| 欧美成人精品一区| 亚洲视频一区| 尤物在线精品| 欧美四级剧情无删版影片| 香蕉成人啪国产精品视频综合网| 另类尿喷潮videofree| 亚洲新中文字幕| 影音先锋亚洲一区| 国产精品久久久久久av福利软件 | 狠狠色丁香婷婷综合| 欧美高清在线一区| 性色av一区二区怡红| 亚洲精品在线视频| 久久精品国产v日韩v亚洲| 一本色道精品久久一区二区三区| 国产精品午夜av在线| 欧美激情精品久久久久| 欧美在线一二三| aa日韩免费精品视频一| 免费观看欧美在线视频的网站| 亚洲一区久久| av成人黄色| 精品不卡一区| 国产欧美日韩视频在线观看 | 尤物99国产成人精品视频| 欧美日韩综合精品| 欧美男人的天堂| 麻豆精品传媒视频|