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

            黎明的剔透里伸出了你沁清的曖昧

            Graphics|EngineDev|GameDev|2D&3D Art

              C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              60 隨筆 :: 1 文章 :: 18 評(píng)論 :: 0 Trackbacks
            Projective Texture:shadow的基礎(chǔ) 在fixed function pipline中啟動(dòng)自動(dòng)生成貼圖坐標(biāo)功能后,用object linear模式或者eye linear模式來(lái)設(shè)置紋理參數(shù),這樣就可以把紋理從眼睛的觀察方向投射到場(chǎng)景中去,如果要從光源方向投射紋理,就要使用glActiveTextureARB首先把那一層的紋理單元激活,然后載入光源方向的透視觀察矩陣,最后別忘了glEnable(GL_TEXTUREn_ARB).
            在shader中我們可以簡(jiǎn)化這些操作:
            投影紋理映射真正的流程是 “ 根據(jù)投影機(jī)(視點(diǎn)相機(jī))的位置、投影角度,物體的坐標(biāo),求出每個(gè)頂點(diǎn)所對(duì)應(yīng)的紋理坐標(biāo),然后依據(jù)紋理坐標(biāo)去查詢紋理值 ” ,也就是說(shuō),不是將紋理投影到墻上,而是把墻投影到紋理上。投影紋理坐標(biāo)的求得,也與紋理本身沒(méi)有關(guān)系,而是由投影機(jī)的位置、角度,以及 3D 模型的頂點(diǎn)坐標(biāo)所決定
            .projtexcoord=偏移矩陣 * 光源投影矩陣 * 光源觀察矩陣 * 建模矩陣 ( Cg Tutorial
            這個(gè)流程和一般我們渲染時(shí)的管線差不多
            NDC的范圍為[-1,1],而紋理坐標(biāo)是[0,1],所以我們要有一個(gè)偏移矩陣,可以用乘以0.5再加上0.5來(lái)計(jì)算,效果是一樣的。
            在shader上實(shí)現(xiàn)沒(méi)有使用fixed function pipline那樣繁瑣,使用前面已經(jīng)用到的Bank BRDF anisotropy 光照來(lái)渲染
            Vertex Shader:
             1uniform vec3 lightposition;
             2uniform vec3 eyeposition;
             3uniform mat4 texMatrix;
             4varying float  NdotL, NdotH, NdotV, VdotH, LdotT, VdotT;
             5varying vec4 projtexcoord;
             6void main(void){
             7    
             8    vec3 objPosition = vec3 (gl_ModelViewMatrix * gl_Vertex);
             9    vec3 Normal = normalize (gl_NormalMatrix * gl_Normal);
            10    vec3 LightDir = normalize (lightposition - objPosition);
            11    vec3 EyeDir = normalize (eyeposition - objPosition);
            12    vec3 HalfVec = normalize (LightDir + EyeDir);
            13    
            14    vec3 TangVec = normalize(cross(Normal, EyeDir));
            15
            16    NdotL = max(dot(Normal, LightDir), 0.0);
            17    LdotT = max(dot(LightDir, TangVec), 0.0);
            18    VdotT = max(dot(EyeDir, TangVec), 0.0);
            19
            20    projtexcoord = texMatrix*vec4(objPosition,1.0);
            21    projtexcoord = 0.5 * (projtexcoord + 1.0);
            22
            23    gl_Position = ftransform();
            24}

            Frag  Shader:
             1uniform vec4 ambient;
             2uniform vec4 DiffuseLightColor;
             3uniform vec4 SpecularLightColor;
             4uniform float shininess;
             5uniform sampler2D ProjectiveTexture;
             6varying float NdotL, NdotH, NdotV, VdotH, LdotT, VdotT ;
             7varying vec4 projtexcoord;
             8
             9float diff=0.1;
            10float spec=1.0;
            11void main(void)
            12     float sqrt1 = sqrt(1.0 - pow(LdotT, 2.0));
            13     float sqrt2 = sqrt(1.0 - pow(VdotT, 2.0)); 
            14     float Rs=sqrt1*sqrt2 - LdotT*VdotT;
            15     vec3 diffuse = diff * vec3(DiffuseLightColor) * NdotL;
            16     float BRDF = spec * pow(Rs,shininess);
            17     vec3 specular =BRDF *vec3(SpecularLightColor) * NdotL;
            18 
            19     vec4 Color = vec4((diffuse + specular),1.0); 
            20     Color =Color+ ambient;
            21 
            22     vec4 texcolor=texture2DProj(ProjectiveTexture,projtexcoord );
            23
            24     gl_FragColor =Color * texcolor;
            25}

            effect:
            object1:

            object2:

            object3:

            參考:
            http://blog.csdn.net/pizi0475/article/details/6714826
            http://blog.csdn.net/pizi0475/article/details/6714813


            posted on 2012-03-09 03:00 情絕格調(diào)(fresmaster) 閱讀(4289) 評(píng)論(3)  編輯 收藏 引用 所屬分類: Graphics

            評(píng)論

            # re: GLSL.Projective Texture Mapping 2015-05-05 21:01 Zi_菜
            您好,我想看看實(shí)例的代碼,請(qǐng)問(wèn)可以給我一份么?  回復(fù)  更多評(píng)論
              

            # re: GLSL.Projective Texture Mapping 2015-05-05 21:15 Zi_菜
            如果方便的話,我的郵箱是lacp7723413@163.com  回復(fù)  更多評(píng)論
              

            # re: GLSL.Projective Texture Mapping 2016-08-11 10:42 www.czgo.net
            《環(huán)球頭條網(wǎng)》www.czgo.net在這里我們?yōu)槟峁┤珖?guó)各地以及國(guó)內(nèi)外最新的新聞快訊內(nèi)容、新聞、時(shí)事熱點(diǎn)新聞,網(wǎng)涵蓋了國(guó)內(nèi)外各大報(bào)社,包括國(guó)內(nèi)外社會(huì),軍事,財(cái)經(jīng),娛樂(lè),體育,汽車,科技,房產(chǎn),教育,游戲,旅游,奇聞趣事,美女圖庫(kù)等各個(gè)領(lǐng)域多個(gè)欄目的新聞資訊。環(huán)球頭條網(wǎng)是一個(gè)全面展現(xiàn)社會(huì)萬(wàn)象、人生百態(tài)的新聞資訊網(wǎng)。  回復(fù)  更多評(píng)論
              

            精品久久久久中文字幕一区| 国产精品成人无码久久久久久| 国产精品对白刺激久久久| 亚洲欧洲久久av| 国产精品久久久久久久久久免费| 97久久精品午夜一区二区| 久久精品国产网红主播| 青青草原精品99久久精品66| 亚洲国产精品无码久久98| 久久久久亚洲AV无码专区首JN | 久久久网中文字幕| 国产精品久久久久久影院| 久久精品天天中文字幕人妻| 国产精品成人久久久| 亚洲欧美日韩精品久久| 狠狠色综合久久久久尤物| 国产精品热久久无码av| 一本大道加勒比久久综合| 精品国产91久久久久久久 | 久久久久国产精品麻豆AR影院| 久久久久国色AV免费看图片| 久久人人爽人人爽人人片AV不 | 久久综合给合久久狠狠狠97色| 高清免费久久午夜精品| 国产精品成人99久久久久| 久久亚洲2019中文字幕| 亚洲成色www久久网站夜月| 久久综合丁香激情久久| 蜜臀久久99精品久久久久久| 久久天天躁狠狠躁夜夜avapp| 国产毛片久久久久久国产毛片| 欧美精品九九99久久在观看| av午夜福利一片免费看久久 | 香蕉久久影院| 亚洲午夜精品久久久久久浪潮| 99精品久久久久久久婷婷| 国产精品美女久久久久网| 国产精品成人久久久| 国产精品VIDEOSSEX久久发布 | 久久国产精品视频| 一本色综合网久久|