| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276 | //-----------------------------------------------------------------------------// Copyright (c) 2012 GarageGames, LLC//// Permission is hereby granted, free of charge, to any person obtaining a copy// of this software and associated documentation files (the "Software"), to// deal in the Software without restriction, including without limitation the// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or// sell copies of the Software, and to permit persons to whom the Software is// furnished to do so, subject to the following conditions://// The above copyright notice and this permission notice shall be included in// all copies or substantial portions of the Software.//// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS// IN THE SOFTWARE.//-----------------------------------------------------------------------------#ifndef _SCATTERSKY_H_#define _SCATTERSKY_H_#ifndef _SCENEOBJECT_H_#include "scene/sceneObject.h"#endif#ifndef _GFXPRIMITIVEBUFFER_H_#include "gfx/gfxPrimitiveBuffer.h"#endif#ifndef _GFXVERTEXBUFFER_H_#include "gfx/gfxVertexBuffer.h"#endif#ifndef _GFXSTATEBLOCK_H_#include "gfx/gfxStateBlock.h"#endif#ifndef _RENDERPASSMANAGER_H_#include "renderInstance/renderPassManager.h"#endif#ifndef _PRIMBUILDER_H_#include "gfx/primBuilder.h"#endif#ifndef _LIGHTINFO_H_#include "lighting/lightInfo.h"#endif#ifndef _LIGHTFLAREDATA_H_#include "T3D/lightFlareData.h"#endif#ifndef _TRESPONSECURVE_H_#include "math/util/tResponseCurve.h"#endif#include "T3D/assets/MaterialAsset.h"class LightInfo;class SphereMesh;class TimeOfDay;class CubemapData;class MatrixSet;class ScatterSky : public SceneObject, public ISceneLight{   typedef SceneObject Parent;public:   enum MaskBits   {      UpdateMask = Parent::NextFreeMask,      TimeMask = Parent::NextFreeMask << 1,      NextFreeMask = Parent::NextFreeMask << 2   };   ScatterSky();   ~ScatterSky();   // SimObject   bool onAdd() override;   void onRemove() override;   // ISceneLight   void submitLights( LightManager *lm, bool staticLighting ) override;   LightInfo* getLight() override { return mLight; }   // ConsoleObject   DECLARE_CONOBJECT(ScatterSky);   DECLARE_CATEGORY("Environment \t Background");   void inspectPostApply() override;   static void initPersistFields();   // Network   U32  packUpdate  ( NetConnection *conn, U32 mask, BitStream *stream ) override;   void unpackUpdate( NetConnection *conn,           BitStream *stream ) override;   void prepRenderImage( SceneRenderState* state ) override;     ///   void setAzimuth( F32 azimuth );   ///   void setElevation( F32 elevation );   ///   F32 getAzimuth() const { return mSunAzimuth; }   ///   F32 getElevation() const { return mSunElevation; }   struct SphereVertex   {      Point3F pos;   };   Vector<SphereVertex> tmpVertices;   Vector<F32> vertsVec;   struct FinalVertexData   {      Point3F pos;   };   Vector<FinalVertexData> finalVertData;   void addVertex(Point3F vert);   void BuildFinalVert();   void clearVectors();protected:   void _render( ObjectRenderInst *ri, SceneRenderState *state, BaseMatInstance *overrideMat );   void _debugRender( ObjectRenderInst *ri, SceneRenderState *state, BaseMatInstance *overrideMat );   void _renderMoon( ObjectRenderInst *ri, SceneRenderState *state, BaseMatInstance *overrideMat );   void _initVBIB();   bool _initShader();   void _initMoon();   void _initCurves();   F32 _getRayleighPhase( F32 fCos2 );   F32 _getMiePhase( F32 fCos, F32 fCos2, F32 g, F32 g2 );   F32 _vernierScale( F32 fCos );   void _generateSkyPoints();   void _getColor( const Point3F &pos, LinearColorF *outColor );   void _getFogColor( LinearColorF *outColor );   void _getAmbientColor( LinearColorF *outColor );   void _getSunColor( LinearColorF *outColor );   void _interpolateColors();   void _conformLights();   void _updateTimeOfDay( TimeOfDay *timeofDay, F32 time );   // static protected field set methods   static bool ptSetElevation( void *object, const char *index, const char *data );   static bool ptSetAzimuth( void *object, const char *index, const char *data );   // SimObject.   void _onSelected() override;   void _onUnselected() override;protected:   static const F32 smEarthRadius;   static const F32 smAtmosphereRadius;   static const F32 smViewerHeight;#define CURVE_COUNT 5   FloatCurve mCurves[CURVE_COUNT];   U32 mVertCount;   U32 mPrimCount;   F32 mRayleighScattering;   F32 mRayleighScattering4PI;   F32 mSunSize;   F32 mMieScattering;   F32 mMieScattering4PI;   F32 mSkyBrightness;   F32 mMiePhaseAssymetry;   F32 mOuterRadius;   F32 mScale;   LinearColorF mWavelength;   F32 mWavelength4[3];   F32 mRayleighScaleDepth;   F32 mMieScaleDepth;   F32 mSphereInnerRadius;   F32 mSphereOuterRadius;   F32 mExposure;   F32 mNightInterpolant;   F32 mZOffset;   VectorF mLightDir;   VectorF mSunDir;   F32 mSunAzimuth;   F32 mSunElevation;   F32 mMoonAzimuth;   F32 mMoonElevation;   F32 mTimeOfDay;   F32 mBrightness;   LinearColorF mNightColor;   LinearColorF mNightFogColor;   LinearColorF mAmbientColor;   ///< Not a field   LinearColorF mSunColor;       ///< Not a field   LinearColorF mFogColor;       ///< Not a field   LinearColorF mAmbientScale;   LinearColorF mSunScale;   LinearColorF mFogScale;   LightInfo *mLight;   bool mCastShadows;   S32 mStaticRefreshFreq;   S32 mDynamicRefreshFreq;   bool mDirty;   LightFlareData *mFlareData;   LightFlareState mFlareState;   F32 mFlareScale;   bool mMoonEnabled;   DECLARE_MATERIALASSET(ScatterSky, MoonMat);   DECLARE_ASSET_NET_SETGET(ScatterSky, MoonMat, UpdateMask);   BaseMatInstance *mMoonMatInst;   F32 mMoonScale;   LinearColorF mMoonTint;   VectorF mMoonLightDir;   CubemapData *mNightCubemap;   StringTableEntry mNightCubemapName;   bool mUseNightCubemap;   MatrixSet *mMatrixSet;   Vector<Point3F> mSkyPoints;   // Prim buffer, vertex buffer and shader for rendering.   GFXPrimitiveBufferHandle mPrimBuffer;   GFXVertexBufferHandle<GFXVertexP> mVB;   GFXShaderRef mShader;   GFXStateBlockRef mStateBlock;   // Shared shader constant blocks   GFXShaderConstBufferRef mShaderConsts;   GFXShaderConstHandle *mModelViewProjSC;   GFXShaderConstHandle *mMiscSC;                     // Camera height, cam height squared, scale and scale over depth.   GFXShaderConstHandle *mSphereRadiiSC;              // Inner and out radius, and inner and outer radius squared.   GFXShaderConstHandle *mScatteringCoefficientsSC;   // Rayleigh sun brightness, mie sun brightness and 4 * PI * coefficients.   GFXShaderConstHandle *mCamPosSC;   GFXShaderConstHandle *mLightDirSC;   GFXShaderConstHandle *mSunDirSC;   GFXShaderConstHandle *mNightColorSC;   GFXShaderConstHandle *mInverseWavelengthSC;   GFXShaderConstHandle *mNightInterpolantAndExposureSC;   GFXShaderConstHandle *mUseCubemapSC;   F32 mColorizeAmt;   LinearColorF mColorize;   GFXShaderConstHandle *mColorizeSC;};#endif // _SCATTERSKY_H_
 |