Changeset 3036 for GTP


Ignore:
Timestamp:
10/17/08 01:08:42 (16 years ago)
Author:
mattausch
Message:

shader system starting to work

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

Legend:

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

    r3035 r3036  
    382382        sCgDeferredShadowProgram->AddParameter("weights", 9); 
    383383 
     384        sCgCombineIllumProgram->AddParameter("colors", 0); 
     385        sCgCombineIllumProgram->AddParameter("ssaoTex", 1); 
     386        sCgCombineIllumProgram->AddParameter("illumTex", 2); 
     387 
     388        sCgCombineSsaoProgram->AddParameter("colors", 0); 
     389        sCgCombineSsaoProgram->AddParameter("ssaoTex", 1); 
     390        sCgCombineSsaoProgram->AddParameter("filterOffs", 2); 
     391        sCgCombineSsaoProgram->AddParameter("filterWeights", 3); 
     392 
    384393 
    385394        float filterWeights[NUM_PCF_TABS]; 
     
    726735        glDrawBuffers(1, mrt + colorBufferIdx); 
    727736 
    728         sCgCombineIllumProgram->SetTexture("colors", colorsTex); 
    729         sCgCombineIllumProgram->SetTexture("ssaoTex", ssaoTex); 
    730         sCgCombineIllumProgram->SetTexture("illumTex", illumTex); 
     737        sCgCombineIllumProgram->SetTexture(0, colorsTex); 
     738        sCgCombineIllumProgram->SetTexture(1, ssaoTex); 
     739        sCgCombineIllumProgram->SetTexture(2, illumTex); 
    731740         
    732741        DrawQuad(sCgCombineIllumProgram); 
     
    769778        } 
    770779 
    771         //ComputeSampleOffsets(filterOffsets, fbo->GetWidth(), fbo->GetHeight()); 
    772         sCgCombineSsaoProgram->SetArray2f("filterOffs", (float *)filterOffsets, NUM_DOWNSAMPLES); 
    773         sCgCombineSsaoProgram->SetArray1f("filterWeights", (float *)filterWeights, NUM_DOWNSAMPLES); 
    774  
    775         sCgCombineSsaoProgram->SetTexture("colors", colorsTex); 
    776         sCgCombineSsaoProgram->SetTexture("ssaoTex", ssaoTex); 
     780         
     781        sCgCombineSsaoProgram->SetTexture(0, colorsTex); 
     782        sCgCombineSsaoProgram->SetTexture(1, ssaoTex); 
     783 
     784        sCgCombineSsaoProgram->SetArray2f(2, (float *)filterOffsets, NUM_DOWNSAMPLES); 
     785        sCgCombineSsaoProgram->SetArray1f(3, (float *)filterWeights, NUM_DOWNSAMPLES); 
    777786         
    778787        DrawQuad(sCgCombineSsaoProgram); 
  • GTP/trunk/App/Demos/Vis/FriendlyCulling/src/Material.cpp

    r3034 r3036  
    4444Material::~Material() 
    4545{ 
    46         DEL_PTR(mGPUFragmentParameters); 
    47         DEL_PTR(mGPUVertexParameters); 
     46        //DEL_PTR(mGPUFragmentParameters); 
     47        //DEL_PTR(mGPUVertexParameters); 
    4848} 
    4949 
     
    9393 
    9494 
     95void Material::SetFragmentProgram(ShaderProgram *p)  
     96{  
     97        mFragmentProgram = p;  
     98 
     99        mGPUFragmentParameters->Reset(); 
     100        mGPUFragmentParameters->SetProgram(p); 
    95101} 
     102         
     103 
     104void Material::SetVertexProgram(ShaderProgram *p)  
     105{  
     106        mVertexProgram = p;  
     107 
     108        mGPUVertexParameters->Reset(); 
     109        mGPUVertexParameters->SetProgram(p); 
     110} 
     111 
     112} 
  • GTP/trunk/App/Demos/Vis/FriendlyCulling/src/Material.h

    r3034 r3036  
    8080        void InitMaterial(); 
    8181 
    82         GPUProgramParameters *mGPUVertexParameters; 
    83         GPUProgramParameters *mGPUFragmentParameters; 
     82        void SetFragmentProgram(ShaderProgram *p); 
     83        void SetVertexProgram(ShaderProgram *p); 
    8484 
    85         ShaderProgram *mFragmentProgram; 
    86         ShaderProgram *mVertexProgram; 
     85        ShaderProgram *GetFragmentProgram() { return mFragmentProgram; } 
     86        ShaderProgram *GetVertexProgram() { return mVertexProgram; } 
     87 
     88        void SetFragmentProgramParameters(GPUProgramParameters *p) { mGPUFragmentParameters = p; } 
     89        void SetVertexProgramParameters(GPUProgramParameters *p) { mGPUVertexParameters = p; } 
     90 
     91        GPUProgramParameters *GetFragmentProgramParameters() { return mGPUFragmentParameters; } 
     92        GPUProgramParameters *GetVertexProgramParameters() { return mGPUVertexParameters; } 
     93 
    8794 
    8895protected: 
     
    99106        /// the associated texture 
    100107        Texture *mTexture; 
     108 
     109        GPUProgramParameters *mGPUVertexParameters; 
     110        GPUProgramParameters *mGPUFragmentParameters; 
     111 
     112        ShaderProgram *mFragmentProgram; 
     113        ShaderProgram *mVertexProgram; 
    101114}; 
    102115 
  • GTP/trunk/App/Demos/Vis/FriendlyCulling/src/RenderState.cpp

    r3034 r3036  
    152152        if (mRenderType == DEFERRED) 
    153153        { 
    154                 if (mat->mFragmentProgram && (mat->mFragmentProgram != mCurrentFragmentProgram)) 
    155                 { 
    156                         mCurrentFragmentProgram = mat->mFragmentProgram; 
     154                if (mat->GetFragmentProgram() && (mat->GetFragmentProgram() != mCurrentFragmentProgram)) 
     155                { 
     156                        mCurrentFragmentProgram = mat->GetFragmentProgram(); 
    157157                        mCurrentFragmentProgram->Bind(); 
    158158                } 
    159159         
    160                 if (mat->mVertexProgram && (mat->mVertexProgram != mCurrentVertexProgram)) 
    161                 { 
    162                         mCurrentVertexProgram = mat->mVertexProgram; 
     160                if (mat->GetVertexProgram() && (mat->GetVertexProgram() != mCurrentVertexProgram)) 
     161                { 
     162                        mCurrentVertexProgram = mat->GetVertexProgram(); 
    163163                        mCurrentVertexProgram->Bind(); 
    164164                } 
  • GTP/trunk/App/Demos/Vis/FriendlyCulling/src/ResourceManager.cpp

    r3034 r3036  
    4343        CLEAR_CONTAINER(mShapes); 
    4444        CLEAR_CONTAINER(mLODs); 
     45        CLEAR_CONTAINER(mGPUParameters); 
    4546} 
    4647 
     
    206207                mat->mFragmentProgram = RenderState::sCgMrtFragmentTexProgram; 
    207208 
    208                 mat->mGPUFragmentParameters = new GPUProgramParameters(mat->mFragmentProgram); 
     209                mat->mGPUFragmentParameters = CreateGPUProgramParameters(mat->mFragmentProgram); 
    209210                mat->mGPUFragmentParameters->SetTexture(0, mat->GetTexture()->GetId()); 
    210211        }        
     
    212213        { 
    213214                mat->mFragmentProgram = RenderState::sCgMrtFragmentProgram; 
    214                 mat->mGPUFragmentParameters = new GPUProgramParameters(mat->mFragmentProgram); 
    215         } 
    216  
    217         mat->mGPUVertexParameters = new GPUProgramParameters(RenderState::sCgMrtVertexProgram); 
     215                mat->mGPUFragmentParameters = CreateGPUProgramParameters(mat->mFragmentProgram); 
     216        } 
     217 
     218        mat->mGPUVertexParameters = CreateGPUProgramParameters(RenderState::sCgMrtVertexProgram); 
    218219 
    219220        return mat; 
     
    314315} 
    315316 
    316 } 
     317 
     318GPUProgramParameters *ResourceManager::CreateGPUProgramParameters(ShaderProgram *p) 
     319{ 
     320        GPUProgramParameters *gpuParams = new GPUProgramParameters(p); 
     321        mGPUParameters.push_back(gpuParams); 
     322 
     323        return gpuParams; 
     324} 
     325 
     326} 
     327 
  • GTP/trunk/App/Demos/Vis/FriendlyCulling/src/ResourceManager.h

    r3020 r3036  
    2323class Matrix4x4; 
    2424class Transform3; 
     25class ShaderProgram; 
     26class GPUProgramParameters; 
    2527 
    2628 
     
    3739 
    3840        int GetNumEntities() const { return (int)mSceneEntities.size(); } 
     41 
     42        /** Creates new gpu program parameters. 
     43        */ 
     44        GPUProgramParameters *CreateGPUProgramParameters(ShaderProgram *p); 
    3945 
    4046protected: 
     
    5460 
    5561        // these are kept to be able to delete these resources afterwards 
    56         std::vector<Texture *> mTextures; 
    57         std::vector<Material *> mMaterials; 
    58         std::vector<Geometry *> mGeometry; 
    59         std::vector<Transform3 *> mTrafos; 
    60          
     62        TextureContainer mTextures; 
     63        MaterialContainer mMaterials; 
     64        GeometryContainer mGeometry; 
     65        TransformContainer mTrafos; 
     66        GPUParamContainer mGPUParameters; 
     67 
    6168        ShapeContainer mShapes; 
    6269 
  • GTP/trunk/App/Demos/Vis/FriendlyCulling/src/ShaderProgram.cpp

    r3034 r3036  
    1414} 
    1515 
     16 
     17void GPUProgramParameters::Reset() 
     18{ 
     19        mFloats.clear(); 
     20        mTextures.clear(); 
     21        mMatrices.clear(); 
     22        mArrays.clear(); 
     23} 
     24 
     25 
    1626void GPUProgramParameters::SetValue1f(int idx, float value) 
    1727{ 
     28        if (mFloats.size() < idx + 1) 
     29                mFloats.resize(idx + 1); 
     30 
     31        mFloats[idx] = FloatParam(&value, 1); 
    1832} 
    1933 
     
    2135void GPUProgramParameters::SetValue2f(int idx, float val1, float val2) 
    2236{ 
    23 } 
    24  
    25  
    26 void GPUProgramParameters::SetValue3f(int idx, float val1, float val, float val3) 
    27 { 
     37        if (mFloats.size() < idx + 1) 
     38                mFloats.resize(idx + 1); 
     39 
     40        float vals[] = {val1, val2}; 
     41 
     42        mFloats[idx] = FloatParam(vals, 2); 
     43} 
     44 
     45 
     46void GPUProgramParameters::SetValue3f(int idx, float val1, float val2, float val3) 
     47{ 
     48        if (mFloats.size() < idx + 1) 
     49                mFloats.resize(idx + 1); 
     50 
     51        float vals[] = {val1, val2, val3}; 
     52 
     53        mFloats[idx] = FloatParam(vals, 3); 
    2854} 
    2955 
     
    3157void GPUProgramParameters::SetArray1f(int idx, float *vals, int numElements) 
    3258{ 
     59        if (mArrays.size() < idx + 1) 
     60                mArrays.resize(idx + 1); 
     61 
     62        mArrays[idx] = ArrayParam(vals, 1, numElements); 
    3363} 
    3464 
     
    3666void GPUProgramParameters::SetArray2f(int idx, float *vals, int numElements) 
    3767{ 
     68        if (mArrays.size() < idx + 1) 
     69                mArrays.resize(idx + 1); 
     70 
     71        mArrays[idx] = ArrayParam(vals, 2, numElements); 
    3872} 
    3973 
     
    4175void GPUProgramParameters::SetArray3f(int idx, float *vals, int numElements) 
    4276{ 
     77        if (mArrays.size() < idx + 1) 
     78                mArrays.resize(idx + 1); 
     79 
     80        mArrays[idx] = ArrayParam(vals, 3, numElements); 
    4381} 
    4482 
     
    4684void GPUProgramParameters::SetTexture(int idx, unsigned int tex) 
    4785{ 
    48         mTextures.push_back(IntParam(idx, tex)); 
     86        if (mTextures.size() < idx + 1) 
     87                mTextures.resize(idx + 1); 
     88 
     89        mTextures[idx] = IntParam(tex); 
    4990} 
    5091 
     
    5293void GPUProgramParameters::SetMatrix(int idx, Matrix4x4 *mat) 
    5394{ 
     95        if (mMatrices.size() < idx + 1) 
     96                mMatrices.resize(idx + 1); 
     97 
     98        mMatrices[idx] = MatrixParam(mat); 
    5499} 
    55100 
     
    105150void GPUProgramParameters::UpdateParameters() 
    106151{ 
    107         for (size_t i = 0; i < mFloats.size(); ++ i) 
     152        for (int i = 0; i < (int)mFloats.size(); ++ i) 
    108153        { 
    109154                const FloatParam &p = mFloats[i]; 
     155 
     156                if (!p.mValid) continue; 
    110157 
    111158                switch (p.mNumComponents) 
    112159                { 
    113160                case 1: 
    114                         mProgram->SetValue1f(p.mIndex, p.mValues[0]); 
     161                        mProgram->SetValue1f(i, p.mValues[0]); 
    115162                        break; 
    116163                case 2: 
    117                         mProgram->SetValue2f(p.mIndex, p.mValues[0], p.mValues[1]); 
     164                        mProgram->SetValue2f(i, p.mValues[0], p.mValues[1]); 
    118165                        break; 
    119166                case 3: 
    120                         mProgram->SetValue3f(p.mIndex, p.mValues[0], p.mValues[1], p.mValues[2]); 
     167                        mProgram->SetValue3f(i, p.mValues[0], p.mValues[1], p.mValues[2]); 
    121168                        break; 
    122169                default: 
    123                         mProgram->SetValue1f(p.mIndex, p.mValues[0]); 
     170                        mProgram->SetValue1f(i, p.mValues[0]); 
    124171                } 
    125172        } 
    126173 
    127         for (size_t i = 0; i < mTextures.size(); ++ i) 
     174        for (int i = 0; i < (int)mTextures.size(); ++ i) 
    128175        { 
    129176                const IntParam &p = mTextures[i]; 
    130                 mProgram->SetTexture(p.mIndex, p.mValue); 
    131         } 
    132  
    133         for (size_t i = 0; i < mMatrices.size(); ++ i) 
     177 
     178                if (p.mValid) 
     179                        mProgram->SetTexture(i, p.mValue); 
     180        } 
     181 
     182        for (int i = 0; i < (int)mMatrices.size(); ++ i) 
    134183        { 
    135184                const MatrixParam &p = mMatrices[i]; 
    136                 mProgram->SetMatrix(p.mIndex, *p.mValue); 
     185 
     186                if (p.mValid) 
     187                        mProgram->SetMatrix(i, *p.mValue); 
     188        } 
     189         
     190        for (int i = 0; i < (int)mArrays.size(); ++ i) 
     191        { 
     192                const ArrayParam &p = mArrays[i]; 
     193 
     194                if (!p.mValid) continue; 
     195 
     196                switch (p.mNumComponents) 
     197                { 
     198                case 1: 
     199                        mProgram->SetArray1f(i, p.mValues, p.mNumEntries); 
     200                        break; 
     201                case 2: 
     202                        mProgram->SetArray2f(i, p.mValues, p.mNumEntries); 
     203                        break; 
     204                case 3: 
     205                        mProgram->SetArray3f(i, p.mValues, p.mNumEntries); 
     206                        break; 
     207                default: 
     208                        mProgram->SetArray1f(i, p.mValues, p.mNumEntries); 
     209                } 
    137210        } 
    138211} 
  • GTP/trunk/App/Demos/Vis/FriendlyCulling/src/ShaderProgram.h

    r3034 r3036  
    3636public: 
    3737 
     38        /** Constructor which initialized this parameter set for a given program. 
     39        */ 
     40        GPUProgramParameters(ShaderProgram *p); 
     41 
     42        void SetProgram(ShaderProgram *p) { mProgram = p; } 
     43        /** Resets this parameter set. 
     44        */ 
     45        void Reset(); 
     46 
     47 
    3848        /////////// 
    3949        //-- set parameters by index 
     
    6676        void SetArray2f(const std::string &name, float *vals, int numElements); 
    6777        void SetArray3f(const std::string &name, float *vals, int numElements); 
    68  
    6978        /** Sets the texture parameter. 
    7079        */ 
     
    7685        */ 
    7786        void UpdateParameters(); 
    78  
    79  
    80         GPUProgramParameters(ShaderProgram *p); 
    81  
     87         
    8288 
    8389protected: 
     
    8591        struct FloatParam 
    8692        { 
    87                 int mIndex; 
     93                FloatParam(): mValid(false), mNumComponents(0) {} 
     94 
     95                FloatParam(float *val, int comp):  
     96                mNumComponents(comp), mValid(true) 
     97                { 
     98                        for (int i = 0; i < mNumComponents; ++ i) 
     99                        { 
     100                                mValues[i] = val[i]; 
     101                        } 
     102                } 
     103 
     104                bool mValid; 
    88105                float mValues[4]; 
    89106                int mNumComponents; 
     
    92109        struct IntParam 
    93110        { 
    94                 IntParam(int idx, float val): mIndex(idx), mValue(val) {} 
    95  
    96                 int mIndex; 
     111                IntParam(): mValid(false) {} 
     112                IntParam(float val): mValue(val), mValid(true) {} 
     113 
     114                bool mValid; 
    97115                float mValue; 
    98116        }; 
     
    100118        struct MatrixParam 
    101119        { 
    102                 int mIndex; 
     120                MatrixParam(): mValue(NULL), mValid(false) {} 
     121 
     122                MatrixParam(Matrix4x4 *mat): mValue(mat), mValid(true) 
     123                {} 
     124 
     125                bool mValid; 
    103126                Matrix4x4 *mValue; 
    104127        }; 
     
    106129        struct ArrayParam 
    107130        { 
    108                 int mIndex; 
    109  
     131                ArrayParam(): mValues(NULL), mNumEntries(0), mNumComponents(0), mValid(false) {} 
     132                ArrayParam(float *val, int comp, int numEntries):  
     133                mValues(val), mNumComponents(comp), mNumEntries(numEntries), mValid(true) 
     134                {} 
     135 
     136                bool mValid; 
    110137                float *mValues; 
     138 
    111139                int mNumEntries; 
    112  
    113140                int mNumComponents; 
    114141        }; 
  • GTP/trunk/App/Demos/Vis/FriendlyCulling/src/SkyPreetham.cpp

    r3021 r3036  
    66#include "Camera.h" 
    77#include "RenderState.h" 
     8#include "ShaderProgram.h" 
     9#include "Shape.h" 
     10#include "Material.h" 
    811 
    912 
     
    2326 
    2427 
    25 static CGprogram sCgSkyProgram = NULL; 
    26 static CGprogram sCgMrtFragmentSkyDomeProgram = NULL; 
    27  
    28  
    29 static CGparameter sLightDirParam; 
    30 static CGparameter sThetaSunParam; 
    31 static CGparameter sZenithColorParam; 
    32 static CGparameter sAColorParam; 
    33 static CGparameter sBColorParam; 
    34 static CGparameter sCColorParam; 
    35 static CGparameter sDColorParam; 
    36 static CGparameter sEColorParam; 
    37 static CGparameter sMultiplierParam; 
     28static ShaderProgram *sCgSkyProgram = NULL; 
     29static ShaderProgram *sCgMrtFragmentSkyDomeProgram = NULL; 
    3830 
    3931ShaderContainer SkyPreetham::sShaders; 
     
    5446void SkyPreetham::InitCG(CGcontext context) 
    5547{        
    56         ShaderProgram *pr; 
    57  
    58         sCgSkyProgram =  
    59                 cgCreateProgramFromFile(context,  
    60                                                                 CG_SOURCE, 
    61                                                                 "src/shaders/sky_preetham.cg",  
    62                                                                 RenderState::sCgVertexProfile, 
    63                                                                 "default_vs", 
    64                                                                 NULL); 
    65  
    66         if (sCgSkyProgram != NULL) 
     48        sCgSkyProgram = new ShaderProgram(context,  
     49                                              "src/shaders/sky_preetham.cg", 
     50                                                                          RenderState::sCgVertexProfile,         
     51                                                                          "default_vs"); 
     52 
     53        if (sCgSkyProgram->IsValid()) 
    6754        { 
    68                 cgGLLoadProgram(sCgSkyProgram); 
    69  
    70                 sLightDirParam = cgGetNamedParameter(sCgSkyProgram, "lightDir"); 
    71                 sThetaSunParam = cgGetNamedParameter(sCgSkyProgram, "thetaSun"); 
    72                 sZenithColorParam = cgGetNamedParameter(sCgSkyProgram, "zenithColor"); 
    73                 sAColorParam = cgGetNamedParameter(sCgSkyProgram, "aColor"); 
    74                 sBColorParam = cgGetNamedParameter(sCgSkyProgram, "bColor"); 
    75                 sCColorParam = cgGetNamedParameter(sCgSkyProgram, "cColor"); 
    76                 sDColorParam = cgGetNamedParameter(sCgSkyProgram, "dColor"); 
    77                 sEColorParam = cgGetNamedParameter(sCgSkyProgram, "eColor"); 
    78  
    79                 sMultiplierParam = cgGetNamedParameter(sCgSkyProgram, "multiplier"); 
    80  
    81                 pr = new ShaderProgram(sCgSkyProgram); 
    82                 sShaders.push_back(pr); 
     55                sCgSkyProgram->AddParameter("lightDir", 0); 
     56                sCgSkyProgram->AddParameter("thetaSun", 1); 
     57                sCgSkyProgram->AddParameter("zenithColor", 2); 
     58                sCgSkyProgram->AddParameter("aColor", 3); 
     59                sCgSkyProgram->AddParameter("bColor", 4); 
     60                sCgSkyProgram->AddParameter("cColor", 5); 
     61                sCgSkyProgram->AddParameter("dColor", 6); 
     62                sCgSkyProgram->AddParameter("eColor", 7); 
     63                sCgSkyProgram->AddParameter("multiplier", 8); 
    8364        } 
    8465        else 
    8566                cerr << "sky program failed to load" << endl; 
    8667 
     68                sShaders.push_back(sCgSkyProgram); 
     69 
    8770        sCgMrtFragmentSkyDomeProgram =  
    88                 cgCreateProgramFromFile(context,  
    89                                                                 CG_SOURCE, 
    90                                                                 "src/shaders/sky_preetham.cg",  
    91                                                                 RenderState::sCgFragmentProfile, 
    92                                                                 "frag_skydome", 
    93                                                                 NULL); 
    94  
    95         if (sCgMrtFragmentSkyDomeProgram != NULL) 
    96         { 
    97                 cgGLLoadProgram(sCgMrtFragmentSkyDomeProgram); 
    98                 //cgGLSetParameter1f(sMaxDepthParam, MAX_DEPTH_CONST / farDist); 
    99  
    100                 pr = new ShaderProgram(sCgMrtFragmentSkyDomeProgram); 
    101                 sShaders.push_back(pr); 
    102         } 
    103         else 
     71                new ShaderProgram(context,  
     72                                  "src/shaders/sky_preetham.cg",  
     73                                                  RenderState::sCgFragmentProfile, 
     74                                                  "frag_skydome"); 
     75 
     76        // simple shader used for just pushing out the fragments to the mrts 
     77        if (!sCgMrtFragmentSkyDomeProgram->IsValid()) 
    10478                cerr << "fragment skyprogram failed to load" << endl; 
     79         
     80        sShaders.push_back(sCgMrtFragmentSkyDomeProgram); 
    10581} 
    10682 
     
    11894{ 
    11995        CreateSunQuad(); 
     96        Shape *shape = mSkyDome->GetShape(0); 
     97 
     98        Material *mat = shape->GetMaterial(); 
     99 
     100        mat->SetFragmentProgram(sCgMrtFragmentSkyDomeProgram); 
     101        mat->SetVertexProgram(sCgSkyProgram); 
    120102} 
    121103 
     
    135117        Vector3 zenithColor; 
    136118        vector<Vector3> ABCDE; 
     119 
    137120        ComputeFactors(sunDir, zenithColor, ABCDE, sun_theta); 
    138121 
     
    149132        mSkyDome->GetTransform()->SetMatrix(s * m); 
    150133         
    151         cgGLSetParameter3f(sLightDirParam, sunDir.x, sunDir.y, sunDir.z); 
    152         cgGLSetParameter2f(sThetaSunParam, sun_theta.first, sun_theta.second); 
    153         cgGLSetParameter3f(sZenithColorParam, zenithColor.x, zenithColor.y, zenithColor.z); 
    154  
    155         cgGLSetParameter3f(sAColorParam, ABCDE[0].x, ABCDE[0].y, ABCDE[0].z); 
    156         cgGLSetParameter3f(sBColorParam, ABCDE[1].x, ABCDE[1].y, ABCDE[1].z); 
    157         cgGLSetParameter3f(sCColorParam, ABCDE[2].x, ABCDE[2].y, ABCDE[2].z); 
    158         cgGLSetParameter3f(sDColorParam, ABCDE[3].x, ABCDE[3].y, ABCDE[3].z); 
    159         cgGLSetParameter3f(sEColorParam, ABCDE[4].x, ABCDE[4].y, ABCDE[4].z); 
    160  
    161         if (state->GetRenderPassType() == RenderState::DEFERRED) 
    162         { 
    163                 cgGLEnableProfile(RenderState::sCgFragmentProfile); 
    164                 cgGLBindProgram(sCgMrtFragmentSkyDomeProgram); 
    165  
    166         } 
     134        GPUProgramParameters *vtxParams = mSkyDome->GetShape(0)->GetMaterial()->GetVertexProgramParameters(); 
     135 
     136        vtxParams->SetValue3f(0, sunDir.x, sunDir.y, sunDir.z); 
     137        vtxParams->SetValue2f(1, sun_theta.first, sun_theta.second); 
     138        vtxParams->SetValue3f(2, zenithColor.x, zenithColor.y, zenithColor.z); 
     139 
     140        vtxParams->SetValue3f(3, ABCDE[0].x, ABCDE[0].y, ABCDE[0].z); 
     141        vtxParams->SetValue3f(4, ABCDE[1].x, ABCDE[1].y, ABCDE[1].z); 
     142        vtxParams->SetValue3f(5, ABCDE[2].x, ABCDE[2].y, ABCDE[2].z); 
     143        vtxParams->SetValue3f(6, ABCDE[3].x, ABCDE[3].y, ABCDE[3].z); 
     144        vtxParams->SetValue3f(7, ABCDE[4].x, ABCDE[4].y, ABCDE[4].z); 
     145 
    167146 
    168147        if (!scaleToRange) 
    169148        {        
    170149                // use tone mapping 
    171                 cgGLSetParameter1f(sMultiplierParam, 1.0f); 
     150                sCgSkyProgram->SetValue1f(8, 1.0f); 
    172151        } 
    173152        else 
    174153        { 
    175154                // no tone mapping => scale 
    176                 cgGLSetParameter1f(sMultiplierParam, 8e-5f); 
     155                sCgSkyProgram->SetValue1f(8, 8e-5f); 
    177156        } 
    178157 
    179158        cgGLEnableProfile(RenderState::sCgVertexProfile); 
    180         cgGLBindProgram(sCgSkyProgram); 
    181159 
    182160        // Render sky dome. 
     
    185163        // Render additively blended sun disc. 
    186164        //RenderSunDisk(sunDir, camera); 
    187  
    188         cgGLDisableProfile(RenderState::sCgFragmentProfile); 
    189165} 
    190166 
     
    192168void SkyPreetham::RenderSunDisk(const Vector3 &sunDir, Camera *camera) 
    193169{ 
     170#if TODOD 
    194171        // Move skybox with camera. 
    195172        Vector3 position = camera->GetPosition(); 
     
    212189        sunPos *= rotx;; 
    213190 
    214         //sunposition.rotateAroundY(-D().getScene().getLight().getHorizontalOrientation() + 90.0f); 
    215         //sunposition.rotateAroundX(-D().getScene().getLight().getVerticalOrientation()); 
     191        sunposition.rotateAroundY(-D().getScene().getLight().getHorizontalOrientation() + 90.0f); 
     192        sunposition.rotateAroundX(-D().getScene().getLight().getVerticalOrientation()); 
    216193         
    217194        glMatrixMode(GL_MODELVIEW); 
     
    222199        glMaterialfv(GL_FRONT, GL_AMBIENT, ambient); 
    223200 
    224         //Float size = 0.5f + (1.0f - lightdirection.y) * 0.5f; 
    225  
    226         //mSunEffect->setVariableVector3("LightDiffuseColor", D().getScene().getLight().getDiffuseColor()); 
    227         //mSunEffect->setVariableFloat("SunSize", size); 
    228         //mSunEffect->setVariableTexture2D("SunTexture", mSunTexture); 
    229  
    230         /*mSunEffect->activate(); 
     201        Float size = 0.5f + (1.0f - lightdirection.y) * 0.5f; 
     202 
     203        mSunEffect->setVariableVector3("LightDiffuseColor", D().getScene().getLight().getDiffuseColor()); 
     204        mSunEffect->setVariableFloat("SunSize", size); 
     205        mSunEffect->setVariableTexture2D("SunTexture", mSunTexture); 
     206 
     207        mSunEffect->activate(); 
    231208         
    232209        mSunQuad->render(); 
    233210 
    234211        mSunEffect->deactivate(); 
    235         F().getRenderDevice().setDefaultBlendingMode(FRenderDevice::BLENDING_NONE);*/ 
     212        F().getRenderDevice().setDefaultBlendingMode(FRenderDevice::BLENDING_NONE); 
    236213 
    237214        glPopMatrix(); 
     215#endif 
    238216} 
    239217 
     
    241219void SkyPreetham::CreateSunQuad() 
    242220{ 
    243         /* 
     221#if TODO 
    244222        mSunQuad = new FVertexBuffer(); 
    245223        mSunQuad->setupPrimitiveType(FVertexBuffer::PRIMITIVES_TRIANGLES); 
     
    263241        mSunQuad->setIndex(4, 1); 
    264242        mSunQuad->setIndex(5, 3); 
    265         */ 
     243#endif 
    266244} 
    267245 
  • GTP/trunk/App/Demos/Vis/FriendlyCulling/src/chcdemo.cpp

    r3034 r3036  
    19671967                state.SetRenderPassType(RenderState::DEFERRED); 
    19681968 
    1969         const bool useToneMapping = ((renderMethod == RENDER_DEPTH_PASS_DEFERRED) || (renderMethod == RENDER_DEFERRED)) && useHDR; 
     1969        const bool useToneMapping =  
     1970                ((renderMethod == RENDER_DEPTH_PASS_DEFERRED) ||  
     1971                 (renderMethod == RENDER_DEFERRED)) && useHDR; 
    19701972 
    19711973        preetham->RenderSkyDome(-light->GetDirection(), camera, &state, !useToneMapping); 
  • GTP/trunk/App/Demos/Vis/FriendlyCulling/src/common.h

    r3022 r3036  
    2828 
    2929class Shape; 
    30 struct LODLevel; 
    3130class Polygon3; 
    3231class Vector3; 
    3332class Geometry; 
     33class GPUProgramParameters; 
     34class Transform3; 
     35class Texture; 
     36class Material; 
     37 
    3438struct LODLevel; 
     39 
    3540 
    3641 
     
    481486typedef std::queue<BvhNode *> BvhNodeQueue; 
    482487 
    483  
    484488typedef std::vector<Shape *> ShapeContainer; 
    485489typedef std::vector<Geometry *> GeometryContainer; 
     
    487491typedef std::vector<Polygon3 *> PolygonContainer; 
    488492typedef std::vector<LODLevel *> LODContainer; 
     493typedef std::vector<Transform3 *> TransformContainer; 
     494typedef std::vector<Texture *> TextureContainer; 
     495typedef std::vector<Material *> MaterialContainer; 
     496typedef std::vector<GPUProgramParameters *> GPUParamContainer; 
    489497 
    490498typedef std::vector<Vector3> VertexArray; 
Note: See TracChangeset for help on using the changeset viewer.