| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464 | //-----------------------------------------------------------------------------// 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 _TERRDATA_H_#define _TERRDATA_H_#ifndef _MPOINT3_H_#include "math/mPoint3.h"#endif#ifndef _SCENEOBJECT_H_#include "scene/sceneObject.h"#endif#ifndef __RESOURCE_H__#include "core/resource.h"#endif#ifndef _RENDERPASSMANAGER_H_#include "renderInstance/renderPassManager.h"#endif#ifndef _TSIGNAL_H_#include "core/util/tSignal.h"#endif#ifndef _TERRFILE_H_#include "terrain/terrFile.h"#endif#ifndef _GFXPRIMITIVEBUFFER_H_#include "gfx/gfxPrimitiveBuffer.h"#endifclass GBitmap;class TerrainBlock;class TerrCell;class PhysicsBody;class TerrainCellMaterial;class TerrainBlock : public SceneObject{   typedef SceneObject Parent;   friend class TerrainEditor;   friend class TerrainCellMaterial;protected:   enum   {      TransformMask        = Parent::NextFreeMask,      FileMask             = Parent::NextFreeMask << 1,      SizeMask             = Parent::NextFreeMask << 2,      MaterialMask         = Parent::NextFreeMask << 3,      HeightMapChangeMask  = Parent::NextFreeMask << 4,      MiscMask             = Parent::NextFreeMask << 5,      NextFreeMask = Parent::NextFreeMask << 6,   };public:   enum BaseTexFormat   {      NONE, DDS, PNG, JPG   };   static const char* formatToExtension(BaseTexFormat format)   {      switch (format)      {      case DDS:         return "dds";      case PNG:         return "png";      case JPG:         return "jpg";      default:         return "";      }   };protected:   Box3F mBounds;   ///   GBitmap *mLightMap;   /// The lightmap dimensions in pixels.   U32 mLightMapSize;   /// The lightmap texture.   GFXTexHandle mLightMapTex;   /// The terrain data file.   Resource<TerrainFile> mFile;   /// The TerrainFile CRC sent from the server.   U32 mCRC;   ///   FileName mTerrFileName;      /// The maximum detail distance found in the material list.   F32 mMaxDetailDistance;   ///   Vector<GFXTexHandle> mBaseTextures;   ///    GFXTexHandle mLayerTex;   /// The shader used to generate the base texture map.   GFXShaderRef mBaseShader;   ///   GFXStateBlockRef mBaseShaderSB;   ///   GFXShaderConstBufferRef mBaseShaderConsts;   ///   GFXShaderConstHandle *mBaseTexScaleConst;   GFXShaderConstHandle *mBaseTexIdConst;   GFXShaderConstHandle *mBaseLayerSizeConst;   ///   GFXTextureTargetRef mBaseTarget;   /// The base texture.   GFXTexHandle mBaseTex;   ///   bool mDetailsDirty;   ///   bool mLayerTexDirty;   /// The desired size for the base texture.   U32 mBaseTexSize;   BaseTexFormat mBaseTexFormat;   ///   TerrCell *mCell;   /// The shared base material which is used to render   /// cells that are outside the detail map range.   TerrainCellMaterial *mBaseMaterial;    /// A dummy material only used for shadow   /// material generation.   BaseMatInstance *mDefaultMatInst;   F32 mSquareSize;   PhysicsBody *mPhysicsRep;   U32 mScreenError;   /// The shared primitive buffer used in rendering.   GFXPrimitiveBufferHandle mPrimBuffer;   /// The cells used in the last render pass   /// when doing debug rendering.   /// @see _renderDebug   Vector<TerrCell*> mDebugCells;   /// Set to enable debug rendering of the terrain.  It   /// is exposed to the console via $terrain::debugRender.   static bool smDebugRender;	/// Allows the terrain to cast shadows onto itself and other objects.	bool mCastShadows;   /// A global LOD scale used to tweak the default   /// terrain screen error value.   static F32 smLODScale;   /// A global detail scale used to tweak the    /// material detail distances.   static F32 smDetailScale;   /// True if the zoning needs to be recalculated for the terrain.   bool mZoningDirty;   String _getBaseTexCacheFileName() const;   void _rebuildQuadtree();   void _updatePhysics();   void _renderBlock( SceneRenderState *state );   void _renderDebug( ObjectRenderInst *ri, SceneRenderState *state, BaseMatInstance *overrideMat );   /// The callback used to get texture events.   /// @see GFXTextureManager::addEventDelegate   void _onTextureEvent( GFXTexCallbackCode code );   /// Used to release terrain materials when   /// the material manager flushes them.   /// @see MaterialManager::getFlushSignal   void _onFlushMaterials();   ///    bool _initBaseShader();   ///   void _updateMaterials();   ///    void _updateBaseTexture( bool writeToCache );   void _updateLayerTexture();   void _updateBounds();   void _onZoningChanged( SceneZoneSpaceManager *zoneManager );   void _updateZoning();   // Protected fields   static bool _setTerrainFile( void *obj, const char *index, const char *data );   static bool _setSquareSize( void *obj, const char *index, const char *data );   static bool _setBaseTexSize(void *obj, const char *index, const char *data);   static bool _setBaseTexFormat(void *obj, const char *index, const char *data);   static bool _setLightMapSize( void *obj, const char *index, const char *data );public:   enum    {      LightmapUpdate    = BIT(0),      HeightmapUpdate   = BIT(1),      LayersUpdate      = BIT(2),      EmptyUpdate       = BIT(3)   };   static Signal<void(U32,TerrainBlock*,const Point2I& ,const Point2I&)> smUpdateSignal;   ///   bool import(   const GBitmap &heightMap,                   F32 heightScale,                   F32 metersPerPixel,                  const Vector<U8> &layerMap,                   const Vector<String> &materials,                  bool flipYAxis = true );#ifdef TORQUE_TOOLS   bool exportHeightMap( const UTF8 *filePath, const String &format ) const;   bool exportLayerMaps( const UTF8 *filePrefix, const String &format ) const;#endifpublic:   TerrainBlock();   virtual ~TerrainBlock();   U32 getCRC() const { return(mCRC); }   Resource<TerrainFile> getFile() const { return mFile; };   bool onAdd();   void onRemove();   void onEditorEnable();   void onEditorDisable();   /// Adds a new material as the top layer or    /// inserts it at the specified index.   void addMaterial( const String &name, U32 insertAt = -1 );   /// Removes the material at the index.   void removeMaterial( U32 index );   /// Updates the material at the index.   void updateMaterial( U32 index, const String &name );   /// Deletes all the materials on the terrain.   void deleteAllMaterials();   //void setMaterialName( U32 index, const String &name );   /// Accessors and mutators for TerrainMaterialUndoAction.   /// @{   const Vector<TerrainMaterial*>& getMaterials() const { return mFile->mMaterials; }      const Vector<U8>& getLayerMap() const { return mFile->mLayerMap; }   void setMaterials( const Vector<TerrainMaterial*> &materials ) { mFile->mMaterials = materials; }   void setLayerMap( const Vector<U8> &layers ) { mFile->mLayerMap = layers; }   /// @}   TerrainMaterial* getMaterial( U32 index ) const;   const char* getMaterialName( U32 index ) const;   U32 getMaterialCount() const;   //BaseMatInstance* getMaterialInst( U32 x, U32 y );   void setHeight( const Point2I &pos, F32 height );   F32 getHeight( const Point2I &pos );   // Performs an update to the selected range of the terrain   // grid including the collision and rendering structures.   void updateGrid(  const Point2I &minPt,                      const Point2I &maxPt,                      bool updateClient = false );   void updateGridMaterials( const Point2I &minPt, const Point2I &maxPt );   Point2I getGridPos( const Point3F &worldPos ) const;      /// This returns true and the terrain z height for   /// a 2d position in the terrains object space.   ///   /// If the terrain at that point is within an empty block   /// or the 2d position is outside of the terrain area then   /// it returns false.   ///   bool getHeight( const Point2F &pos, F32 *height ) const;   void getMinMaxHeight( F32 *minHeight, F32 *maxHeight ) const;   /// This returns true and the terrain normal for a    /// 2d position in the terrains object space.   ///   /// If the terrain at that point is within an empty block   /// or the 2d position is outside of the terrain area then   /// it returns false.   ///   bool getNormal(   const Point2F &pos,                      Point3F *normal,                      bool normalize = true,                      bool skipEmpty = true ) const;   /// This returns true and the smoothed terrain normal    // for a 2d position in the terrains object space.   ///   /// If the terrain at that point is within an empty block   /// or the 2d position is outside of the terrain area then   /// it returns false.   ///   bool getSmoothNormal(   const Point2F &pos,                            Point3F *normal,                            bool normalize = true,                           bool skipEmpty = true ) const;   /// This returns true and the terrain normal and z height   /// for a 2d position in the terrains object space.   ///   /// If the terrain at that point is within an empty block   /// or the 2d position is outside of the terrain area then   /// it returns false.   ///   bool getNormalAndHeight(   const Point2F &pos,                               Point3F *normal,                               F32 *height,                               bool normalize = true ) const;   /// This returns true and the terrain normal, z height, and   /// material name for a 2d position in the terrains object   /// space.   ///   /// If the terrain at that point is within an empty block   /// or the 2d position is outside of the terrain area then   /// it returns false.   ///   bool getNormalHeightMaterial( const Point2F &pos,                                  Point3F *normal,                                  F32 *height,                                  StringTableEntry &matName ) const;   // only the editor currently uses this method - should always be using a ray to collide with   bool collideBox( const Point3F &start, const Point3F &end, RayInfo* info )   {      return castRay( start, end, info );   }   ///   void setLightMap( GBitmap *newLightMap );   /// Fills the lightmap with white.   void clearLightMap();   /// Retuns the dimensions of the light map.   U32 getLightMapSize() const { return mLightMapSize; }   const GBitmap* getLightMap() const { return mLightMap; }   GBitmap* getLightMap() { return mLightMap; }   ///   GFXTextureObject* getLightMapTex();public:   bool setFile( const FileName& terrFileName );   void setFile(const Resource<TerrainFile>& file);   bool save(const char* filename);   F32 getSquareSize() const { return mSquareSize; }   /// Returns the dimensions of the terrain in world space.   F32 getWorldBlockSize() const { return mSquareSize * (F32)mFile->mSize; }   /// Retuns the dimensions of the terrain in samples.   U32 getBlockSize() const { return mFile->mSize; }   U32 getScreenError() const { return smLODScale * mScreenError; }   // SceneObject   void setTransform( const MatrixF &mat );   void setScale( const VectorF &scale );   void prepRenderImage  ( SceneRenderState* state );   void buildConvex(const Box3F& box,Convex* convex);   bool buildPolyList(PolyListContext context, AbstractPolyList* polyList, const Box3F &box, const SphereF &sphere);   bool castRay(const Point3F &start, const Point3F &end, RayInfo* info);   bool castRayI(const Point3F &start, const Point3F &end, RayInfo* info, bool emptyCollide);      bool castRayBlock(   const Point3F &pStart,                         const Point3F &pEnd,                         const Point2I &blockPos,       					   U32 level,                         F32 invDeltaX,                         F32 invDeltaY,                         F32 startT,                         F32 endT,                         RayInfo *info,                         bool collideEmpty );   const FileName& getTerrainFile() const { return mTerrFileName; }   void postLight(Vector<TerrainBlock *> &terrBlocks) {};   DECLARE_CONOBJECT(TerrainBlock);   static void initPersistFields();   U32 packUpdate   (NetConnection *conn, U32 mask, BitStream *stream);   void unpackUpdate(NetConnection *conn,           BitStream *stream);   void inspectPostApply();};#endif // _TERRDATA_H_
 |