| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270 | //-----------------------------------------------------------------------------// 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 _LIGHTINFO_H_#define _LIGHTINFO_H_#ifndef _GFXSTRUCTS_H_#include "gfx/gfxStructs.h"#endif#ifndef _TVECTOR_H_#include "core/util/tVector.h"#endif#ifndef _TDICTIONARY_H_#include "core/util/tDictionary.h"#endifstruct SceneData;class LightManager;class SimObject;class BitStream;/// The extended light info type wrapper object.class LightInfoExType{protected:   typedef HashTable<String,U32> TypeMap;   /// Returns the map of all the info types.  We create   /// it as a method static so that its available to other   /// statics regardless of initialization order.   static inline TypeMap& getTypeMap()   {      static TypeMap smTypeMap;      return smTypeMap;   }   /// The info type index for this type.   U32 mTypeIndex;public:   LightInfoExType( const char *type );   inline LightInfoExType( const LightInfoExType &type )      : mTypeIndex( type.mTypeIndex )   {   }   inline operator U32 () const { return mTypeIndex; }};/// This is the base class for extended lighting info/// that lies outside of the normal info stored in LightInfo.class LightInfoEx{public:   /// Basic destructor so we can delete the extended info   /// without knowing the concrete type.   virtual ~LightInfoEx() { }   ///    virtual const LightInfoExType& getType() const = 0;   /// Copy the values from the other LightInfoEx.   virtual void set( const LightInfoEx *ex ) {}   ///   virtual void packUpdate( BitStream *stream ) const {}   ///   virtual void unpackUpdate( BitStream *stream ) {}};/// This is the base light information class that will be tracked by the /// engine.  Should basically contain a bounding volume and methods to interact/// with the rest of the system (for example, setting GFX fixed function lights).class LightInfo{public:   enum Type    {      Point    = 0,      Spot     = 1,      Vector   = 2,      Ambient  = 3,      Count    = 4,   };protected:   Type mType;   /// The primary light color.   LinearColorF mColor;   F32 mBrightness;   LinearColorF mAmbient;   MatrixF mTransform;   Point3F mRange;   F32 mInnerConeAngle;   F32 mOuterConeAngle;   bool mCastShadows;   S32 mStaticRefreshFreq;   S32 mDynamicRefreshFreq;   ::Vector<LightInfoEx*> mExtended;   /// The priority of this light used for   /// light and shadow scoring.   F32 mPriority;   /// A temporary which holds the score used   /// when prioritizing lights for rendering.   F32 mScore;   /// A temporary value which holds the amount this light is faded due to distance   F32 mFadeAmount;   /// Whether to render debugging visualizations   /// for this light.   bool mDebugRender;public:   LightInfo();   ~LightInfo();   // Copies data passed in from light   void set( const LightInfo *light );   // Accessors   Type getType() const { return mType; }   void setType( Type val ) { mType = val; }   const MatrixF& getTransform() const { return mTransform; }   void setTransform( const MatrixF &xfm ) { mTransform = xfm; }   Point3F getPosition() const { return mTransform.getPosition(); }   void setPosition( const Point3F &pos ) { mTransform.setPosition( pos ); }   VectorF getDirection() const { return mTransform.getForwardVector(); }   void setDirection( const VectorF &val );   const LinearColorF& getColor() const { return mColor; }   void setColor( const LinearColorF &val ) { mColor = val; }   F32 getBrightness() const { return mBrightness; }   void setBrightness( F32 val ) { mBrightness = val; }   const LinearColorF& getAmbient() const { return mAmbient; }   void setAmbient( const LinearColorF &val ) { mAmbient = val; }   const Point3F& getRange() const { return mRange; }   void setRange( const Point3F &range ) { mRange = range; }   void setRange( F32 range ) { mRange.set( range, range, range ); }   F32 getInnerConeAngle() const { return mInnerConeAngle; }   void setInnerConeAngle( F32 val ) { mInnerConeAngle = val; }   F32 getOuterConeAngle() const { return mOuterConeAngle; }   void setOuterConeAngle( F32 val ) { mOuterConeAngle = val; }   bool getCastShadows() const { return mCastShadows; }   void setCastShadows( bool castShadows ) { mCastShadows = castShadows; }      S32 getStaticRefreshFreq() const { return mStaticRefreshFreq; }   void setStaticRefreshFreq(S32 _staticRefreshFreq) { mStaticRefreshFreq = _staticRefreshFreq; }   S32 getDynamicRefreshFreq() const { return mDynamicRefreshFreq; }   void setDynamicRefreshFreq(S32 _dynamicRefreshFreq) { mDynamicRefreshFreq = _dynamicRefreshFreq; }   void setPriority( F32 priority ) { mPriority = priority; }   F32 getPriority() const { return mPriority; }   void setScore( F32 score ) { mScore = score; }   F32 getScore() const { return mScore; }   void setFadeAmount(F32 fade) { mFadeAmount = fade; }   F32 getFadeAmount() const { return mFadeAmount; }   bool isDebugRenderingEnabled() const { return mDebugRender; }   void enableDebugRendering( bool value ) { mDebugRender = value; }   /// Helper function for getting the extended light info.   /// @see getExtended   template <class ExClass>   inline ExClass* getExtended() const { return (ExClass*)getExtended( ExClass::Type ); }   /// Returns the extended light info for the selected type.   LightInfoEx* getExtended( const LightInfoExType &type ) const;   /// Adds the extended info to the light deleting the    /// existing extended info if it has one.   void addExtended( LightInfoEx *lightInfoEx );   /// Delete all registered LightInfoEx instances of the given   /// type.   void deleteExtended( const LightInfoExType& type );   ///    void deleteAllLightInfoEx();   // Builds the world to light view projection used for   // shadow texture and cookie lookups.   void getWorldToLightProj( MatrixF *outMatrix ) const;   ///   void packExtended( BitStream *stream ) const;   ///   void unpackExtended( BitStream *stream );};///class LightInfoList : public Vector<LightInfo*>{public:   void registerLight( LightInfo *light );   void unregisterLight( LightInfo *light );};/// When the scene is queried for lights, the light manager will get /// this interface to trigger a register light call.class ISceneLight{public:   virtual ~ISceneLight() {}   /// Submit lights to the light manager passed in.   virtual void submitLights( LightManager *lm, bool staticLighting ) = 0;   ///   virtual LightInfo* getLight() = 0;};#endif // _LIGHTINFO_H_
 |