| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279 | //-----------------------------------------------------------------------------// 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 _BASEMATINSTANCE_H_#define _BASEMATINSTANCE_H_#ifndef _TSIGNAL_H_#include "core/util/tSignal.h"#endif#ifndef _BASEMATERIALDEFINITION_H_#include "materials/baseMaterialDefinition.h"#endif#ifndef _MATERIALPARAMETERS_H_#include "materials/materialParameters.h"#endif#ifndef _MMATRIX_H_#include "math/mMatrix.h"#endif#ifndef _GFXENUMS_H_#include "gfx/gfxEnums.h"#endif#ifndef _GFXSHADER_H_#include "gfx/gfxShader.h"#endif#ifndef _MATERIALFEATUREDATA_H_#include "materials/materialFeatureData.h"#endif#ifndef _MATINSTANCEHOOK_H_#include "materials/matInstanceHook.h"#endif#ifndef _MATSTATEHINT_H_#include "materials/matStateHint.h"#endif#ifndef _GFXDEVICE_H_#include "gfx/gfxDevice.h"#endif#ifndef CUSTOMSHADERBINDINGDATA_H#include "materials/customShaderBindingData.h"#endifstruct RenderPassData;class GFXVertexBufferHandleBase;class GFXPrimitiveBufferHandle;struct SceneData;class SceneRenderState;struct GFXStateBlockDesc;class GFXVertexFormat;class MatrixSet;class ProcessedMaterial;class GuiTreeViewCtrl;///class BaseMatInstance{protected:   /// The array of active material hooks indexed    /// by a MatInstanceHookType.   Vector<MatInstanceHook*> mHooks;   ///   MatFeaturesDelegate mFeaturesDelegate;   /// Should be true if init has been called and it succeeded.   /// It is up to the derived class to set this variable appropriately.   bool mIsValid;   /// This is set by initialization and used by the deferred.   bool mHasNormalMaps;   /// This material makes use of bone transforms   bool mUsesHardwareSkinning;public:   virtual ~BaseMatInstance();   /// @param features The features you want to allow for this material.     ///   /// @param vertexFormat The vertex format on which this material will be rendered.   ///   /// @see GFXVertexFormat   /// @see FeatureSet   virtual bool init(   const FeatureSet &features,                         const GFXVertexFormat *vertexFormat ) = 0;   /// Reinitializes the material using the previous   /// initialization parameters.   /// @see init   virtual bool reInit() = 0;   /// Returns true if init has been successfully called.   /// It is up to the derived class to set this value properly.   bool isValid() { return mIsValid; }   /// Adds this stateblock to the base state block    /// used during initialization.   /// @see init   virtual void addStateBlockDesc(const GFXStateBlockDesc& desc) = 0;   /// Updates the state blocks for this material.   virtual void updateStateBlocks() = 0;   /// Adds a shader macro which will be passed to the shader   /// during initialization.   /// @see init   virtual void addShaderMacro( const String &name, const String &value ) = 0;   /// Get a MaterialParameters block for this BaseMatInstance,    /// caller is responsible for freeing it.   virtual MaterialParameters* allocMaterialParameters() = 0;   /// Set the current parameters for this BaseMatInstance   virtual void setMaterialParameters(MaterialParameters* param) = 0;   /// Get the current parameters for this BaseMatInstance (BaseMatInstances are created with a default active   /// MaterialParameters which is managed by BaseMatInstance.   virtual MaterialParameters* getMaterialParameters() = 0;   /// Returns a MaterialParameterHandle for name.   virtual MaterialParameterHandle* getMaterialParameterHandle(const String& name) = 0;   /// Sets up the next rendering pass for this material.  It is   /// typically called like so...   ///   ///@code   ///   while( mat->setupPass( state, sgData ) )   ///   {   ///      mat->setTransforms(...);   ///      mat->setSceneInfo(...);   ///      ...   ///      GFX->drawPrimitive();   ///   }   ///@endcode   ///   virtual bool setupPass( SceneRenderState *state, const SceneData &sgData ) = 0;      /// This initializes the material transforms and should be    /// called after setupPass() within the pass loop.   /// @see setupPass   virtual void setTransforms( const MatrixSet &matrixSet, SceneRenderState *state ) = 0;   /// Sets node transforms for the current stage. Used for hardware skinning.   virtual void setNodeTransforms( const MatrixF *address, const U32 numTransforms ) = 0;   /// Sets custom shader data   virtual void setCustomShaderData(Vector<CustomShaderBindingData> &shaderData) = 0;   /// This initializes various material scene state settings and   /// should be called after setupPass() within the pass loop.   /// @see setupPass   virtual void setSceneInfo( SceneRenderState *state, const SceneData &sgData ) = 0;   /// This is normally called from within setupPass() automatically, so its   /// unnecessary to do so manually unless a texture stage has changed.  If   /// so it should be called after setupPass() within the pass loop.   /// @see setupPass   virtual void setTextureStages(SceneRenderState *, const SceneData &sgData ) = 0;   /// Sets the vertex and primitive buffers as well as the instancing    /// stream buffer for the current material if the material is instanced.   virtual void setBuffers( GFXVertexBufferHandleBase *vertBuffer, GFXPrimitiveBufferHandle *primBuffer ) = 0;   /// Returns true if this material is instanced.   virtual bool isInstanced() const = 0;   /// Used to increment the instance buffer for this material.   virtual bool stepInstance() = 0;   /// Returns true if the material is forward lit and requires   /// a list of lights which affect it when rendering.   virtual bool isForwardLit() const = 0;   /// Sets a SimObject which will passed into ShaderFeature::createConstHandles.   /// Normal features do not make use of this, it is for special class specific   /// or user designed features.   virtual void setUserObject( SimObject *userObject ) = 0;   virtual SimObject* getUserObject() const = 0;   /// Returns the material this instance is based on.   virtual BaseMaterialDefinition* getMaterial() = 0;   // BTRTODO: This stuff below should probably not be in BaseMatInstance   virtual bool hasGlow() = 0;   virtual bool hasAccumulation() = 0;      virtual U32 getCurPass() = 0;   virtual U32 getCurStageNum() = 0;   virtual RenderPassData *getPass(U32 pass) = 0;   /// Returns the state hint which can be used for    /// sorting and fast comparisions of the equality    /// of a material instance.   virtual const MatStateHint& getStateHint() const = 0;   /// Returns the active features in use by this material.   /// @see getRequestedFeatures   virtual const FeatureSet& getFeatures() const = 0;   /// Returns the features that were requested at material   /// creation time which may differ from the active features.   /// @see getFeatures   virtual const FeatureSet& getRequestedFeatures() const = 0;   virtual const GFXVertexFormat* getVertexFormat() const = 0;   virtual void dumpShaderInfo() const = 0;   virtual void getShaderInfo(GuiTreeViewCtrl* tree, U32 item) const = 0;   /// Fast test for use of normal maps in this material.   bool hasNormalMap() const { return mHasNormalMaps; }   bool usesHardwareSkinning() const { return mUsesHardwareSkinning; }   ///   MatFeaturesDelegate& getFeaturesDelegate() { return mFeaturesDelegate; }   /// Returns true if this MatInstance is built from a CustomMaterial.   virtual bool isCustomMaterial() const = 0;   /// @name Material Hook functions   /// @{   ///   void addHook( MatInstanceHook *hook );   /// Helper function for getting a hook.   /// @see getHook   template <class HOOK>   inline HOOK* getHook() { return (HOOK*)getHook( HOOK::Type ); }   ///   MatInstanceHook* getHook( const MatInstanceHookType &type ) const;   ///   void deleteHook( const MatInstanceHookType &type );   ///   U32 deleteAllHooks();   /// @}   virtual const GFXStateBlockDesc &getUserStateBlock() const = 0;protected:   bool needsHighlighting;public:   bool needsSelectionHighlighting() { return needsHighlighting; };   void setSelectionHighlighting(bool flag) { needsHighlighting = flag; };};#endif /// _BASEMATINSTANCE_H_
 |