source: GTP/trunk/Lib/Illum/IllumModule/OgreIllumModule/src/RenderingRuns/OgrePMWeightComputeRenderingRun.cpp @ 2333

Revision 2333, 8.9 KB checked in by szirmay, 18 years ago (diff)
Line 
1#include "OgrePMWeightComputeRenderingRun.h"
2#include "OgreIlluminationManager.h"
3#include "OgrePMEntryPointMapRenderingRun.h"
4#include "OgreDepthShadowMapRenderingRun.h"
5
6Texture* OgrePMWeightComputeRenderingRun::weightTexture = 0;
7Texture* OgrePMWeightComputeRenderingRun::allWeightsTexture = 0;
8
9OgrePMWeightComputeRenderingRun::OgrePMWeightComputeRenderingRun(String name, String LightName)
10                                                                                                                   : OgreRenderingRun(1, 1)
11                                                                                                                   , RenderingRun(1, 1)
12{
13        this->name = name;
14        weights = 0;
15       
16        this->light = Root::getSingleton()._getCurrentSceneManager()->getLight(LightName);
17        createWeightMap();
18
19        OgreIlluminationManager::getSingleton().createGlobalRun(ILLUMRUN_PM_ENTRYPOINTMAP);
20}
21
22void OgrePMWeightComputeRenderingRun::createWeightMap()
23{
24        if(allWeightsTexture == 0)
25        {
26                unsigned int entryPointCnt = OgreIlluminationManager::getSingleton().getPathMapEntryPoints().size();
27                int width = entryPointCnt / 4096;
28                int height = 4096;
29                TexturePtr texPtr = Ogre::TextureManager::getSingleton().createManual(name + "_ALL",
30                                                                                                                                                        "default",
31                                                                                                                                                        TEX_TYPE_2D,
32                                                                                                                                                        width,
33                                                                                                                                                        height,
34                                                                                                                                                        0,
35                                                                                                                                                        0,
36                                                                                                                                                        PF_FLOAT16_RGBA,
37                                                                                                                                                        TU_RENDERTARGET);
38                allWeightsTexture = texPtr.getPointer();
39                //add viewport to rendertarget
40                HardwarePixelBuffer* hpb = (allWeightsTexture->getBuffer()).getPointer();
41                RenderTarget* rt = hpb->getRenderTarget();
42                Camera* wc = Root::getSingleton()._getCurrentSceneManager()->createCamera(name + "_ALL_CAMERA");
43                Viewport* v = rt->addViewport(wc);
44                v->setBackgroundColour(ColourValue::Black);
45                v->setClearEveryFrame(false);
46                v->setOverlaysEnabled(false);
47                rt->setAutoUpdated(false);
48
49                unsigned int clustercount = OgreIlluminationManager::getSingleton().getPathMapClusterLengthsSize();
50                width = clustercount;
51                height = 1;
52                texPtr = Ogre::TextureManager::getSingleton().createManual(name,
53                                                                                                                                        "default",
54                                                                                                                                        TEX_TYPE_2D,
55                                                                                                                                        width,
56                                                                                                                                        height,
57                                                                                                                                        0,
58                                                                                                                                        0,
59                                                                                                                                        PF_FLOAT16_RGBA,
60                                                                                                                                        TU_RENDERTARGET);
61                weightTexture = texPtr.getPointer();
62                //add viewport to rendertarget
63                hpb = (weightTexture->getBuffer()).getPointer();
64                rt = hpb->getRenderTarget();
65                wc = Root::getSingleton()._getCurrentSceneManager()->createCamera(name + "_CAMERA");
66                v = rt->addViewport(wc);
67                v->setOverlaysEnabled(false);
68                rt->setAutoUpdated(false);             
69        }
70}
71
72
73
74void OgrePMWeightComputeRenderingRun::updateFrame(unsigned long frameNum)
75{
76        OgreIlluminationManager::getSingleton().updateGlobalRun(ILLUMRUN_PM_ENTRYPOINTMAP, frameNum);
77        OgrePMEntryPointMapRenderingRun* PMEPrun = (OgrePMEntryPointMapRenderingRun*)
78                OgreIlluminationManager::getSingleton().getGlobalRun(ILLUMRUN_PM_ENTRYPOINTMAP)->asOgreRenderingRun();
79        unsigned int entryPointCnt = OgreIlluminationManager::getSingleton().getPathMapEntryPoints().size();
80        int col = entryPointCnt / 4096;
81               
82        if(light->getType() == Light::LT_SPOTLIGHT)
83        {
84                OgreIlluminationManager::getSingleton().createPerLightRun(light->getName(), ILLUMRUN_DEPTH_SHADOWMAP);
85                OgreIlluminationManager::getSingleton().updatePerLightRun(light->getName(), ILLUMRUN_DEPTH_SHADOWMAP, frameNum);
86                OgreDepthShadowMapRenderingRun* SMrun = (OgreDepthShadowMapRenderingRun*) OgreIlluminationManager::getSingleton()
87                        .getPerLightRun(light->getName(), ILLUMRUN_DEPTH_SHADOWMAP)->asOgreRenderingRun();
88               
89                MaterialPtr mat = MaterialManager::getSingleton().getByName("GTP/PathMap_ComputeWeights");
90                GpuProgramParameters* Fparams = mat->getTechnique(0)->getPass(0)->getFragmentProgramParameters().getPointer();
91                       
92                        Vector3 lightPos = light->getDerivedPosition();
93                        Vector3 lightDir = light->getDerivedDirection();
94                        Radian lightAngle = light->getSpotlightOuterAngle();
95                       
96                        Fparams->setNamedConstant("nRadionColumns", col);
97                        Fparams->setNamedConstant("lightPos", lightPos);
98                        Fparams->setNamedConstant("lightDir", lightDir);
99                        Fparams->setNamedConstant("lightPower", light->getPowerScale());
100                        Fparams->setNamedConstant("lightColor", light->getDiffuseColour());
101                        Fparams->setNamedConstant("lightViewProj", SMrun->getLightViewProjMatrix());
102                        Fparams->setNamedConstant("lightFarPlane", SMrun->getLightFarPlane());
103                        Fparams->setNamedConstant("lightAttenuation", Vector4(light->getAttenuationRange(),
104                                                                                                                                        light->getAttenuationConstant(),
105                                                                                                                                        light->getAttenuationLinear(),
106                                                                                                                                        light->getAttenuationQuadric()));
107                        Fparams->setNamedConstant("lightAngleCos", Math::Cos(lightAngle.valueRadians()/2.0));                   
108                        Fparams->setNamedConstant("spotLightFalloff", light->getSpotlightFalloff());                   
109                       
110                        mat->getTechnique(0)->getPass(0)->getTextureUnitState(0)->setTextureName(
111                                                PMEPrun->getEntryPointTextureName());
112                        mat->getTechnique(0)->getPass(0)->getTextureUnitState(1)->setTextureName(
113                                                SMrun->getDepthMapTextureName());
114                               
115                        RenderTarget* rt = allWeightsTexture->getBuffer().getPointer()->getRenderTarget();
116                        if(frameNum != rt->getLastFrameNumber())
117                                rt->getViewport(0)->setClearEveryFrame(true);
118                        else
119                                rt->getViewport(0)->setClearEveryFrame(false);
120                       
121                                renderFullscreenQuad(mat->getName(), rt);
122                       
123
124                //      rt->writeContentsToFile("allweights.bmp");
125                //      rt->writeContentsToFile("allweights.dds");
126
127        }
128        else if(light->getType() == Light::LT_POINT)
129        {
130                OgreIlluminationManager::getSingleton().createPerLightRun(light->getName(), ILLUMRUN_DEPTH_SHADOWMAP);
131                OgreIlluminationManager::getSingleton().updatePerLightRun(light->getName(), ILLUMRUN_DEPTH_SHADOWMAP, frameNum);
132                OgreDepthShadowMapRenderingRun* SMrun = (OgreDepthShadowMapRenderingRun*) OgreIlluminationManager::getSingleton()
133                        .getPerLightRun(light->getName(), ILLUMRUN_DEPTH_SHADOWMAP)->asOgreRenderingRun();
134               
135                MaterialPtr mat = MaterialManager::getSingleton().getByName("GTP/PathMap_ComputeWeights_Point");
136                GpuProgramParameters* Fparams = mat->getTechnique(0)->getPass(0)->getFragmentProgramParameters().getPointer();
137                       
138                        Vector3 lightPos = light->getDerivedPosition();
139                       
140                        Fparams->setNamedConstant("nRadionColumns", col);
141                        Fparams->setNamedConstant("lightPos", lightPos);
142                        Fparams->setNamedConstant("lightPower", light->getPowerScale());
143                        Fparams->setNamedConstant("lightColor", light->getDiffuseColour());
144                        Fparams->setNamedConstant("lightFarPlane", SMrun->getLightFarPlane());
145                        Fparams->setNamedConstant("lightAttenuation", Vector4(light->getAttenuationRange(),
146                                                                                                                                        light->getAttenuationConstant(),
147                                                                                                                                        light->getAttenuationLinear(),
148                                                                                                                                        light->getAttenuationQuadric()));
149
150                        mat->getTechnique(0)->getPass(0)->getTextureUnitState(0)->setTextureName(
151                                                PMEPrun->getEntryPointTextureName());
152                        mat->getTechnique(0)->getPass(0)->getTextureUnitState(1)->setTextureName(
153                                                SMrun->getDepthMapTextureName());
154                               
155                        RenderTarget* rt = allWeightsTexture->getBuffer().getPointer()->getRenderTarget();
156                        if(frameNum != rt->getLastFrameNumber())
157                                rt->getViewport(0)->setClearEveryFrame(true);
158                        else
159                                rt->getViewport(0)->setClearEveryFrame(false);
160                       
161                                renderFullscreenQuad(mat->getName(), rt);
162                       
163        }
164
165}
166
167void OgrePMWeightComputeRenderingRun::sumWeights(unsigned long frameNum)
168{
169        RenderTarget* rt = weightTexture->getBuffer().getPointer()->getRenderTarget();
170        if(frameNum == rt->getLastFrameNumber())return;
171       
172        unsigned int entryPointCnt = OgreIlluminationManager::getSingleton().getPathMapEntryPoints().size();
173        int col = entryPointCnt / 4096;
174        unsigned int clustercount = OgreIlluminationManager::getSingleton().getPathMapClusterLengthsSize();
175        OgrePMEntryPointMapRenderingRun* PMEPrun = (OgrePMEntryPointMapRenderingRun*)
176        OgreIlluminationManager::getSingleton().getGlobalRun(ILLUMRUN_PM_ENTRYPOINTMAP)->asOgreRenderingRun();
177       
178        MaterialPtr mat = MaterialManager::getSingleton().getByName("GTP/PathMap_SumWeights");
179        GpuProgramParameters* Fparams = mat->getTechnique(0)->getPass(0)->getFragmentProgramParameters().getPointer();
180        Fparams->setNamedConstant("nRadionColumns", col);
181        Fparams->setNamedConstant("clusterCount", (float) clustercount);
182        mat->getTechnique(0)->getPass(0)->getTextureUnitState(0)->setTextureName(
183                                                PMEPrun->getEntryPointTextureName());
184        mat->getTechnique(0)->getPass(0)->getTextureUnitState(1)->setTextureName(
185                                                PMEPrun->getClusterLengthTextureName());
186        mat->getTechnique(0)->getPass(0)->getTextureUnitState(2)->setTextureName(
187                                                allWeightsTexture->getName());
188       
189        renderFullscreenQuad(mat->getName(), rt);
190}
191
192void OgrePMWeightComputeRenderingRun::freeAllResources()
193{
194        this->weightTexture = 0;
195        this->allWeightsTexture = 0;
196        TextureManager::getSingleton().remove(name);
197        Root::getSingleton()._getCurrentSceneManager()->destroyCamera(name + "_CAMERA");       
198
199        TextureManager::getSingleton().remove(name + "_ALL");
200        Root::getSingleton()._getCurrentSceneManager()->destroyCamera(name + "_ALL" + "_CAMERA");
201}
Note: See TracBrowser for help on using the repository browser.