• <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
            Cook Torrance 模型將物體粗糙表面看做很多微小平面組成,每一個(gè)微小平面都被看做一個(gè)理想的鏡面反射,物體表面粗糙程度由微平面斜率的變化來(lái)衡量,一個(gè)粗糙表面由一些列斜率變化很大的微平面組成,而相對(duì)平滑的微平面斜率變化很小,
            Vertex shader:
             1uniform vec3 lightposition;//光源為位置
             2uniform vec3 eyeposition;//相機(jī)位置
             3varying float  NdotL, NdotH, NdotV, VdotH ;
             4void main(void){
             5
             6    vec3 objPosition = vec3 (gl_ModelViewMatrix * gl_Vertex);
             7    vec3 Normal = normalize (gl_NormalMatrix * gl_Normal);
             8    vec3 LightDir = normalize (lightposition - objPosition);
             9    vec3 EyeDir = normalize (eyeposition - objPosition);
            10    vec3 HalfVec = normalize (LightDir + EyeDir);
            11
            12    NdotL = max(dot(Normal, LightDir), 0.0);
            13    NdotH = max(dot(Normal, HalfVec), 0.0);
            14    NdotV = max(dot(Normal, EyeDir), 0.0);
            15    VdotH = max(dot(EyeDir, HalfVec), 0.0);
            16
            17    gl_Position = ftransform();
            18}
            Frag Shader:
             1uniform sampler2D tex;
             2uniform vec4 ambient;//環(huán)境光顏色
             3uniform vec4 DiffuseLightColor;//漫反射光源顏色
             4uniform vec4 SpecularLightColor;//specular光源顏色
             5varying float NdotL, NdotH, NdotV, VdotH ;
             6float diff=0.1;
             7float spec=1.0;
             8void main(void){  
             9    float m = 0.6;//物體表面粗超程度
            10    float f0 = 0.9;//入射角接近0時(shí)候的菲涅爾反射系數(shù)
            11
            12    float Fresnel = f0 + (1.0 - f0) * pow((1.0 - VdotH), 5.0);
            13    float Droughness = (pow(NdotH, 2.0)-1.0/ (m * m * pow(NdotH,2.0)); 
            14    float Drough = (1.0 / m * m * pow(NdotH,4.0)) * exp(Droughness);
            15    float G1 = (2.0 * NdotH * NdotL) / VdotH;
            16    float G2 = (2.0 * NdotH * NdotV) / VdotH;
            17    float Geometric= min(1.0, min(G1, G2));
            18
            19    float Rs = (Fresnel * Drough * Geometric) / (NdotV * NdotL);
            20
            21    vec3 diffuse = diff * vec3(DiffuseLightColor) * NdotL;
            22    vec3 specular = spec * vec3(SpecularLightColor) * Rs;
            23
            24    vec4 Color = vec4((diffuse + specular),1.0); 
            25      gl_FragColor = Color;
            26}
            f0系數(shù)的設(shè)置對(duì)反射的亮度有一定的影響。  此處設(shè)置的比較大,一般近似取f0=pow((1.0 - VdotH), 4.0);
            Effect:
            Object1

            object2

            posted on 2012-03-05 19:08 情絕格調(diào)(fresmaster) 閱讀(2663) 評(píng)論(2)  編輯 收藏 引用 所屬分類: Graphics

            評(píng)論

            # re: GLSL.Cook Torrance Model 2013-02-18 23:54 杯具Graphic
            vec3 specular = spec * vec3(SpecularLightColor) * Rs;
            這句有錯(cuò)啊,應(yīng)該再乘一個(gè) NdotL ,看了很多資料我就為了驗(yàn)證某“陽(yáng)春白雪下里巴人”上的錯(cuò)誤...路過(guò)這順便糾正下  回復(fù)  更多評(píng)論
              

            # re: GLSL.Cook Torrance Model 2013-04-11 12:28 情絕格調(diào)(fresmaster)
            應(yīng)該不用再乘NdotL了吧,乘NdotL的意義何在?Cook-Torrance 光照模型和經(jīng)典光照模型的本質(zhì)區(qū)別在于使用不同的方法計(jì)算鏡面反射光的雙向反射率,Rs在計(jì)算過(guò)程中有一個(gè)除以NdotL的過(guò)程@杯具Graphic  回復(fù)  更多評(píng)論
              

            亚洲国产成人久久一区久久| 91久久婷婷国产综合精品青草| 久久久无码精品午夜| 一本久久综合亚洲鲁鲁五月天| 中文字幕日本人妻久久久免费| 久久青青草原亚洲av无码app| 色综合久久综精品| 久久亚洲精品国产亚洲老地址| av国内精品久久久久影院| 久久综合色之久久综合| 国产精品9999久久久久| 午夜精品久久久久久影视777| 777米奇久久最新地址| 久久99九九国产免费看小说| 天天综合久久久网| 久久人妻无码中文字幕| 国内精品免费久久影院| 久久精品成人免费看| 久久人人妻人人爽人人爽| 中文字幕无码久久精品青草| 久久香蕉国产线看观看99| 国产成人久久精品一区二区三区| 国产精品美女久久久网AV| 久久精品国产亚洲AV嫖农村妇女| 久久人人爽人人爽人人爽| 无码精品久久一区二区三区 | 久久精品国产亚洲AV忘忧草18| 93精91精品国产综合久久香蕉| 久久精品99久久香蕉国产色戒| 亚洲Av无码国产情品久久| 国产叼嘿久久精品久久| 夜夜亚洲天天久久| 久久久精品一区二区三区| 久久线看观看精品香蕉国产| 国产一区二区精品久久| 国产成人精品久久综合| 久久精品国产99国产精品| 久久男人AV资源网站| 无码任你躁久久久久久久| 国产精品乱码久久久久久软件| 久久国产色av免费看|