Ignore:
Timestamp:
11/06/08 13:31:58 (16 years ago)
Author:
mattausch
Message:

updated shader programs

Location:
GTP/trunk/App/Demos/Vis/FriendlyCulling/src
Files:
6 edited

Legend:

Unmodified
Added
Removed
  • GTP/trunk/App/Demos/Vis/FriendlyCulling/src/DeferredRenderer.cpp

    r3103 r3104  
    321321        sCgGiProgram = sm->CreateFragmentProgram("globillum", "main", "giFrag"); 
    322322        sCgCombineIllumProgram = sm->CreateFragmentProgram("globillum", "combine", "combineGi"); 
    323         sCgCombineSsaoProgram = sm->CreateFragmentProgram("combineSsao", "combine", "combineSsao"); 
     323        //sCgCombineSsaoProgram = sm->CreateFragmentProgram("combineSsao", "combine", "combineSsao"); 
     324        sCgCombineSsaoProgram = sm->CreateFragmentProgram("ssao", "combine", "combineSsao"); 
    324325        sCgAntiAliasingProgram = sm->CreateFragmentProgram("antialiasing", "main", "antiAliasing"); 
    325326        sCgToneProgram = sm->CreateFragmentProgram("tonemap", "ToneMap", "toneMap"); 
     
    327328        sCgLogLumProgram = sm->CreateFragmentProgram("tonemap", "CalcAvgLogLum", "avgLogLum"); 
    328329 
    329         int i; 
    330  
    331         i = 0; 
    332         sCgSsaoProgram->AddParameter("colors", i ++); 
    333         sCgSsaoProgram->AddParameter("normals", i ++); 
    334         sCgSsaoProgram->AddParameter("oldTex", i ++); 
    335         sCgSsaoProgram->AddParameter("noiseTex", i ++); 
    336         sCgSsaoProgram->AddParameter("temporalCoherence", i ++); 
    337         sCgSsaoProgram->AddParameter("samples", i ++); 
    338         sCgSsaoProgram->AddParameter("bl", i ++); 
    339         sCgSsaoProgram->AddParameter("br", i ++); 
    340         sCgSsaoProgram->AddParameter("tl", i ++); 
    341         sCgSsaoProgram->AddParameter("tr", i ++); 
    342         sCgSsaoProgram->AddParameter("modelViewProj", i ++); 
    343         sCgSsaoProgram->AddParameter("oldModelViewProj", i ++); 
    344  
    345         sCgSsaoProgram->AddParameter("oldEyePos", i ++); 
    346         sCgSsaoProgram->AddParameter("oldbl", i ++); 
    347         sCgSsaoProgram->AddParameter("oldbr", i ++); 
    348         sCgSsaoProgram->AddParameter("oldtl", i ++); 
    349         sCgSsaoProgram->AddParameter("oldtr", i ++); 
    350          
    351         i = 0; 
    352         sCgGiProgram->AddParameter("colors", i ++); 
    353         sCgGiProgram->AddParameter("normals", i ++); 
    354         sCgGiProgram->AddParameter("noiseTex", i ++); 
    355         sCgGiProgram->AddParameter("oldSsaoTex", i ++); 
    356         sCgGiProgram->AddParameter("oldIllumTex", i ++); 
    357         sCgGiProgram->AddParameter("temporalCoherence", i ++); 
    358         sCgGiProgram->AddParameter("samples", i ++); 
    359         sCgGiProgram->AddParameter("bl", i ++); 
    360         sCgGiProgram->AddParameter("br", i ++); 
    361         sCgGiProgram->AddParameter("tl", i ++); 
    362         sCgGiProgram->AddParameter("tr", i ++); 
    363         sCgGiProgram->AddParameter("oldModelViewProj", i ++); 
    364         sCgGiProgram->AddParameter("modelViewProj", i ++); 
    365  
    366         sCgAntiAliasingProgram->AddParameter("colors", 0); 
    367         sCgAntiAliasingProgram->AddParameter("normals", 1); 
    368  
    369         sCgDeferredProgram->AddParameter("colors", 0); 
    370         sCgDeferredProgram->AddParameter("normals", 1); 
    371         sCgDeferredProgram->AddParameter("lightDir", 2); 
     330 
     331        /////////////////// 
     332        //-- initialize program parameters 
     333 
     334        string ssaoParams[] =  
     335                {"colors", "normals", "oldTex", "noiseTex", "temporalCoherence",  
     336                 "samples", "bl", "br", "tl", "tr", "modelViewProj", "oldModelViewProj", 
     337                 "oldEyePos", "oldbl", "oldbr", "oldtl", "oldtr"}; 
     338        sCgSsaoProgram->AddParameters(ssaoParams, 0, 17); 
     339         
     340        string giParams[] =  
     341                {"colors", "normals", "noiseTex", "oldSsaoTex", "oldIllumTex",  
     342                 "temporalCoherence", "samples", "bl", "br", "tl", "tr", "oldModelViewProj", "modelViewProj"}; 
     343        sCgGiProgram->AddParameters(giParams, 0, 13); 
     344 
     345        string toneParams[] = {"colors", "imageKey", "whiteLum", "middleGrey"}; 
     346        sCgToneProgram->AddParameters(toneParams, 0, 4); 
     347 
     348 
     349        //////////////// 
     350 
     351        string deferredShadowParams[] =  
     352                {"colors", "normals", "shadowMap", "noiseTex", "shadowMatrix",  
     353                 "sampleWidth", "lightDir", "eyePos", "samples", "weights"}; 
     354         
     355        sCgDeferredShadowProgram->AddParameters(deferredShadowParams, 0, 10); 
     356         
     357        //////////////// 
     358 
     359        string combineIllumParams[] = {"colorsTex", "ssaoTex", "illumTex"}; 
     360        sCgCombineIllumProgram->AddParameters(combineIllumParams, 0, 3); 
     361 
     362        //////////////// 
     363 
     364        string combineSsaoParams[] = {"colorsTex", "ssaoTex", "filterOffs", "filterWeights"}; 
     365        sCgCombineSsaoProgram->AddParameters(combineSsaoParams, 0, 4); 
     366 
     367        ////////////// 
     368 
     369        string deferredParams[] = {"colors", "normals", "lightDir"}; 
     370        sCgDeferredProgram->AddParameters(deferredParams, 0, 3); 
     371 
     372        /////////////////// 
     373 
     374        string aaParams[] = {"colors", "normals"}; 
     375        sCgAntiAliasingProgram->AddParameters(aaParams, 0, 2); 
     376 
     377        ///////////////////// 
     378 
     379        string downSampleParams[] = {"colors", "downSampleOffs"}; 
     380        sCgDownSampleProgram->AddParameters(downSampleParams, 0, 2); 
     381 
     382        //////////// 
    372383 
    373384        sCgLogLumProgram->AddParameter("colors", 0); 
    374385         
    375         sCgToneProgram->AddParameter("colors", 0); 
    376         sCgToneProgram->AddParameter("imageKey", 1); 
    377         sCgToneProgram->AddParameter("whiteLum", 2); 
    378         sCgToneProgram->AddParameter("middleGrey", 3); 
    379  
    380         sCgDownSampleProgram->AddParameter("colors", 0); 
    381         sCgDownSampleProgram->AddParameter("downSampleOffs", 1); 
    382  
    383         sCgDeferredShadowProgram->AddParameter("colors", 0); 
    384         sCgDeferredShadowProgram->AddParameter("normals", 1); 
    385         sCgDeferredShadowProgram->AddParameter("shadowMap", 2); 
    386         sCgDeferredShadowProgram->AddParameter("noise", 3); 
    387         sCgDeferredShadowProgram->AddParameter("shadowMatrix", 4); 
    388         sCgDeferredShadowProgram->AddParameter("sampleWidth", 5); 
    389         sCgDeferredShadowProgram->AddParameter("lightDir", 6); 
    390         sCgDeferredShadowProgram->AddParameter("eyePos", 7); 
    391         sCgDeferredShadowProgram->AddParameter("samples", 8); 
    392         sCgDeferredShadowProgram->AddParameter("weights", 9); 
    393  
    394         sCgCombineIllumProgram->AddParameter("colors", 0); 
    395         sCgCombineIllumProgram->AddParameter("ssaoTex", 1); 
    396         sCgCombineIllumProgram->AddParameter("illumTex", 2); 
    397  
    398         sCgCombineSsaoProgram->AddParameter("colorsTex", 0); 
    399         sCgCombineSsaoProgram->AddParameter("normalsTex", 1); 
    400         sCgCombineSsaoProgram->AddParameter("ssaoTex", 2); 
    401         sCgCombineSsaoProgram->AddParameter("filterOffs", 3); 
    402         sCgCombineSsaoProgram->AddParameter("filterWeights", 4); 
     386         
     387         
     388        /////////// 
     389 
    403390 
    404391        PoissonDiscSampleGenerator2 poisson(NUM_SSAO_FILTERSAMPLES, 1.0f); 
     
    744731        glDrawBuffers(1, mrt + colorBufferIdx); 
    745732 
    746         sCgCombineSsaoProgram->SetTexture(0, colorsTex); 
    747         sCgCombineSsaoProgram->SetTexture(1, normalsTex); 
    748         sCgCombineSsaoProgram->SetTexture(2, ssaoTex); 
    749  
    750         sCgCombineSsaoProgram->SetArray2f(3, (float *)ssaoFilterOffsets, NUM_SSAO_FILTERSAMPLES); 
    751         sCgCombineSsaoProgram->SetArray1f(4, (float *)ssaoFilterWeights, NUM_SSAO_FILTERSAMPLES); 
     733        int i = 0; 
     734        sCgCombineSsaoProgram->SetTexture(i ++, colorsTex); 
     735        //sCgCombineSsaoProgram->SetTexture(i ++, normalsTex); 
     736        sCgCombineSsaoProgram->SetTexture(i ++, ssaoTex); 
     737 
     738        sCgCombineSsaoProgram->SetArray2f(i ++, (float *)ssaoFilterOffsets, NUM_SSAO_FILTERSAMPLES); 
     739        sCgCombineSsaoProgram->SetArray1f(i ++, (float *)ssaoFilterWeights, NUM_SSAO_FILTERSAMPLES); 
    752740         
    753741        DrawQuad(sCgCombineSsaoProgram); 
     
    976964        Matrix4x4 matViewing, matProjection; 
    977965 
     966        // hack: temporarily change far to improve precision 
     967        const float oldFar = mCamera->GetFar(); 
     968        mCamera->SetFar(1e3f); 
     969        //mCamera->SetFar(1e2f); 
     970 
     971 
    978972        //mCamera->GetModelViewMatrix(matViewing); 
    979973        mCamera->GetViewOrientationMatrix(matViewing); 
     
    10171011        glPushAttrib(GL_VIEWPORT_BIT); 
    10181012        glViewport(0, 0, mWidth, mHeight); 
     1013        // revert to old far plane 
     1014        mCamera->SetFar(oldFar); 
    10191015} 
    10201016 
  • GTP/trunk/App/Demos/Vis/FriendlyCulling/src/ShaderProgram.cpp

    r3046 r3104  
    363363 
    364364 
     365void ShaderProgram::AddParameters(std::string params[],  
     366                                                                  int startIdx,  
     367                                                                  int numElements) 
     368{ 
     369        for (int i = 0; i < numElements; ++ i) 
     370        { 
     371                AddParameter(params[i], startIdx + i); 
     372        } 
     373} 
     374 
     375 
    365376CGparameter ShaderProgram::GetOrCreateParameter(const string &name) 
    366377{ 
  • GTP/trunk/App/Demos/Vis/FriendlyCulling/src/ShaderProgram.h

    r3046 r3104  
    199199        */ 
    200200        CGparameter AddParameter(const std::string &name, int idx); 
    201  
     201        /** Comvenience method that adds an array of parameters beginning with 
     202                index i of size numElements 
     203        */ 
     204        void AddParameters(std::string params[], int startIdx, int numElements); 
    202205 
    203206        ////////////// 
  • GTP/trunk/App/Demos/Vis/FriendlyCulling/src/shaders/deferred.cg

    r3099 r3104  
    231231        const float currentDepth = currentPos.z * precisionScale; 
    232232 
    233         const float2 ao = ssao(IN, colors, noise, samples, normal,  
     233        const float2 ao = ssao(IN, colors, noiseTex, samples, normal,  
    234234                                   eyeSpacePos, w, bl, br, tl, tr, normalize(viewDir)); 
    235235 
  • GTP/trunk/App/Demos/Vis/FriendlyCulling/src/shaders/globillum.cg

    r3103 r3104  
    254254 
    255255pixel combine(fragment IN,  
    256                           uniform sampler2D colors, 
     256                          uniform sampler2D colorsTex, 
    257257                          uniform sampler2D ssaoTex, 
    258258                          uniform sampler2D illumTex 
     
    261261        pixel OUT; 
    262262 
    263         float4 col = tex2Dlod(colors, float4(IN.texCoord, 0, 0)); 
     263        float4 col = tex2Dlod(colorsTex, float4(IN.texCoord, 0, 0)); 
    264264        float ao = tex2Dlod(ssaoTex, float4(IN.texCoord, 0, 0)).x; 
    265265 
  • GTP/trunk/App/Demos/Vis/FriendlyCulling/src/shaders/ssao.cg

    r3103 r3104  
    354354        return OUT; 
    355355} 
     356 
     357float Filter(float2 texCoord,  
     358                         uniform sampler2D ssaoTex, 
     359                         uniform float2 filterOffs[NUM_SSAO_FILTERSAMPLES], 
     360                         uniform float filterWeights[NUM_SSAO_FILTERSAMPLES]) 
     361{ 
     362        float average = .0f; 
     363        float w = .0f; 
     364 
     365        for (int i = 0; i < NUM_SSAO_FILTERSAMPLES; ++ i) 
     366        { 
     367                average += filterWeights[i] * tex2Dlod(ssaoTex, float4(texCoord + filterOffs[i], 0, 0)).x; 
     368                w += filterWeights[i]; 
     369        } 
     370 
     371        average *= 1.0f / (float)w; 
     372 
     373        return average; 
     374} 
     375 
     376 
     377pixel combine(fragment IN,  
     378                          uniform sampler2D colorsTex, 
     379                          uniform sampler2D ssaoTex, 
     380                          uniform float2 filterOffs[NUM_SSAO_FILTERSAMPLES], 
     381                          uniform float filterWeights[NUM_SSAO_FILTERSAMPLES] 
     382                          ) 
     383{ 
     384        pixel OUT; 
     385 
     386        float4 col = tex2Dlod(colorsTex, float4(IN.texCoord, 0, 0)); 
     387        float4 ao = tex2Dlod(ssaoTex, float4(IN.texCoord, 0, 0)); 
     388 
     389        //if (ao.y < 10.0f) ao.x = Filter(IN.texCoord, ssaoTex, filterOffs, filterWeights); 
     390 
     391        //OUT.illum_col = col * ao.x; 
     392        //OUT.illum_col = float4(ao.y, ao.y, ao.y, col.w); 
     393        //OUT.illum_col = float4(ao.x, ao.x, ao.x, col.w); 
     394        OUT.illum_col.xyz = float3(1.0f - ao.x, 1.0f - ao.y * 1e-2f, 1); 
     395        //OUT.illum_col.xyz = float3(1.0f - ao.x, ao.y, 0); 
     396        OUT.illum_col.w = col.w; 
     397 
     398        return OUT; 
     399} 
Note: See TracChangeset for help on using the changeset viewer.