#ifndef COMPONENTS_TERRAIN_MATERIAL_H #define COMPONENTS_TERRAIN_MATERIAL_H #include namespace Terrain { class MaterialGenerator { public: /// @param layerList layer textures /// @param blendmapList blend textures /// @param shaders Whether to use shaders. With a shader, blendmap packing can be used (4 channels instead of one), /// so if this parameter is true, then the supplied blend maps are expected to be packed. MaterialGenerator (bool shaders); void setLayerList (const std::vector& layerList) { mLayerList = layerList; } bool hasLayers() { return mLayerList.size(); } void setBlendmapList (const std::vector& blendmapList) { mBlendmapList = blendmapList; } void setCompositeMap (const std::string& name) { mCompositeMap = name; } /// Creates a material suitable for displaying a chunk of terrain using alpha-blending. /// @param mat Material that will be replaced by the generated material. May be empty as well, in which case /// a new material is created. Ogre::MaterialPtr generate (Ogre::MaterialPtr mat); /// Creates a material suitable for displaying a chunk of terrain using a ready-made composite map. /// @param mat Material that will be replaced by the generated material. May be empty as well, in which case /// a new material is created. Ogre::MaterialPtr generateForCompositeMap (Ogre::MaterialPtr mat); /// Creates a material suitable for rendering composite maps, i.e. for "baking" several layer textures /// into one. The main difference compared to a normal material is that no shading is applied at this point. /// @param mat Material that will be replaced by the generated material. May be empty as well, in which case /// a new material is created. Ogre::MaterialPtr generateForCompositeMapRTT (Ogre::MaterialPtr mat); private: Ogre::MaterialPtr create (Ogre::MaterialPtr mat, bool renderCompositeMap, bool displayCompositeMap); int getRequiredPasses (); int getMaxLayersPerPass (); int mNumLayers; std::vector mLayerList; std::vector mBlendmapList; std::string mCompositeMap; bool mShaders; }; } #endif