| /*
|
| * Copyright 2006 Sony Computer Entertainment Inc.
|
| *
|
| * Licensed under the MIT Open Source License, for details please see license.txt or the website
|
| * http://www.opensource.org/licenses/mit-license.php
|
| *
|
| */ |
| |
| #ifndef __domGlsl_surface_type_h__ |
| #define __domGlsl_surface_type_h__ |
| |
| #include <dae/daeDocument.h> |
| #include <dom/domTypes.h> |
| #include <dom/domElements.h> |
| |
| #include <dom/domFx_surface_common.h> |
| #include <dom/domFx_annotate_common.h> |
| #include <dom/domFx_code_profile.h> |
| #include <dom/domFx_include_common.h> |
| #include <dom/domGlsl_setparam_simple.h> |
| class DAE; |
| |
| /** |
| * A surface type for the GLSL profile. This surface inherits from the fx_surface_common |
| * type and adds the ability to programmatically generate textures. |
| */ |
| class domGlsl_surface_type_complexType : public domFx_surface_common_complexType |
| { |
| public: |
| class domGenerator; |
| |
| typedef daeSmartRef<domGenerator> domGeneratorRef; |
| typedef daeTArray<domGeneratorRef> domGenerator_Array; |
| |
| /** |
| * A procedural surface generator. |
| */ |
| class domGenerator : public daeElement |
| { |
| public: |
| virtual COLLADA_TYPE::TypeEnum getElementType() const { return COLLADA_TYPE::GENERATOR; } |
| static daeInt ID() { return 105; } |
| virtual daeInt typeID() const { return ID(); } |
| public: |
| class domName; |
| |
| typedef daeSmartRef<domName> domNameRef; |
| typedef daeTArray<domNameRef> domName_Array; |
| |
| /** |
| * The entry symbol for the shader function. |
| */ |
| class domName : public daeElement |
| { |
| public: |
| virtual COLLADA_TYPE::TypeEnum getElementType() const { return COLLADA_TYPE::NAME; } |
| static daeInt ID() { return 106; } |
| virtual daeInt typeID() const { return ID(); } |
| protected: // Attribute |
| xsNCName attrSource; |
| |
| protected: // Value |
| /** |
| * The xsNCName value of the text data of this element. |
| */ |
| xsNCName _value; |
| |
| public: //Accessors and Mutators |
| /** |
| * Gets the source attribute. |
| * @return Returns a xsNCName of the source attribute. |
| */ |
| xsNCName getSource() const { return attrSource; } |
| /** |
| * Sets the source attribute. |
| * @param atSource The new value for the source attribute. |
| */ |
| void setSource( xsNCName atSource ) { *(daeStringRef*)&attrSource = atSource; _validAttributeArray[0] = true; } |
| |
| /** |
| * Gets the value of this element. |
| * @return Returns a xsNCName of the value. |
| */ |
| xsNCName getValue() const { return _value; } |
| /** |
| * Sets the _value of this element. |
| * @param val The new value for this element. |
| */ |
| void setValue( xsNCName val ) { *(daeStringRef*)&_value = val; } |
| |
| protected: |
| /** |
| * Constructor |
| */ |
| domName(DAE& dae) : daeElement(dae), attrSource(), _value() {} |
| /** |
| * Destructor |
| */ |
| virtual ~domName() {} |
| /** |
| * Overloaded assignment operator |
| */ |
| virtual domName &operator=( const domName &cpy ) { (void)cpy; return *this; } |
| |
| public: // STATIC METHODS |
| /** |
| * Creates an instance of this class and returns a daeElementRef referencing it. |
| * @return a daeElementRef referencing an instance of this object. |
| */ |
| static DLLSPEC daeElementRef create(DAE& dae); |
| /** |
| * Creates a daeMetaElement object that describes this element in the meta object reflection framework. |
| * If a daeMetaElement already exists it will return that instead of creating a new one. |
| * @return A daeMetaElement describing this COLLADA element. |
| */ |
| static DLLSPEC daeMetaElement* registerElement(DAE& dae); |
| }; |
| |
| |
| |
| protected: // Elements |
| /** |
| * The annotate element allows you to specify an annotation for this surface |
| * generator. @see domAnnotate |
| */ |
| domFx_annotate_common_Array elemAnnotate_array; |
| /** |
| * The code element allows you to embed GLSL code to use for this surface |
| * generator. @see domCode |
| */ |
| domFx_code_profile_Array elemCode_array; |
| /** |
| * The include element allows you to import GLSL code to use for this surface |
| * generator. @see domInclude |
| */ |
| domFx_include_common_Array elemInclude_array; |
| /** |
| * The entry symbol for the shader function. @see domName |
| */ |
| domNameRef elemName; |
| /** |
| * The setparam element allows you to assign a new value to a previously defined |
| * parameter. @see domSetparam |
| */ |
| domGlsl_setparam_simple_Array elemSetparam_array; |
| /** |
| * Used to preserve order in elements that do not specify strict sequencing of sub-elements. |
| */ |
| daeElementRefArray _contents; |
| /** |
| * Used to preserve order in elements that have a complex content model. |
| */ |
| daeUIntArray _contentsOrder; |
| |
| /** |
| * Used to store information needed for some content model objects. |
| */ |
| daeTArray< daeCharArray * > _CMData; |
| |
| |
| public: //Accessors and Mutators |
| /** |
| * Gets the annotate element array. |
| * @return Returns a reference to the array of annotate elements. |
| */ |
| domFx_annotate_common_Array &getAnnotate_array() { return elemAnnotate_array; } |
| /** |
| * Gets the annotate element array. |
| * @return Returns a constant reference to the array of annotate elements. |
| */ |
| const domFx_annotate_common_Array &getAnnotate_array() const { return elemAnnotate_array; } |
| /** |
| * Gets the code element array. |
| * @return Returns a reference to the array of code elements. |
| */ |
| domFx_code_profile_Array &getCode_array() { return elemCode_array; } |
| /** |
| * Gets the code element array. |
| * @return Returns a constant reference to the array of code elements. |
| */ |
| const domFx_code_profile_Array &getCode_array() const { return elemCode_array; } |
| /** |
| * Gets the include element array. |
| * @return Returns a reference to the array of include elements. |
| */ |
| domFx_include_common_Array &getInclude_array() { return elemInclude_array; } |
| /** |
| * Gets the include element array. |
| * @return Returns a constant reference to the array of include elements. |
| */ |
| const domFx_include_common_Array &getInclude_array() const { return elemInclude_array; } |
| /** |
| * Gets the name element. |
| * @return a daeSmartRef to the name element. |
| */ |
| const domNameRef getName() const { return elemName; } |
| /** |
| * Gets the setparam element array. |
| * @return Returns a reference to the array of setparam elements. |
| */ |
| domGlsl_setparam_simple_Array &getSetparam_array() { return elemSetparam_array; } |
| /** |
| * Gets the setparam element array. |
| * @return Returns a constant reference to the array of setparam elements. |
| */ |
| const domGlsl_setparam_simple_Array &getSetparam_array() const { return elemSetparam_array; } |
| /** |
| * Gets the _contents array. |
| * @return Returns a reference to the _contents element array. |
| */ |
| daeElementRefArray &getContents() { return _contents; } |
| /** |
| * Gets the _contents array. |
| * @return Returns a constant reference to the _contents element array. |
| */ |
| const daeElementRefArray &getContents() const { return _contents; } |
| |
| protected: |
| /** |
| * Constructor |
| */ |
| domGenerator(DAE& dae) : daeElement(dae), elemAnnotate_array(), elemCode_array(), elemInclude_array(), elemName(), elemSetparam_array() {} |
| /** |
| * Destructor |
| */ |
| virtual ~domGenerator() { daeElement::deleteCMDataArray(_CMData); } |
| /** |
| * Overloaded assignment operator |
| */ |
| virtual domGenerator &operator=( const domGenerator &cpy ) { (void)cpy; return *this; } |
| |
| public: // STATIC METHODS |
| /** |
| * Creates an instance of this class and returns a daeElementRef referencing it. |
| * @return a daeElementRef referencing an instance of this object. |
| */ |
| static DLLSPEC daeElementRef create(DAE& dae); |
| /** |
| * Creates a daeMetaElement object that describes this element in the meta object reflection framework. |
| * If a daeMetaElement already exists it will return that instead of creating a new one. |
| * @return A daeMetaElement describing this COLLADA element. |
| */ |
| static DLLSPEC daeMetaElement* registerElement(DAE& dae); |
| }; |
| |
| |
| |
| protected: // Element |
| /** |
| * A procedural surface generator. @see domGenerator |
| */ |
| domGeneratorRef elemGenerator; |
| |
| public: //Accessors and Mutators |
| /** |
| * Gets the generator element. |
| * @return a daeSmartRef to the generator element. |
| */ |
| const domGeneratorRef getGenerator() const { return elemGenerator; } |
| protected: |
| /** |
| * Constructor |
| */ |
| domGlsl_surface_type_complexType(DAE& dae, daeElement* elt) : domFx_surface_common_complexType(dae, elt), elemGenerator() {} |
| /** |
| * Destructor |
| */ |
| virtual ~domGlsl_surface_type_complexType() {} |
| /** |
| * Overloaded assignment operator |
| */ |
| virtual domGlsl_surface_type_complexType &operator=( const domGlsl_surface_type_complexType &cpy ) { (void)cpy; return *this; } |
| }; |
| |
| /** |
| * An element of type domGlsl_surface_type_complexType. |
| */ |
| class domGlsl_surface_type : public daeElement, public domGlsl_surface_type_complexType |
| { |
| public: |
| virtual COLLADA_TYPE::TypeEnum getElementType() const { return COLLADA_TYPE::GLSL_SURFACE_TYPE; } |
| static daeInt ID() { return 107; } |
| virtual daeInt typeID() const { return ID(); } |
| protected: |
| /** |
| * Constructor |
| */ |
| domGlsl_surface_type(DAE& dae) : daeElement(dae), domGlsl_surface_type_complexType(dae, this) {} |
| /** |
| * Destructor |
| */ |
| virtual ~domGlsl_surface_type() {} |
| /** |
| * Overloaded assignment operator |
| */ |
| virtual domGlsl_surface_type &operator=( const domGlsl_surface_type &cpy ) { (void)cpy; return *this; } |
| |
| public: // STATIC METHODS |
| /** |
| * Creates an instance of this class and returns a daeElementRef referencing it. |
| * @return a daeElementRef referencing an instance of this object. |
| */ |
| static DLLSPEC daeElementRef create(DAE& dae); |
| /** |
| * Creates a daeMetaElement object that describes this element in the meta object reflection framework. |
| * If a daeMetaElement already exists it will return that instead of creating a new one. |
| * @return A daeMetaElement describing this COLLADA element. |
| */ |
| static DLLSPEC daeMetaElement* registerElement(DAE& dae); |
| }; |
| |
| |
| #endif |