From ff34a41621c4fb659d0523e4e0a5c1c57e682a51 Mon Sep 17 00:00:00 2001 From: Emmanuel Christophe <emmanuel.christophe@orfeo-toolbox.org> Date: Thu, 26 Feb 2009 14:32:24 +0800 Subject: [PATCH] OSSIM: update to 1.7.15 --- .../ossim/elevation/ossimElevationShapeIdx.h | 41 - .../ossim/imaging/ossimEsriShapeFileCutter.h | 200 -- .../ossim/imaging/ossimEsriShapeFileFilter.h | 270 --- .../ossim/imaging/ossimImageShapeFileIndex.h | 61 - .../ossim/imaging/ossimImageSourceInterface.h | 109 - .../include/ossim/vec/ossimShapeDatabase.h | 136 -- .../include/ossim/vec/ossimShapeFile.h | 312 --- .../otbossim/include/ossim/vec/shapefil.h | 540 ----- .../elevation/ossimElevationShapeIdx.cpp | 275 --- .../imaging/ossimEsriShapeFileCutter.cpp | 323 --- .../imaging/ossimEsriShapeFileFilter.cpp | 813 ------- .../imaging/ossimImageShapeFileIndex.cpp | 197 -- .../imaging/ossimImageSourceInterface.cpp | 18 - Utilities/otbossim/src/ossim/vec/dbfopen.c | 1552 ------------- .../src/ossim/vec/ossimShapeDatabase.cpp | 268 --- .../otbossim/src/ossim/vec/ossimShapeFile.cpp | 220 -- Utilities/otbossim/src/ossim/vec/shpopen.c | 2021 ----------------- Utilities/otbossim/src/ossim/vec/shptree.c | 986 -------- 18 files changed, 8342 deletions(-) delete mode 100644 Utilities/otbossim/include/ossim/elevation/ossimElevationShapeIdx.h delete mode 100644 Utilities/otbossim/include/ossim/imaging/ossimEsriShapeFileCutter.h delete mode 100644 Utilities/otbossim/include/ossim/imaging/ossimEsriShapeFileFilter.h delete mode 100644 Utilities/otbossim/include/ossim/imaging/ossimImageShapeFileIndex.h delete mode 100644 Utilities/otbossim/include/ossim/imaging/ossimImageSourceInterface.h delete mode 100644 Utilities/otbossim/include/ossim/vec/ossimShapeDatabase.h delete mode 100644 Utilities/otbossim/include/ossim/vec/ossimShapeFile.h delete mode 100644 Utilities/otbossim/include/ossim/vec/shapefil.h delete mode 100644 Utilities/otbossim/src/ossim/elevation/ossimElevationShapeIdx.cpp delete mode 100644 Utilities/otbossim/src/ossim/imaging/ossimEsriShapeFileCutter.cpp delete mode 100644 Utilities/otbossim/src/ossim/imaging/ossimEsriShapeFileFilter.cpp delete mode 100644 Utilities/otbossim/src/ossim/imaging/ossimImageShapeFileIndex.cpp delete mode 100644 Utilities/otbossim/src/ossim/imaging/ossimImageSourceInterface.cpp delete mode 100644 Utilities/otbossim/src/ossim/vec/dbfopen.c delete mode 100644 Utilities/otbossim/src/ossim/vec/ossimShapeDatabase.cpp delete mode 100644 Utilities/otbossim/src/ossim/vec/ossimShapeFile.cpp delete mode 100644 Utilities/otbossim/src/ossim/vec/shpopen.c delete mode 100644 Utilities/otbossim/src/ossim/vec/shptree.c diff --git a/Utilities/otbossim/include/ossim/elevation/ossimElevationShapeIdx.h b/Utilities/otbossim/include/ossim/elevation/ossimElevationShapeIdx.h deleted file mode 100644 index 6f55b6b5c3..0000000000 --- a/Utilities/otbossim/include/ossim/elevation/ossimElevationShapeIdx.h +++ /dev/null @@ -1,41 +0,0 @@ -#ifndef ossimElevationShapeIdx_HEADER -#define ossimElevationShapeIdx_HEADER -#include <exception> -#include <ossim/base/ossimObject.h> -#include <ossim/base/ossimRefPtr.h> -#include <ossim/base/ossimFilename.h> - -class ossimElevationShapeIdxPrivate; - -class ossimElevationShapeIdx : public ossimObject -{ -public: - ossimElevationShapeIdx(const ossimFilename& shapeFilename = "", - bool overWriteFlag = false); - virtual ~ossimElevationShapeIdx(); - void setFilename(const ossimFilename& file, bool overWriteFlag=false); - - void add(const ossimFilename& filename, - ossim_float64 minx, // decimal degrees - ossim_float64 miny, // decimal degrees - ossim_float64 minz, // height in meters meters - ossim_float64 maxx, // decimal degrees - ossim_float64 maxy, // decimal degrees - ossim_float64 maxz); // height in meters meters - - void buildQuadTree(int maxDepth=0); - static const ossimString& defaultName(); - -protected: - static ossimString theDefaultName; - ossimElevationShapeIdxPrivate* thePrivateData; - - ossimFilename theShapeFilename; - ossim_float64 theGlobalMinx; - ossim_float64 theGlobalMiny; - ossim_float64 theGlobalMaxx; - ossim_float64 theGlobalMaxy; - -}; - -#endif diff --git a/Utilities/otbossim/include/ossim/imaging/ossimEsriShapeFileCutter.h b/Utilities/otbossim/include/ossim/imaging/ossimEsriShapeFileCutter.h deleted file mode 100644 index 0d64ed4a23..0000000000 --- a/Utilities/otbossim/include/ossim/imaging/ossimEsriShapeFileCutter.h +++ /dev/null @@ -1,200 +0,0 @@ -//******************************************************************* -// Copyright (C) 2000 ImageLinks Inc. -// -// License: LGPL -// -// See LICENSE.txt file in the top level directory for more details. -// -// Author: Garrett Potts -// -//************************************************************************* -// $Id: ossimEsriShapeFileCutter.h 9094 2006-06-13 19:12:40Z dburken $ -#ifndef ossimEsriShapeFileCutter_HEADER -#define ossimEsriShapeFileCutter_HEADER -#include <ossim/imaging/ossimImageSourceFilter.h> -#include <ossim/base/ossimViewInterface.h> -#include <ossim/imaging/ossimMaskFilter.h> -#include <ossim/imaging/ossimEsriShapeFileFilter.h> - -/** - * This class wraps the ossimEsriShapeFileFilter and ossimMaskFilter to implement - * a composite cutter. - * - * the ossimEsriShapeFileFilter is saved with a shape_file_filter. prefix and the - * ossimMaskFilter is saved with a mask. prefix. Please see ossimEsriShapeFileFilter - * and ossimMaskFilter classes for their keywords. theborder size has an optional units - * associated with it. - * <pre> - * - * The border size can be us-feet, feet, meters, or degrees and is only applied - * to polygons. - * - * Example keyword list - * - * shape_file_filter.brush_color: 255 255 255 - * shape_file_filter.feature_name: - * shape_file_filter.filename: - * shape_file_filter.fill_flag: 0 - * shape_file_filter.max_quadtree_levels: 10 - * shape_file_filter.pen_color: 255 255 255 - * shape_file_filter.point_width_height: 1 1 - * shape_file_filter.thickness: 1 - * shape_file_filter.border_size: 50 meters - * shape_file_filter.type: ossimEsriShapeFileFilter - * mask.mask_type: select - * mask.type: ossimMaskFilter - - * </pre> - * - */ -class ossimEsriShapeFileCutter : public ossimImageSourceFilter, - public ossimViewInterface -{ -public: - /** - * allocates the mask and esri loader - */ - ossimEsriShapeFileCutter(); - - /** - * destroys the data members - */ - virtual ~ossimEsriShapeFileCutter(); - - /** - * Sent to the input - */ - virtual void getDecimationFactor(ossim_uint32 resLevel, - ossimDpt& result)const; - - /** - * The bounding rect call is passed to the mask filter - */ - virtual ossimIrect getBoundingRect(ossim_uint32 resLevel=0)const; - - /** - * The get tile call is passed to the mask filter - */ - virtual ossimRefPtr<ossimImageData> getTile(const ossimIrect& rect, - ossim_uint32 resLevel=0); - - /** - * is passed to the filter and the shape file loader - */ - virtual void initialize(); - - /** - * passed to the input source. - */ - virtual void getDecimationFactors(vector<ossimDpt>& decimations)const; - - /** - * passed to the input source. - */ - virtual ossim_uint32 getNumberOfDecimationLevels()const; - - /** - * passed to the input source. - */ - virtual ossim_uint32 getNumberOfOutputBands() const; - - /** - * passed to the input source. - */ - virtual ossimScalarType getOutputScalarType() const; - - /** - * passed to the input source. - */ - virtual void getValidImageVertices( - vector<ossimIpt>& validVertices, - ossimVertexOrdering ordering=OSSIM_CLOCKWISE_ORDER, - ossim_uint32 resLevel=0)const; - - /** - * passed to the input source. - */ - virtual ossim_uint32 getTileWidth() const; - - /** - * passed to the input source. - */ - virtual ossim_uint32 getTileHeight() const; - - /** - * passed to the input source. - */ - virtual double getNullPixelValue(ossim_uint32 band)const; - - /** - * passed to the input source. - */ - virtual double getMinPixelValue(ossim_uint32 band=0)const; - - /** - * passed to the input source. - */ - virtual double getMaxPixelValue(ossim_uint32 band=0)const; - - /** - * passed to the shape file to load the shape file that will be used - * by the mask filter as input. - */ - void loadFile(const ossimFilename& filename); - - /** - * this is here to support the view interface of the esri shape file. - * it passes view calls to the esri filter - */ - virtual bool setView(ossimObject* baseObject, - bool ownsTheView = false); - - /** - * this is here to support the view interface of the esri shape file. - * Will return the view setting for the esri shape file. - */ - virtual ossimObject* getView(); - - /** - * this is here to support the view interface of the esri shape file. - * Will return the view setting for the esri shape file. - */ - virtual const ossimObject* getView()const; - - /** - * Return the current esri shape file being used - */ - ossimFilename getFilename()const; - - /** - * Sets the mask type. Passes the call to the Mask filter. - */ - void setMaskType(ossimMaskFilter::ossimFileSelectionMaskType type); - - /** - * returns the mask type from the maks filter. - */ - ossimMaskFilter::ossimFileSelectionMaskType getMaskType()const; - - /** - * Passes load state call to the esri shape file loader with prefix - * shape_file_filter. Then passes the load state cll to the mask - * filter with prefix = mask. - */ - virtual bool loadState(const ossimKeywordlist& kwl, - const char* prefix=0); - - /** - * Passes save state call to the esri shape file loader with prefix - * shape_file_filter. Then passes the load state cll to the mask - * filter with prefix = mask. - */ - virtual bool saveState(ossimKeywordlist& kwl, - const char* prefix=0)const; -protected: - ossimEsriShapeFileFilter* theEsriShapeFile; - ossimMaskFilter* theMaskFilter; -TYPE_DATA -}; - -#endif diff --git a/Utilities/otbossim/include/ossim/imaging/ossimEsriShapeFileFilter.h b/Utilities/otbossim/include/ossim/imaging/ossimEsriShapeFileFilter.h deleted file mode 100644 index 18c3f85b05..0000000000 --- a/Utilities/otbossim/include/ossim/imaging/ossimEsriShapeFileFilter.h +++ /dev/null @@ -1,270 +0,0 @@ -//******************************************************************* -// -// License: LGPL -// -// See LICENSE.txt file in the top level directory for more details. -// -// Author: Garrett Potts -// -//************************************************************************* -// $Id: ossimEsriShapeFileFilter.h 9094 2006-06-13 19:12:40Z dburken $ - -#ifndef ossimEsriShapeFileFilter_HEADER -#define ossimEsriShapeFileFilter_HEADER -#include <map> -#include <ossim/imaging/ossimGeoAnnotationSource.h> -#include <ossim/base/ossimViewInterface.h> -#include <ossim/vec/shapefil.h> -#include <ossim/vec/ossimShapeFile.h> -#include <ossim/base/ossimRgbVector.h> - -class ossimGeoAnnotationObject; -class ossimAnnotationObject; - -/*! - * class ossimEsriShapeFileFilter - * - * This class is used to render shape files. Iif this filter has - * an input connection to an ossimImageSourceInterface then it will - * draw any vectors over the input tile. If it is not connected - * it will just render its vector data to a tile and return it. - * <pre> - * supported keywords: - * - * max_quadtree_levels: // number of levels for faster hit testing - * // defaults to 10 - * - * fill_flag: // 1 for true 0 for false. Default is false - * // and specifies how all closed surfaces are - * // to be drawn - * - * feature_name: // currently not used. - * - * pen_color: // specified in Red Green Blue and is the color used - * // if the fill flag is not specified. Future changes - * // might be to include this as an outline color for - * // filled objects. Default is white. Example: 255 255 255 - * - * brush_color: // Color used by objects that have the fill flag enabled - * // format is Red Green Blue. Default is white. - * - * line_thickness: // line drawing thickness in pixels. - * - * border_size: // can be us feet, feet, meters, degrees, - * // will automatically expand all polygons by the - * // specified size. Uses the centroid to estimate - * // non degree units when converting to degrees. - * - * point_width_height: // Specifies the width and height of a point object in - * // pixels. Default is 1 and has the following format - * // w h. Example 1 1 - * - * filename: // The esri shape file to be used - * - * example Keyword list: See ossimAnnotationSource for any additional keywords - * - * - * brush_color: 255 255 255 - * feature_name: - * filename: - * fill_flag: 0 - * max_quadtree_levels: 10 - * pen_color: 255 255 255 - * point_width_height: 1 1 - * thickness: 1 - * border_size: 25 meters - * type: ossimEsriShapeFileFilter - * - * </pre> - */ -class ossimEsriShapeFileFilter : public ossimAnnotationSource, - public ossimViewInterface -{ -public: - ossimEsriShapeFileFilter(ossimImageSource* inputSource=NULL); - ~ossimEsriShapeFileFilter(); - - virtual bool setView(ossimObject* baseObject, - bool ownsTheView = false); - - virtual ossimObject* getView(); - virtual const ossimObject* getView()const; - - virtual bool addObject(ossimAnnotationObject* anObject); - virtual void transformObjects(ossimProjection* projection=0); - virtual void setProjection(ossimProjection* projection, - bool ownsProjectionFlag=false); - virtual bool getImageGeometry(ossimKeywordlist& kwl, - const char* prefix = 0); - virtual ossimIrect getBoundingRect(ossim_uint32 resLevel=0)const; - virtual void computeBoundingRect(); - - virtual void drawAnnotations(ossimRefPtr<ossimImageData> tile); - /*! - * Will delete the current objects within the layer and add all - * objects in the passed in file. - */ - virtual bool loadShapeFile(const ossimFilename& shapeFile); - - virtual ossimFilename getFilename()const - { - return theShapeFile.getFilename(); - } - virtual ossim_int32 getMaxQuadTreeLevels()const - { - return theMaxQuadTreeLevels; - } - - virtual void setMaxQuadTreeLevels(ossim_int32 levels) - { - theMaxQuadTreeLevels = (levels>0?levels:10); - } - - virtual void setBrushColor(const ossimRgbVector& brushColor) - { - theBrushColor = brushColor; - } - - virtual void setPenColor(const ossimRgbVector& penColor) - { - thePenColor = penColor; - } - - virtual ossimRgbVector getPenColor()const - { - return thePenColor; - } - - virtual ossimRgbVector getBrushColor()const - { - return theBrushColor; - } - - virtual bool getFillFlag()const - { - return theFillFlag; - } - - virtual void setFillFlag(bool flag) - { - theFillFlag=flag; - } - virtual ossimString getFeatureName()const - { - return theFeatureName; - } - virtual void setFeatureName(const ossimString& name) - { - theFeatureName = name; - } - - virtual void setThickness(ossim_int32 thickness) - { - theThickness = thickness >= 0? thickness:1; - } - virtual ossim_int32 getThickness()const - { - return theThickness; - } - virtual void setPointRadius(double r) - { - thePointWidthHeight = ossimDpt(fabs(r)*2, fabs(r)*2); - } - virtual double getPointRadius()const - { - return thePointWidthHeight.x/2.0; - } - - virtual ossimAnnotationObject* nextObject(bool restart=false) - { - if(restart) - { - theCurrentObject = theShapeCache.begin(); - } - else - { - if(theCurrentObject != theShapeCache.end()) - { - ++theCurrentObject; - } - - } - - if(theCurrentObject == theShapeCache.end()) - { - return (ossimAnnotationObject*)NULL; - } - return (*theCurrentObject).second; - } - - - virtual bool saveState(ossimKeywordlist& kwl, - const char* prefix=NULL)const; - - virtual bool loadState(const ossimKeywordlist& kwl, - const char* prefix=NULL); -protected: - - /*! - * This holds the output projection. This is used to transform - * the objects to the projection plane. - */ - ossimProjection* theViewProjection; - - /*! - * If the shape file is projected we must know the projector. - * This will allow us to define the geographic objects correctly. - */ - ossimProjection* theShapeFileProjection; - - /*! - * Flag that indicates if we own the view projection. - */ - bool theOwnsViewProjectionFlag; - - /*! - * Specifies if its image/pixel space, Geographic, projected ...etc. - */ - ossimCoordinateSystemType theCoordinateSystem; - - /*! - * If its projected this spceifies the type of unit. We - * need to know if the projection is in meters, feet, us survey feet - * ... etc. - */ - ossimUnitType theUnitType; - - ossim_SHPTree* theTree; - - ossimShapeFile theShapeFile; - - double theMinArray[4]; - double theMaxArray[4]; - - int theMaxQuadTreeLevels; - ossimRgbVector thePenColor; - ossimRgbVector theBrushColor; - bool theFillFlag; - ossim_int32 theThickness; - ossimString theFeatureName; - ossimDpt thePointWidthHeight; - double theBorderSize; - ossimUnitType theBorderSizeUnits; - - mutable std::multimap<int, ossimAnnotationObject*>::iterator theCurrentObject; - - std::multimap<int, ossimAnnotationObject*> theShapeCache; - ossimDrect theBoundingRect; - - void removeViewProjection(); - void deleteCache(); - void checkAndSetDefaultView(); - - virtual void loadPolygon(ossimShapeObject& obj); - virtual void loadPoint(ossimShapeObject& obj); - virtual void loadArc(ossimShapeObject& obj); - -TYPE_DATA -}; - -#endif diff --git a/Utilities/otbossim/include/ossim/imaging/ossimImageShapeFileIndex.h b/Utilities/otbossim/include/ossim/imaging/ossimImageShapeFileIndex.h deleted file mode 100644 index 8973473fdd..0000000000 --- a/Utilities/otbossim/include/ossim/imaging/ossimImageShapeFileIndex.h +++ /dev/null @@ -1,61 +0,0 @@ -#ifndef ossimImageShapeFileIndex_HEADER -#define ossimImageShapeFileIndex_HEADER -#include <ossim/base/ossimObject.h> -#include <ossim/base/ossimReferenced.h> -#include <ossim/base/ossimRefPtr.h> -#include <ossim/base/ossimFilename.h> - -class OSSIM_DLL ossimImageShapeFileIndex : public ossimObject -{ -public: - ossimImageShapeFileIndex(const ossimFilename& shapeFilename = ""); - void setFilename(const ossimFilename& shapeFilename); - - void add(const ossimFilename& filename, - const ossim_int32 entry=-1, // default to all entries - const ossimString& groupName="RASTER"); - /** - * - */ - void build(ossim_uint32 maxDepth=1)const; - -protected: - class ossimImageShapeFileIndexRecord : public ossimReferenced - { - public: - ossimImageShapeFileIndexRecord(const ossimFilename& filename="", - ossim_uint32 entry=0, - const ossimString& groupName="", - ossim_float64 minx=0.0, - ossim_float64 miny=0.0, - ossim_float64 maxx=0.0, - ossim_float64 maxy=0.0) - :theFilename(filename), - theEntry(entry), - theGroupName(groupName), - theMinx(minx), - theMiny(miny), - theMaxx(maxx), - theMaxy(maxy) - { - } - - ossimFilename theFilename; - ossim_uint32 theEntry; - ossimString theGroupName; - ossim_float64 theMinx; - ossim_float64 theMiny; - ossim_float64 theMaxx; - ossim_float64 theMaxy; - }; - - std::vector<ossimRefPtr<ossimImageShapeFileIndexRecord> > theRecords; - - ossimFilename theFilename; - ossim_float64 theGlobalMinx; - ossim_float64 theGlobalMiny; - ossim_float64 theGlobalMaxx; - ossim_float64 theGlobalMaxy; -}; - -#endif diff --git a/Utilities/otbossim/include/ossim/imaging/ossimImageSourceInterface.h b/Utilities/otbossim/include/ossim/imaging/ossimImageSourceInterface.h deleted file mode 100644 index ea924e442a..0000000000 --- a/Utilities/otbossim/include/ossim/imaging/ossimImageSourceInterface.h +++ /dev/null @@ -1,109 +0,0 @@ -//******************************************************************* -// Copyright (C) 2000 ImageLinks Inc. -// -// License: See top level LICENSE.txt file. -// -// Author: Garrett Potts -// -//************************************************************************* -// $Id: ossimImageSourceInterface.h 9094 2006-06-13 19:12:40Z dburken $ -#ifndef ossimImageSourceInterface_HEADER -#define ossimImageSourceInterface_HEADER - -#include <vector> - -#include <ossim/base/ossimErrorContext.h> -#include <ossim/base/ossimConstants.h> -#include <ossim/base/ossimRefPtr.h> -#include <ossim/base/ossimIrect.h> -#include <ossim/base/ossimKeywordlist.h> -#include <ossim/base/ossimFilename.h> - -class ossimImageData; -class ossimObject; - -class OSSIMDLLEXPORT ossimImageSourceInterface -{ -public: - virtual ~ossimImageSourceInterface(); - - virtual ossimObject* getObject()=0; - virtual const ossimObject* getObject()const=0; - - virtual ossimRefPtr<ossimImageData> getTile(const ossimIpt& origin, - ossim_uint32 resLevel=0) = 0; - - virtual ossimRefPtr<ossimImageData> getTile(const ossimIrect& rect, - ossim_uint32 resLevel=0) = 0; - - virtual void getDecimationFactor(ossim_uint32 resLevel, - ossimDpt& result)const=0; - virtual void getDecimationFactors(std::vector<ossimDpt>& decimations)const=0; - virtual ossim_uint32 getNumberOfDecimationLevels()const=0; - - /*! - * Returns the number of bands available from the input. - */ - virtual ossim_uint32 getNumberOfInputBands() const = 0; - - /*! - * Returns the number of bands in output. - */ - virtual ossim_uint32 getNumberOfOutputBands() const = 0; - - /*! - * Initializes bandList to the zero based order of output bands. - */ - virtual void getOutputBandList(std::vector<ossim_uint32>& bandList) const=0; - - virtual ossimScalarType getOutputScalarType() const = 0; - - virtual ossim_uint32 getTileWidth() const = 0; - virtual ossim_uint32 getTileHeight() const = 0; - - virtual double getNullPixelValue(ossim_uint32 band=0)const=0; - virtual double getMinPixelValue(ossim_uint32 band=0)const=0; - virtual double getMaxPixelValue(ossim_uint32 band=0)const=0; - - virtual ossimIrect getBoundingRect(ossim_uint32 resLevel=0)const=0; - - virtual void getValidImageVertices(std::vector<ossimIpt>& validVertices, - ossimVertexOrdering ordering=OSSIM_CLOCKWISE_ORDER, - ossim_uint32 resLevel=0)const=0; - - virtual bool getImageGeometry(ossimKeywordlist& kwl, - const char* prefix=0)=0; - - /** - * Sets the image geometry keyword list. - * - * @note Callers should note that this will override any existing - * geometry. - * - * @note This does not write the geometry to disk, to do so call - * one of the saveImageGeometry methods. - */ - virtual void setImageGeometry(const ossimKeywordlist& kwl)=0; - - /** - * Saves the image geometry to a file that will be made based on the image - * file name. - */ - virtual void saveImageGeometry()const=0; - - /** - * Saves the image geomety to geom_file. - */ - virtual void saveImageGeometry(const ossimFilename& geometry_file)const=0; - - virtual void initialize()=0; - - virtual bool loadState(const ossimKeywordlist& kwl, - const char* prefix=0)=0; - virtual bool saveState(ossimKeywordlist& kwl, - const char* prefix=0)const=0; - -TYPE_DATA -}; - -#endif diff --git a/Utilities/otbossim/include/ossim/vec/ossimShapeDatabase.h b/Utilities/otbossim/include/ossim/vec/ossimShapeDatabase.h deleted file mode 100644 index 95465b7a9d..0000000000 --- a/Utilities/otbossim/include/ossim/vec/ossimShapeDatabase.h +++ /dev/null @@ -1,136 +0,0 @@ -#ifndef ossimShapeDatabase_HEADER -#define ossimShapeDatabase_HEADER -#include <iostream> -#include <ossim/vec/shapefil.h> -#include <ossim/base/ossimFilename.h> -#include <ossim/base/ossimString.h> - - -class OSSIM_DLL ossimShapeDatabaseField -{ -public: - ossimString fieldTypeAsString()const; - - ossimString theName; - int theWidth; - int theDecimals; - ossim_DBFFieldType theFieldType; - ossimString theValue; -}; - -class OSSIM_DLL ossimShapeDatabaseRecord -{ - -public: - bool getField(ossimShapeDatabaseField& result, - ossim_uint32 i) - { - if(i < theFieldArray.size()) - { - result = theFieldArray[i]; - return true; - } - return false; - } - bool setField(const ossimShapeDatabaseField& field, - ossim_uint32 i) - { - if(i < theFieldArray.size()) - { - theFieldArray[i] = field; - return true; - } - return false; - } - int getNumberOfFields()const - { - return theFieldArray.size(); - } - void setNumberOfFields(int n) - { - if(n) - { - theFieldArray.resize(n); - } - else - { - theFieldArray.clear(); - } - } - ossim_int32 getFieldIdx(const ossimString& name, - bool caseInsensitive=true)const; -protected: - std::vector<ossimShapeDatabaseField> theFieldArray; -}; - -class OSSIM_DLL ossimShapeDatabase -{ -public: - friend std::ostream& operator <<(std::ostream& out, const ossimShapeDatabase& rhs) - { - rhs.print(out); - - return out; - } - - ossimShapeDatabase(); - virtual ~ossimShapeDatabase(); - - virtual bool open(const ossimFilename& file, - const ossimString& flags=ossimString("rb")); - - virtual void close(); - - bool getRecord(ossimShapeDatabaseRecord& result); - - bool getRecord(ossimShapeDatabaseRecord& result, - int recordNumber) - { - if(isOpen()) - { - if(recordNumber < getNumberOfRecords()) - { - theRecordNumber = recordNumber; - return getRecord(result); - } - } - - return false; - } - - bool getNextRecord(ossimShapeDatabaseRecord& result) - { - if(isOpen() && ((theRecordNumber+1) < getNumberOfRecords())) - { - ++theRecordNumber; - return getRecord(result); - } - - return false; - } - - int getNumberOfRecords()const; - bool isOpen()const - { - return (theHandle!=NULL); - } - virtual ossim_DBFHandle getHandle() - { - return theHandle; - } - - virtual const ossim_DBFHandle getHandle()const - { - return theHandle; - } - - virtual void print(std::ostream& out)const; - -protected: - ossim_DBFHandle theHandle; - ossimFilename theFilename; - - int theRecordNumber; -}; - -#endif diff --git a/Utilities/otbossim/include/ossim/vec/ossimShapeFile.h b/Utilities/otbossim/include/ossim/vec/ossimShapeFile.h deleted file mode 100644 index 02c45848c6..0000000000 --- a/Utilities/otbossim/include/ossim/vec/ossimShapeFile.h +++ /dev/null @@ -1,312 +0,0 @@ -//******************************************************************* -// -// License: See top level LICENSE.txt file. -// -// Author: Garrett Potts -// -//************************************************************************* -// $Id: ossimShapeFile.h 11424 2007-07-27 17:01:23Z dburken $ - -#ifndef ossimShapeFile_HEADER -#define ossimShapeFile_HEADER -#include <iostream> -#include <ossim/base/ossimConstants.h> -#include <ossim/base/ossimFilename.h> -#include <ossim/base/ossimString.h> -#include <ossim/base/ossimDrect.h> - -#include <ossim/vec/shapefil.h> - -class ossimShapeFile; -class ossimAnnotationObject; - -class OSSIMDLLEXPORT ossimShapeObject -{ -public: - friend std::ostream& operator<<(std::ostream& out, - const ossimShapeObject& rhs); - - ossimShapeObject() - :theShape((ossim_SHPObject*)NULL), - theIndex(-1) - { - } - - ~ossimShapeObject() - { - if(theShape) - { - ossim_SHPDestroyObject(theShape); - theShape = NULL; - } - } - void setShape(ossim_SHPObject* obj); - bool isLoaded()const - { - return (theShape!=NULL); - } - long getIndex()const - { - return theIndex; - } - long getId()const - { - if(theShape) - { - return theShape->nShapeId; - } - - return -1; - } - - bool loadShape(const ossimShapeFile& shapeFile, - long shapeRecord); - - ossim_uint32 getNumberOfParts()const - { - if(theShape) - { - return theShape->nParts; - } - - return 0; - } - ossim_uint32 getNumberOfVertices()const - { - if(theShape) - { - return theShape->nVertices; - } - - return 0; - } - - void getBounds(double& minX, double& minY, double& minZ, double& minM, - double& maxX, double& maxY, double& maxZ, double& maxM)const - { - if(theShape) - { - minX = theShape->dfXMin; - minY = theShape->dfYMin; - minZ = theShape->dfZMin; - minM = theShape->dfMMin; - maxX = theShape->dfXMax; - maxY = theShape->dfYMax; - maxZ = theShape->dfZMax; - maxM = theShape->dfMMax; - } - else - { - minX = minY = minZ = minM = - maxX = maxY = maxZ = maxM = ossim::nan(); - } - } - - void getBounds(double& minX, double& minY, - double& maxX, double& maxY)const - { - if(theShape) - { - minX = theShape->dfXMin; - minY = theShape->dfYMin; - maxX = theShape->dfXMax; - maxY = theShape->dfYMax; - } - else - { - minX = minY = - maxX = maxY = ossim::nan(); - } - } - - void getBoundingRect(ossimDrect& result, - ossimCoordSysOrientMode orient = OSSIM_RIGHT_HANDED)const; - - ossimDrect getBoundingRect(ossimCoordSysOrientMode orient = OSSIM_RIGHT_HANDED)const - { - ossimDrect result; - - getBoundingRect(result, orient); - - return result; - } - - int getType()const - { - if(theShape) - { - return theShape->nSHPType; - } - return ossim_SHPT_NULL; - } - ossimString getTypeByName()const - { - if(theShape) - { - return ossimString(ossim_SHPTypeName(theShape->nSHPType)); - } - return "unknown"; - } - int getPartType(ossim_uint32 partIndex)const - { - if((partIndex > getNumberOfParts())|| - (!theShape)) - { - return -1; - } - - return theShape->panPartType[partIndex]; - } - ossimString getPartByName(ossim_uint32 partIndex)const - { - if((partIndex > getNumberOfParts())|| - (!theShape)) - { - } - switch(theShape->panPartType[partIndex]) - { - case ossim_SHPP_TRISTRIP: - { - ossimString("tristrip"); - break; - } - case ossim_SHPP_TRIFAN: - { - ossimString("trifan"); - break; - } - case ossim_SHPP_OUTERRING: - { - ossimString("outerring"); - break; - } - case ossim_SHPP_INNERRING: - { - ossimString("innerring"); - break; - } - case ossim_SHPP_RING: - { - ossimString("ring"); - break; - } - } - return ossimString("unknown"); - } - ossim_SHPObject* getShapeObject() - { - return theShape; - } - const ossim_SHPObject* getShapeObject()const - { - return theShape; - } - - -protected: - ossim_SHPObject* theShape; - long theIndex; -}; - -class OSSIMDLLEXPORT ossimShapeFile -{ -public: - friend std::ostream& operator <<(std::ostream& out, const ossimShapeFile& rhs) - { - rhs.print(out); - - return out; - } - - ossimShapeFile(); - virtual ~ossimShapeFile(); - - virtual bool open(const ossimFilename& file, - const ossimString& flags=ossimString("rb")); - - virtual void close(); - bool isOpen()const - { - return (theHandle!=NULL); - } - virtual ossim_SHPHandle getHandle() - { - return theHandle; - } - - virtual const ossim_SHPHandle getHandle()const - { - return theHandle; - } - - virtual void print(std::ostream& out)const; - virtual ossimString getShapeTypeString()const; - - - virtual long getNumberOfShapes()const - { - if(theHandle) - { - return theHandle->nRecords; - } - return 0; - } - void getBounds(double& minX, double& minY, double& minZ, double& minM, - double& maxX, double& maxY, double& maxZ, double& maxM)const - { - if(theHandle) - { - minX = theHandle->adBoundsMin[0]; - minY = theHandle->adBoundsMin[1]; - minZ = theHandle->adBoundsMin[2]; - minM = theHandle->adBoundsMin[3]; - maxX = theHandle->adBoundsMax[0]; - maxY = theHandle->adBoundsMax[1]; - maxZ = theHandle->adBoundsMax[2]; - maxM = theHandle->adBoundsMax[3]; - } - else - { - minX = minY = minZ = minM = - maxX = maxY = maxZ = maxM = ossim::nan(); - } - } - - void getBounds(double& minX, double& minY, - double& maxX, double& maxY)const - { - if(theHandle) - { - minX = theHandle->adBoundsMin[0]; - minY = theHandle->adBoundsMin[1]; - maxX = theHandle->adBoundsMax[0]; - maxY = theHandle->adBoundsMax[1]; - } - else - { - minX = minY = maxX = maxY = ossim::nan(); - } - } - - void getBoundingRect(ossimDrect& result, - ossimCoordSysOrientMode orient = OSSIM_RIGHT_HANDED)const; - - ossimDrect getBoundingRect(ossimCoordSysOrientMode orient = OSSIM_RIGHT_HANDED)const - { - ossimDrect result; - - getBoundingRect(result, orient); - - return result; - } - const ossimFilename& getFilename()const - { - return theFilename; - } -protected: - ossim_SHPHandle theHandle; - ossimFilename theFilename; - -}; - -#endif diff --git a/Utilities/otbossim/include/ossim/vec/shapefil.h b/Utilities/otbossim/include/ossim/vec/shapefil.h deleted file mode 100644 index 7dfa62d688..0000000000 --- a/Utilities/otbossim/include/ossim/vec/shapefil.h +++ /dev/null @@ -1,540 +0,0 @@ -#ifndef _SHAPEFILE_H_INCLUDED -#define _SHAPEFILE_H_INCLUDED - -/****************************************************************************** - * $Id: shapefil.h 11039 2007-05-24 15:42:43Z gpotts $ - * - * Project: Shapelib - * Purpose: Primary include file for Shapelib. - * Author: Frank Warmerdam, warmerdam@pobox.com - * - ****************************************************************************** - * Copyright (c) 1999, Frank Warmerdam - * - * This software is available under the following "MIT Style" license, - * or at the option of the licensee under the LGPL (see LICENSE.LGPL). This - * option is discussed in more detail in shapelib.html. - * - * -- - * - * 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. - ****************************************************************************** - * - * $Log$ - * Revision 1.5 2005/10/08 12:57:26 gpotts - * Added adiitional patches - * - * Revision 1.14 2005/03/14 15:21:29 fwarmerdam - * updated - * - * Revision 1.30 2005/01/03 22:30:13 fwarmerdam - * added support for saved quadtrees - * - * Revision 1.29 2004/09/26 20:09:35 fwarmerdam - * avoid rcsid warnings - * - * Revision 1.28 2003/12/29 06:02:18 fwarmerdam - * added cpl_error.h option - * - * Revision 1.27 2003/04/21 18:30:37 warmerda - * added header write/update public methods - * - * Revision 1.26 2002/09/29 00:00:08 warmerda - * added FTLogical and logical attribute read/write calls - * - * Revision 1.25 2002/05/07 13:46:30 warmerda - * added ossim_DBFWriteAttributeDirectly(). - * - * Revision 1.24 2002/04/10 16:59:54 warmerda - * added ossim_SHPRewindObject - * - * Revision 1.23 2002/01/15 14:36:07 warmerda - * updated email address - * - * Revision 1.22 2002/01/15 14:32:00 warmerda - * try to improve ossim_SHPAPI_CALL docs - * - * Revision 1.21 2001/11/01 16:29:55 warmerda - * move pabyRec into ossim_SHPInfo for thread safety - * - * Revision 1.20 2001/07/20 13:06:02 warmerda - * fixed ossim_SHPAPI attribute for ossim_SHPTreeFindLikelyShapes - * - * Revision 1.19 2001/05/31 19:20:13 warmerda - * added ossim_DBFGetFieldIndex() - * - * Revision 1.18 2001/05/31 18:15:40 warmerda - * Added support for NULL fields in ossim_DBF files - * - * Revision 1.17 2001/05/23 13:36:52 warmerda - * added use of ossim_SHPAPI_CALL - * - * Revision 1.16 2000/09/25 14:15:59 warmerda - * added ossim_DBFGetNativeFieldType() - * - * Revision 1.15 2000/02/16 16:03:51 warmerda - * added null shape support - * - * Revision 1.14 1999/11/05 14:12:05 warmerda - * updated license terms - * - * Revision 1.13 1999/06/02 18:24:21 warmerda - * added trimming code - * - * Revision 1.12 1999/06/02 17:56:12 warmerda - * added quad'' subnode support for trees - * - * Revision 1.11 1999/05/18 19:11:11 warmerda - * Added example searching capability - * - * Revision 1.10 1999/05/18 17:49:38 warmerda - * added initial quadtree support - * - * Revision 1.9 1999/05/11 03:19:28 warmerda - * added new Tuple api, and improved extension handling - add from candrsn - * - * Revision 1.8 1999/03/23 17:22:27 warmerda - * Added extern "C" protection for C++ users of shapefil.h. - * - * Revision 1.7 1998/12/31 15:31:07 warmerda - * Added the TRIM_DBF_WHITESPACE and DISABLE_MULTIPATCH_MEASURE options. - * - * Revision 1.6 1998/12/03 15:48:15 warmerda - * Added ossim_SHPCalculateExtents(). - * - * Revision 1.5 1998/11/09 20:57:16 warmerda - * Altered ossim_SHPGetInfo() call. - * - * Revision 1.4 1998/11/09 20:19:33 warmerda - * Added 3D support, and use of ossim_SHPObject. - * - * Revision 1.3 1995/08/23 02:24:05 warmerda - * Added support for reading bounds. - * - * Revision 1.2 1995/08/04 03:17:39 warmerda - * Added header. - * - */ - -#include <stdio.h> - -#ifdef USE_DBMALLOC -#include <dbmalloc.h> -#endif - -#ifdef USE_CPL -#include "cpl_error.h" -#endif - -#ifdef __cplusplus -extern "C" { -#endif - -/************************************************************************/ -/* Configuration options. */ -/************************************************************************/ - -/* -------------------------------------------------------------------- */ -/* Should the ossim_DBFReadStringAttribute() strip leading and */ -/* trailing white space? */ -/* -------------------------------------------------------------------- */ -#define TRIM_DBF_WHITESPACE - -/* -------------------------------------------------------------------- */ -/* Should we write measure values to the Multipatch object? */ -/* Reportedly ArcView crashes if we do write it, so for now it */ -/* is disabled. */ -/* -------------------------------------------------------------------- */ -#define DISABLE_MULTIPATCH_MEASURE - -/* -------------------------------------------------------------------- */ -/* ossim_SHPAPI_CALL */ -/* */ -/* The following two macros are present to allow forcing */ -/* various calling conventions on the Shapelib API. */ -/* */ -/* To force __stdcall conventions (needed to call Shapelib */ -/* from Visual Basic and/or Dephi I believe) the makefile could */ -/* be modified to define: */ -/* */ -/* /DSHPAPI_CALL=__stdcall */ -/* */ -/* If it is desired to force export of the Shapelib API without */ -/* using the shapelib.def file, use the following definition. */ -/* */ -/* /DSHAPELIB_DLLEXPORT */ -/* */ -/* To get both at once it will be necessary to hack this */ -/* include file to define: */ -/* */ -/* #define ossim_SHPAPI_CALL __declspec(dllexport) __stdcall */ -/* #define ossim_SHPAPI_CALL1 __declspec(dllexport) * __stdcall */ -/* */ -/* The complexity of the situtation is partly caused by the */ -/* peculiar requirement of Visual C++ that __stdcall appear */ -/* after any "*"'s in the return value of a function while the */ -/* __declspec(dllexport) must appear before them. */ -/* -------------------------------------------------------------------- */ -#include <ossim/base/ossimConstants.h> - -#ifdef OSSIMMAKINGDLL -# define ossim_SHPAPI_CALL OSSIM_DLL -# define ossim_SHPAPI_CALL1(x) OSSIM_DLL_DATA(x) -#endif -#ifndef ossim_SHPAPI_CALL -# define ossim_SHPAPI_CALL -#endif -#ifndef ossim_SHPAPI_CALL1 -# define ossim_SHPAPI_CALL1(x) x ossim_SHPAPI_CALL -#endif - -#if 0 -#ifdef SHAPELIB_DLLEXPORT -# define ossim_SHPAPI_CALL __declspec(dllexport) -# define ossim_SHPAPI_CALL1(x) __declspec(dllexport) x -#endif -#ifndef ossim_SHPAPI_CALL -# define ossim_SHPAPI_CALL -#endif -#ifndef ossim_SHPAPI_CALL1 -# define ossim_SHPAPI_CALL1(x) x ossim_SHPAPI_CALL -#endif -#endif - -/* -------------------------------------------------------------------- */ -/* Macros for controlling CVSID and ensuring they don't appear */ -/* as unreferenced variables resulting in lots of warnings. */ -/* -------------------------------------------------------------------- */ -#ifndef DISABLE_CVSID -# define ossim_SHP_CVSID(string) static char cpl_cvsid[] = string; \ -static char *cvsid_aw() { return( cvsid_aw() ? ((char *) NULL) : cpl_cvsid ); } -#else -# define ossim_SHP_CVSID(string) -#endif - -/************************************************************************/ -/* ossim_SHP Support. */ -/************************************************************************/ -typedef struct -{ - FILE *fpSHP; - FILE *fpSHX; - - int nShapeType; /* ossim_SHPT_* */ - - int nFileSize; /* ossim_SHP file */ - - int nRecords; - int nMaxRecords; - int *panRecOffset; - int *panRecSize; - - double adBoundsMin[4]; - double adBoundsMax[4]; - - int bUpdated; - - unsigned char *pabyRec; - int nBufSize; -} ossim_SHPInfo; - -typedef ossim_SHPInfo * ossim_SHPHandle; - -/* -------------------------------------------------------------------- */ -/* Shape types (nSHPType) */ -/* -------------------------------------------------------------------- */ -#define ossim_SHPT_NULL 0 -#define ossim_SHPT_POINT 1 -#define ossim_SHPT_ARC 3 -#define ossim_SHPT_POLYGON 5 -#define ossim_SHPT_MULTIPOINT 8 -#define ossim_SHPT_POINTZ 11 -#define ossim_SHPT_ARCZ 13 -#define ossim_SHPT_POLYGONZ 15 -#define ossim_SHPT_MULTIPOINTZ 18 -#define ossim_SHPT_POINTM 21 -#define ossim_SHPT_ARCM 23 -#define ossim_SHPT_POLYGONM 25 -#define ossim_SHPT_MULTIPOINTM 28 -#define ossim_SHPT_MULTIPATCH 31 - - -/* -------------------------------------------------------------------- */ -/* Part types - everything but ossim_SHPT_MULTIPATCH just uses */ -/* ossim_SHPP_RING. */ -/* -------------------------------------------------------------------- */ - -#define ossim_SHPP_TRISTRIP 0 -#define ossim_SHPP_TRIFAN 1 -#define ossim_SHPP_OUTERRING 2 -#define ossim_SHPP_INNERRING 3 -#define ossim_SHPP_FIRSTRING 4 -#define ossim_SHPP_RING 5 - -/* -------------------------------------------------------------------- */ -/* ossim_SHPObject - represents on shape (without attributes) read */ -/* from the .shp file. */ -/* -------------------------------------------------------------------- */ -typedef struct -{ - int nSHPType; - - int nShapeId; /* -1 is unknown/unassigned */ - - int nParts; - int *panPartStart; - int *panPartType; - - int nVertices; - double *padfX; - double *padfY; - double *padfZ; - double *padfM; - - double dfXMin; - double dfYMin; - double dfZMin; - double dfMMin; - - double dfXMax; - double dfYMax; - double dfZMax; - double dfMMax; -} ossim_SHPObject; - -/* -------------------------------------------------------------------- */ -/* ossim_SHP API Prototypes */ -/* -------------------------------------------------------------------- */ -ossim_SHPHandle ossim_SHPAPI_CALL - ossim_SHPOpen( const char * pszShapeFile, const char * pszAccess ); -ossim_SHPHandle ossim_SHPAPI_CALL - ossim_SHPCreate( const char * pszShapeFile, int nShapeType ); -void ossim_SHPAPI_CALL - ossim_SHPGetInfo( ossim_SHPHandle hSHP, int * pnEntities, int * pnShapeType, - double * padfMinBound, double * padfMaxBound ); - -ossim_SHPObject ossim_SHPAPI_CALL1(*) - ossim_SHPReadObject( ossim_SHPHandle hSHP, int iShape ); -int ossim_SHPAPI_CALL - ossim_SHPWriteObject( ossim_SHPHandle hSHP, int iShape, ossim_SHPObject * psObject ); - -void ossim_SHPAPI_CALL - ossim_SHPDestroyObject( ossim_SHPObject * psObject ); -void ossim_SHPAPI_CALL - ossim_SHPComputeExtents( ossim_SHPObject * psObject ); -ossim_SHPObject ossim_SHPAPI_CALL1(*) - ossim_SHPCreateObject( int nSHPType, int nShapeId, int nParts, - const int * panPartStart, const int * panPartType, - int nVertices, - const double * padfX, const double * padfY, - const double * padfZ, const double * padfM ); -ossim_SHPObject ossim_SHPAPI_CALL1(*) - ossim_SHPCreateSimpleObject( int nSHPType, int nVertices, - const double * padfX, - const double * padfY, - const double * padfZ ); - -int ossim_SHPAPI_CALL - ossim_SHPRewindObject( ossim_SHPHandle hSHP, ossim_SHPObject * psObject ); - -void ossim_SHPAPI_CALL ossim_SHPClose( ossim_SHPHandle hSHP ); -void ossim_SHPAPI_CALL ossim_SHPWriteHeader( ossim_SHPHandle hSHP ); - -const char ossim_SHPAPI_CALL1(*) - ossim_SHPTypeName( int nSHPType ); -const char ossim_SHPAPI_CALL1(*) - ossim_SHPPartTypeName( int nPartType ); - -/* -------------------------------------------------------------------- */ -/* Shape quadtree indexing API. */ -/* -------------------------------------------------------------------- */ - -/* this can be two or four for binary or quad tree */ -#define MAX_SUBNODE 4 - -typedef struct shape_tree_node -{ - /* region covered by this node */ - double adfBoundsMin[4]; - double adfBoundsMax[4]; - - /* list of shapes stored at this node. The papsShapeObj pointers - or the whole list can be NULL */ - int nShapeCount; - int *panShapeIds; - ossim_SHPObject **papsShapeObj; - - int nSubNodes; - struct shape_tree_node *apsSubNode[MAX_SUBNODE]; - -} ossim_SHPTreeNode; - -typedef struct -{ - ossim_SHPHandle hSHP; - - int nMaxDepth; - int nDimension; - int nTotalCount; - - ossim_SHPTreeNode *psRoot; -} ossim_SHPTree; - -ossim_SHPTree ossim_SHPAPI_CALL1(*) - ossim_SHPCreateTree( ossim_SHPHandle hSHP, int nDimension, int nMaxDepth, - double *padfBoundsMin, double *padfBoundsMax ); -void ossim_SHPAPI_CALL - ossim_SHPDestroyTree( ossim_SHPTree * hTree ); - -int ossim_SHPAPI_CALL - ossim_SHPWriteTree( ossim_SHPTree *hTree, const char * pszFilename ); -ossim_SHPTree ossim_SHPAPI_CALL - ossim_SHPReadTree( const char * pszFilename ); - -int ossim_SHPAPI_CALL - ossim_SHPTreeAddObject( ossim_SHPTree * hTree, ossim_SHPObject * psObject ); -int ossim_SHPAPI_CALL - ossim_SHPTreeAddShapeId( ossim_SHPTree * hTree, ossim_SHPObject * psObject ); -int ossim_SHPAPI_CALL - ossim_SHPTreeRemoveShapeId( ossim_SHPTree * hTree, int nShapeId ); - -void ossim_SHPAPI_CALL - ossim_SHPTreeTrimExtraNodes( ossim_SHPTree * hTree ); - -int ossim_SHPAPI_CALL1(*) - ossim_SHPTreeFindLikelyShapes( ossim_SHPTree * hTree, - double * padfBoundsMin, - double * padfBoundsMax, - int * ); -int ossim_SHPAPI_CALL - ossim_SHPCheckBoundsOverlap( double *, double *, double *, double *, int ); - -int ossim_SHPAPI_CALL1(*) - ossim_SHPSearchDiskTree( FILE *fp, - double *padfBoundsMin, double *padfBoundsMax, - int *pnShapeCount ); - -/************************************************************************/ -/* ossim_DBF Support. */ -/************************************************************************/ -typedef struct -{ - FILE *fp; - - int nRecords; - - int nRecordLength; - int nHeaderLength; - int nFields; - int *panFieldOffset; - int *panFieldSize; - int *panFieldDecimals; - char *pachFieldType; - - char *pszHeader; - - int nCurrentRecord; - int bCurrentRecordModified; - char *pszCurrentRecord; - - int bNoHeader; - int bUpdated; -} ossim_DBFInfo; - -typedef ossim_DBFInfo * ossim_DBFHandle; - -typedef enum { - FTString, - FTInteger, - FTDouble, - FTLogical, - FTInvalid -} ossim_DBFFieldType; - -#define XBASE_FLDHDR_SZ 32 - -ossim_DBFHandle ossim_SHPAPI_CALL - ossim_DBFOpen( const char * pszDBFFile, const char * pszAccess ); -ossim_DBFHandle ossim_SHPAPI_CALL - ossim_DBFCreate( const char * pszDBFFile ); - -int ossim_SHPAPI_CALL - ossim_DBFGetFieldCount( ossim_DBFHandle psDBF ); -int ossim_SHPAPI_CALL - ossim_DBFGetRecordCount( ossim_DBFHandle psDBF ); -int ossim_SHPAPI_CALL - ossim_DBFAddField( ossim_DBFHandle hDBF, const char * pszFieldName, - ossim_DBFFieldType eType, int nWidth, int nDecimals ); - -ossim_DBFFieldType ossim_SHPAPI_CALL - ossim_DBFGetFieldInfo( ossim_DBFHandle psDBF, int iField, - char * pszFieldName, int * pnWidth, int * pnDecimals ); - -int ossim_SHPAPI_CALL - ossim_DBFGetFieldIndex(ossim_DBFHandle psDBF, const char *pszFieldName); - -int ossim_SHPAPI_CALL - ossim_DBFReadIntegerAttribute( ossim_DBFHandle hDBF, int iShape, int iField ); -double ossim_SHPAPI_CALL - ossim_DBFReadDoubleAttribute( ossim_DBFHandle hDBF, int iShape, int iField ); -const char ossim_SHPAPI_CALL1(*) - ossim_DBFReadStringAttribute( ossim_DBFHandle hDBF, int iShape, int iField ); -const char ossim_SHPAPI_CALL1(*) - ossim_DBFReadLogicalAttribute( ossim_DBFHandle hDBF, int iShape, int iField ); -int ossim_SHPAPI_CALL - ossim_DBFIsAttributeNULL( ossim_DBFHandle hDBF, int iShape, int iField ); - -int ossim_SHPAPI_CALL - ossim_DBFWriteIntegerAttribute( ossim_DBFHandle hDBF, int iShape, int iField, - int nFieldValue ); -int ossim_SHPAPI_CALL - ossim_DBFWriteDoubleAttribute( ossim_DBFHandle hDBF, int iShape, int iField, - double dFieldValue ); -int ossim_SHPAPI_CALL - ossim_DBFWriteStringAttribute( ossim_DBFHandle hDBF, int iShape, int iField, - const char * pszFieldValue ); -int ossim_SHPAPI_CALL - ossim_DBFWriteNULLAttribute( ossim_DBFHandle hDBF, int iShape, int iField ); - -int ossim_SHPAPI_CALL - ossim_DBFWriteLogicalAttribute( ossim_DBFHandle hDBF, int iShape, int iField, - const char lFieldValue); -int ossim_SHPAPI_CALL - ossim_DBFWriteAttributeDirectly(ossim_DBFHandle psDBF, int hEntity, int iField, - void * pValue ); -const char ossim_SHPAPI_CALL1(*) - ossim_DBFReadTuple(ossim_DBFHandle psDBF, int hEntity ); -int ossim_SHPAPI_CALL - ossim_DBFWriteTuple(ossim_DBFHandle psDBF, int hEntity, void * pRawTuple ); - -ossim_DBFHandle ossim_SHPAPI_CALL - ossim_DBFCloneEmpty(ossim_DBFHandle psDBF, const char * pszFilename ); - -void ossim_SHPAPI_CALL - ossim_DBFClose( ossim_DBFHandle hDBF ); -void ossim_SHPAPI_CALL - ossim_DBFUpdateHeader( ossim_DBFHandle hDBF ); -char ossim_SHPAPI_CALL - ossim_DBFGetNativeFieldType( ossim_DBFHandle hDBF, int iField ); - -#ifdef __cplusplus -} -#endif - -#endif /* ndef _SHAPEFILE_H_INCLUDED */ diff --git a/Utilities/otbossim/src/ossim/elevation/ossimElevationShapeIdx.cpp b/Utilities/otbossim/src/ossim/elevation/ossimElevationShapeIdx.cpp deleted file mode 100644 index da29ea1366..0000000000 --- a/Utilities/otbossim/src/ossim/elevation/ossimElevationShapeIdx.cpp +++ /dev/null @@ -1,275 +0,0 @@ -#include <ossim/elevation/ossimElevationShapeIdx.h> -#include <ossim/vec/shapefil.h> - -ossimString ossimElevationShapeIdx::theDefaultName = "elevation_idx.shp"; - -class ossimElevationShapeIdxPrivate : public ossimReferenced -{ -public: - ossimElevationShapeIdxPrivate() - :theShapefileHandle(0), - theDbfHandle(0) - { - } - virtual ~ossimElevationShapeIdxPrivate() - { - shpClose(); - } - ossim_SHPHandle shpOpen(const ossimFilename& file, bool overWriteFlag) - { - shpClose(); - theShapeFilename = file; - if(overWriteFlag) - { - theShapefileHandle = ossim_SHPCreate(file.c_str(), - ossim_SHPT_POLYGON); - } - else - { - theShapefileHandle = ossim_SHPOpen(file.c_str(), - "r+b"); - if(!theShapefileHandle) - { - theShapefileHandle = ossim_SHPCreate(file.c_str(), - ossim_SHPT_POLYGON); - } - } - dbfOpen(overWriteFlag); - - return theShapefileHandle; - } - void shpClose() - { - if(theShapefileHandle) - { - ossim_SHPClose(theShapefileHandle); - theShapefileHandle = 0; - } - } - ossim_SHPHandle shpHandle() - { - return theShapefileHandle; - } - - ossim_DBFHandle dbfHandle() - { - return theDbfHandle; - } - -protected: - void dbfOpen(bool overWriteFlag) - { - dbfClose(); - - if(overWriteFlag) - { - theDbfHandle = ossim_DBFCreate(theShapeFilename.c_str()); - if(theDbfHandle) - { - ossim_DBFAddField(theDbfHandle, "FILENAME", FTString, 256, 0); - ossim_DBFAddField(theDbfHandle, "MINZ", FTDouble, 32, 17); - ossim_DBFAddField(theDbfHandle, "MAXZ", FTDouble, 32, 17); - } - } - else - { - theDbfHandle = ossim_DBFOpen(theShapeFilename.c_str(), "r+b"); - if(!theDbfHandle) - { - theDbfHandle = ossim_DBFCreate(theShapeFilename.c_str()); - if(theDbfHandle) - { - ossim_DBFAddField(theDbfHandle, "FILENAME", FTString, 256, 0); - ossim_DBFAddField(theDbfHandle, "MINZ", FTDouble, 32, 17); - ossim_DBFAddField(theDbfHandle, "MAXZ", FTDouble, 32, 17); - } - } - } - } - void dbfClose() - { - if(theDbfHandle) - { - ossim_DBFClose(theDbfHandle); - theDbfHandle = 0; - } - } - ossimFilename theShapeFilename; - ossim_SHPHandle theShapefileHandle; - ossim_DBFHandle theDbfHandle; -}; - -ossimElevationShapeIdx::ossimElevationShapeIdx(const ossimFilename& shapeFilename, - bool overWriteFlag) - :thePrivateData(0) -{ - setFilename(shapeFilename, overWriteFlag); -} - -ossimElevationShapeIdx::~ossimElevationShapeIdx() -{ - if(thePrivateData) - { - delete thePrivateData; - thePrivateData = 0; - } -} - -const ossimString& ossimElevationShapeIdx::defaultName() -{ - return theDefaultName; -} - -void ossimElevationShapeIdx::setFilename(const ossimFilename& shapeFilename, bool overWriteFlag) -{ - if(thePrivateData) - { - delete thePrivateData; - thePrivateData = 0; - } - if(shapeFilename == "") return; - if(shapeFilename.isDir()) - { - theShapeFilename = shapeFilename.dirCat(theDefaultName); - } - else if(shapeFilename.isFile()) - { - theShapeFilename = shapeFilename; - theShapeFilename.setExtension("shp"); - } - else - { - theShapeFilename = shapeFilename.path(); - - theShapeFilename = theShapeFilename.dirCat(theDefaultName); - theShapeFilename.setExtension("shp"); - } - thePrivateData = new ossimElevationShapeIdxPrivate(); - - if(!thePrivateData->shpOpen(theShapeFilename, overWriteFlag)) - { - thePrivateData = 0; - throw(("ossimElevationShapeIdx::setFilename: Unable to setup index file " + theShapeFilename).c_str()); - } - double minBounds[4]; - double maxBounds[4]; - int nEntities = 0; - int shapeType = ossim_SHPT_NULL; - ossim_SHPGetInfo(thePrivateData->shpHandle(), - &nEntities, - &shapeType, - minBounds, - maxBounds); - if(nEntities < 0) - { - // set it up for the adds - // - theGlobalMinx = 180.0; - theGlobalMiny = 90.0; - theGlobalMaxx = -180.0; - theGlobalMaxy = -90.0; - } - else - { - theGlobalMinx = minBounds[0]; - theGlobalMiny = minBounds[1]; - theGlobalMaxx = maxBounds[0]; - theGlobalMaxy = maxBounds[1]; - } -} - -void ossimElevationShapeIdx::add(const ossimFilename& filename, - ossim_float64 minx, // decimal degrees - ossim_float64 miny, // decimal degrees - ossim_float64 minz, // meters - ossim_float64 maxx, // decimal degrees - ossim_float64 maxy, // decimal degrees - ossim_float64 maxz )// meters -{ - if(!thePrivateData) return; - int iRecord = ossim_DBFGetRecordCount(thePrivateData->dbfHandle()); - double* x = new double[8]; - double* y = new double[8]; - int nVertices = 4; - x[0] = minx; - x[1] = maxx; - x[2] = maxx; - x[3] = minx; - - y[0] = maxy; - y[1] = maxy; - y[2] = miny; - y[3] = miny; - - - if(minx < theGlobalMinx) - { - theGlobalMinx = minx; - } - if(miny < theGlobalMiny) - { - theGlobalMiny = miny; - } - if(maxx > theGlobalMaxx) - { - theGlobalMaxx = maxx; - } - if(maxy > theGlobalMaxy) - { - theGlobalMaxy = maxy; - } - ossim_SHPObject* obj = ossim_SHPCreateSimpleObject(ossim_SHPT_POLYGON, - nVertices, - x, - y, - 0); - - ossim_SHPWriteObject( thePrivateData->shpHandle(), - -1, - obj ); - ossim_DBFWriteStringAttribute(thePrivateData->dbfHandle(), - iRecord, - 0, - filename.c_str()); - ossim_DBFWriteDoubleAttribute(thePrivateData->dbfHandle(), - iRecord, - 0, - (double)minz); - ossim_DBFWriteDoubleAttribute(thePrivateData->dbfHandle(), - iRecord, - 0, - (double)maxz); -} - -void ossimElevationShapeIdx::buildQuadTree(int maxDepth) -{ - if(!thePrivateData) return; - - ossimFilename qTree = theShapeFilename; - - qTree.setExtension("qtree"); - - if(thePrivateData->shpHandle()) - { - double minBounds[4] = {0.0,0.0,0.0,0.0}; - double maxBounds[4] = {0.0,0.0,0.0,0.0}; - - minBounds[0] = theGlobalMinx; - minBounds[1] = theGlobalMiny; - maxBounds[0] = theGlobalMaxx; - maxBounds[1] = theGlobalMaxy; - - ossim_SHPTree* tree = ossim_SHPCreateTree(thePrivateData->shpHandle(), - 2, - maxDepth, - minBounds, - maxBounds); - if(tree) - { - ossim_SHPWriteTree(tree, - qTree.c_str()); - - ossim_SHPDestroyTree(tree); - } - } -} diff --git a/Utilities/otbossim/src/ossim/imaging/ossimEsriShapeFileCutter.cpp b/Utilities/otbossim/src/ossim/imaging/ossimEsriShapeFileCutter.cpp deleted file mode 100644 index 08bb370054..0000000000 --- a/Utilities/otbossim/src/ossim/imaging/ossimEsriShapeFileCutter.cpp +++ /dev/null @@ -1,323 +0,0 @@ -//******************************************************************* -// Copyright (C) 2000 ImageLinks Inc. -// -// License: LGPL -// -// See LICENSE.txt file in the top level directory for more details. -// -// Author: Garrett Potts -// -//************************************************************************* -// $Id: ossimEsriShapeFileCutter.cpp 9094 2006-06-13 19:12:40Z dburken $ -#include <ossim/imaging/ossimEsriShapeFileCutter.h> - -RTTI_DEF2(ossimEsriShapeFileCutter, - "ossimEsriShapeFileCutter", - ossimImageSourceFilter, - ossimViewInterface); - -ossimEsriShapeFileCutter::ossimEsriShapeFileCutter() - :ossimImageSourceFilter(), - ossimViewInterface(), - theEsriShapeFile(NULL), - theMaskFilter(NULL) -{ - theObject = this; - theEsriShapeFile = new ossimEsriShapeFileFilter; - theEsriShapeFile->setFillFlag(true); - - theMaskFilter = new ossimMaskFilter; - - theMaskFilter->connectMyInputTo(1, - theEsriShapeFile); -} - -ossimEsriShapeFileCutter::~ossimEsriShapeFileCutter() -{ - if(theEsriShapeFile) - { - delete theEsriShapeFile; - theEsriShapeFile = NULL; - } - - if(theMaskFilter) - { - delete theMaskFilter; - theMaskFilter = NULL; - } -} - -ossimRefPtr<ossimImageData> ossimEsriShapeFileCutter::getTile( - const ossimIrect& rect, - ossim_uint32 resLevel) -{ - if(isSourceEnabled()) - { - if(theMaskFilter) - { - return theMaskFilter->getTile(rect, resLevel); - } - } - else - { - if(getInput()) - { - ossimImageSourceInterface* input = PTR_CAST(ossimImageSourceInterface, - getInput()); - - if(input) - { - return input->getTile(rect, resLevel); - } - } - } - - return NULL; -} - -void ossimEsriShapeFileCutter::initialize() -{ - if(theEsriShapeFile) - { - theEsriShapeFile->initialize(); - } - - - if(theMaskFilter) - { - theMaskFilter->disconnectMyInput((ossim_int32)0); - theMaskFilter->disconnectMyInput((ossim_int32)1); - theMaskFilter->connectMyInputTo((int)0, - getInput(0)); - theMaskFilter->connectMyInputTo(1, - theEsriShapeFile); - } -} - -bool ossimEsriShapeFileCutter::loadState(const ossimKeywordlist& kwl, - const char* prefix) -{ - ossimString shapeFilePrefix = ossimString(prefix) + "shape_file_filter."; - ossimString maskPrefix = ossimString(prefix) + "mask."; - - theEsriShapeFile->loadState(kwl, shapeFilePrefix.c_str()); - theMaskFilter->loadState(kwl, maskPrefix.c_str()); - - return ossimImageSourceFilter::loadState(kwl, prefix); -} - -bool ossimEsriShapeFileCutter::saveState(ossimKeywordlist& kwl, - const char* prefix)const -{ - ossimString shapeFilePrefix = ossimString(prefix) + "shape_file_filter."; - ossimString maskPrefix = ossimString(prefix) + "mask."; - - theEsriShapeFile->saveState(kwl, shapeFilePrefix.c_str()); - theMaskFilter->saveState(kwl, maskPrefix.c_str()); - - return ossimImageSourceFilter::saveState(kwl, prefix); -} - -void ossimEsriShapeFileCutter::getDecimationFactor(ossim_uint32 resLevel, - ossimDpt& result)const -{ - ossimImageSourceInterface* input = PTR_CAST(ossimImageSourceInterface, getInput(0)); - if(input) - { - input->getDecimationFactor(resLevel, result); - } -} - -ossimIrect ossimEsriShapeFileCutter::getBoundingRect(ossim_uint32 resLevel)const -{ - ossimIrect result; - result.makeNan(); - - if(theMaskFilter) - { - result = theMaskFilter->getBoundingRect(resLevel); - } - - return result; -} - -void ossimEsriShapeFileCutter::getDecimationFactors( - vector<ossimDpt>& decimations)const -{ - ossimImageSourceInterface* input = PTR_CAST(ossimImageSourceInterface, - getInput(0)); - if(input) - { - input->getDecimationFactors(decimations); - } -} - -ossim_uint32 ossimEsriShapeFileCutter::getNumberOfDecimationLevels()const -{ - ossimImageSourceInterface* input = PTR_CAST(ossimImageSourceInterface, - getInput(0)); - if(input) - { - return input->getNumberOfDecimationLevels(); - } - return 0; -} - -ossim_uint32 ossimEsriShapeFileCutter::getNumberOfOutputBands() const -{ - ossimImageSourceInterface* input = PTR_CAST(ossimImageSourceInterface, - getInput(0)); - if(input) - { - return input->getNumberOfOutputBands(); - } - return 0; -} - -ossimScalarType ossimEsriShapeFileCutter::getOutputScalarType() const -{ - ossimImageSourceInterface* input = PTR_CAST(ossimImageSourceInterface, - getInput(0)); - if(input) - { - return input->getOutputScalarType(); - } - - return OSSIM_SCALAR_UNKNOWN; -} - -void ossimEsriShapeFileCutter::getValidImageVertices( - vector<ossimIpt>& validVertices, - ossimVertexOrdering ordering, - ossim_uint32 resLevel) const -{ - ossimImageSourceInterface* input = PTR_CAST(ossimImageSourceInterface, - getInput(0)); - if(input) - { - input->getValidImageVertices(validVertices, ordering, resLevel); - } -} - -ossim_uint32 ossimEsriShapeFileCutter::getTileWidth() const -{ - ossimImageSourceInterface* input = PTR_CAST(ossimImageSourceInterface, - getInput(0)); - if(input) - { - return input->getTileWidth(); - } - - return 0; -} - -ossim_uint32 ossimEsriShapeFileCutter::getTileHeight() const -{ - ossimImageSourceInterface* input = PTR_CAST(ossimImageSourceInterface, - getInput(0)); - if(input) - { - return input->getTileHeight(); - } - return 0; -} - -double ossimEsriShapeFileCutter::getNullPixelValue(ossim_uint32 band)const -{ - ossimImageSourceInterface* input = PTR_CAST(ossimImageSourceInterface, - getInput(0)); - if(input) - { - return input->getNullPixelValue(band); - } - return 0; -} - -double ossimEsriShapeFileCutter::getMinPixelValue(ossim_uint32 band)const -{ - ossimImageSourceInterface* input = PTR_CAST(ossimImageSourceInterface, - getInput(0)); - if(input) - { - return input->getMinPixelValue(band); - } - return 0; -} - -double ossimEsriShapeFileCutter::getMaxPixelValue(ossim_uint32 band)const -{ - ossimImageSourceInterface* input = PTR_CAST(ossimImageSourceInterface, getInput(0)); - if(input) - { - return input->getMaxPixelValue(band); - } - return 0; -} - -void ossimEsriShapeFileCutter::loadFile(const ossimFilename& filename) -{ - if(theEsriShapeFile) - { - theEsriShapeFile->loadShapeFile(filename); - } -} - -bool ossimEsriShapeFileCutter::setView(ossimObject* baseObject, - bool ownsTheView) -{ - if(theEsriShapeFile) - { - return theEsriShapeFile->setView(baseObject, ownsTheView); - } - - return false; -} - -ossimObject* ossimEsriShapeFileCutter::getView() -{ - if(theEsriShapeFile) - { - return theEsriShapeFile->getView(); - } - - return NULL;; -} - -const ossimObject* ossimEsriShapeFileCutter::getView()const -{ - if(theEsriShapeFile) - { - return theEsriShapeFile->getView(); - } - - return NULL;; -} - -ossimFilename ossimEsriShapeFileCutter::getFilename()const -{ - if(theEsriShapeFile) - { - return theEsriShapeFile->getFilename(); - } - - return ossimFilename(); -} - -void ossimEsriShapeFileCutter::setMaskType( - ossimMaskFilter::ossimFileSelectionMaskType type) -{ - if(theMaskFilter) - { - theMaskFilter->setMaskType(type); - } -} - -ossimMaskFilter::ossimFileSelectionMaskType ossimEsriShapeFileCutter::getMaskType()const -{ - if(theMaskFilter) - { - return theMaskFilter->getMaskType(); - } - - return ossimMaskFilter::OSSIM_MASK_TYPE_SELECT; -} diff --git a/Utilities/otbossim/src/ossim/imaging/ossimEsriShapeFileFilter.cpp b/Utilities/otbossim/src/ossim/imaging/ossimEsriShapeFileFilter.cpp deleted file mode 100644 index d47c07b7e0..0000000000 --- a/Utilities/otbossim/src/ossim/imaging/ossimEsriShapeFileFilter.cpp +++ /dev/null @@ -1,813 +0,0 @@ -//******************************************************************* -// Copyright (C) 2000 ImageLinks Inc. -// -// License: See LICENSE.txt file in the top level directory. -// -// Author: Garrett Potts -// -//************************************************************************* -// $Id: ossimEsriShapeFileFilter.cpp 11411 2007-07-27 13:53:51Z dburken $ - -#include <cstdio> -#include <cstdlib> -#include <sstream> -using namespace std; - -#include <ossim/imaging/ossimEsriShapeFileFilter.h> -#include <ossim/vec/ossimShapeFile.h> -#include <ossim/imaging/ossimAnnotationPolyObject.h> -#include <ossim/imaging/ossimGeoAnnotationPolyLineObject.h> -#include <ossim/imaging/ossimAnnotationObject.h> -#include <ossim/imaging/ossimGeoAnnotationPolyObject.h> -#include <ossim/imaging/ossimGeoAnnotationEllipseObject.h> -#include <ossim/base/ossimTrace.h> -#include <ossim/base/ossimCommon.h> -#include <ossim/base/ossimConstants.h> -#include <ossim/base/ossimKeywordNames.h> -#include <ossim/base/ossimTrace.h> -#include <ossim/base/ossimNotifyContext.h> -#include <ossim/base/ossimFilename.h> -#include <ossim/base/ossimGeoPolygon.h> -#include <ossim/base/ossimUnitConversionTool.h> -#include <ossim/projection/ossimProjection.h> -#include <ossim/projection/ossimProjectionFactoryRegistry.h> -#include <ossim/projection/ossimMapProjection.h> - - -RTTI_DEF2(ossimEsriShapeFileFilter, - "ossimEsriShapeFileFilter", - ossimAnnotationSource, - ossimViewInterface); - -static const ossimTrace traceDebug("ossimEsriShapeFileFilter:debug"); - -ossimEsriShapeFileFilter::ossimEsriShapeFileFilter(ossimImageSource* inputSource) - :ossimAnnotationSource(inputSource), - ossimViewInterface(), - theViewProjection(NULL), - theShapeFileProjection(NULL), - theOwnsViewProjectionFlag(true), - theCoordinateSystem(OSSIM_GEOGRAPHIC_SPACE), - theUnitType(OSSIM_METERS), - theTree((ossim_SHPTree*)NULL), - theMaxQuadTreeLevels(10), - thePenColor(255,255,255), - theBrushColor(255,255,255), - theFillFlag(false), - theThickness(1), - thePointWidthHeight(1, 1), - theBorderSize(0.0), - theBorderSizeUnits(OSSIM_DEGREES) -{ - ossimViewInterface::theObject = this; - ossimAnnotationSource::setNumberOfBands(3); - theBoundingRect.makeNan(); - theMinArray[0] = theMinArray[1] = theMinArray[2] = theMinArray[3] = ossim::nan(); - theMaxArray[0] = theMaxArray[1] = theMaxArray[2] = theMaxArray[3] = ossim::nan(); -} - -ossimEsriShapeFileFilter::~ossimEsriShapeFileFilter() -{ - removeViewProjection(); - - if(theTree) - { - ossim_SHPDestroyTree(theTree); - } - - deleteCache(); -} - -bool ossimEsriShapeFileFilter::setView(ossimObject* baseObject, - bool ownsTheView) -{ - ossimProjection* proj = PTR_CAST(ossimProjection, baseObject); - if(proj) - { - setProjection(proj, ownsTheView); - - return true; - } - else if(!baseObject) - { - setProjection((ossimProjection*)NULL, true); - } - - return false; -} - -ossimObject* ossimEsriShapeFileFilter::getView() -{ - return theViewProjection; -} - -const ossimObject* ossimEsriShapeFileFilter::getView()const -{ - return theViewProjection; -} - -bool ossimEsriShapeFileFilter::addObject(ossimAnnotationObject* anObject) -{ - ossimNotify(ossimNotifyLevel_WARN) - << "ossimEsriShapeFileFilter::addObject\n" - << "Can't add objects to layer, must go through Esri loadShapeFile" - <<endl; - - return false; -} - -void ossimEsriShapeFileFilter::computeBoundingRect() -{ -// ossimAnnotationSource::computeBoundingRect(); - - std::multimap<int, ossimAnnotationObject*>::iterator iter = theShapeCache.begin(); - - theBoundingRect.makeNan(); - while(iter != theShapeCache.end()) - { - ossimDrect rect = (*iter).second->getBoundingRect(); - if(theBoundingRect.hasNans()) - { - theBoundingRect = rect; - } - else - { - if(!rect.hasNans()) - { - theBoundingRect = theBoundingRect.combine(rect); - } - } - - ++iter; - } -} - -ossimIrect ossimEsriShapeFileFilter::getBoundingRect(ossim_uint32 resLevel)const -{ - if(!isSourceEnabled()|| - getInput()) - { - if(getInput()) - { - ossimImageSourceInterface* input = PTR_CAST(ossimImageSourceInterface, - getInput()); - if(input) - { - return input->getBoundingRect(resLevel); - } - } - } - return theBoundingRect; -} - -void ossimEsriShapeFileFilter::drawAnnotations(ossimRefPtr<ossimImageData> tile) -{ - ossimAnnotationSource::drawAnnotations(tile); - - if (!theTree||!theShapeFile.isOpen()) return; - if(theViewProjection) - { - ossimIrect rect = tile->getImageRectangle(); - - rect = ossimIrect(rect.ul().x, - rect.ul().y, - rect.lr().x, - rect.lr().y); - double boundsMin[2]; - double boundsMax[2]; - - ossimGpt gp1; - ossimGpt gp2; - ossimGpt gp3; - ossimGpt gp4; - - theViewProjection->lineSampleToWorld(rect.ul(), - gp1); - theViewProjection->lineSampleToWorld(rect.ur(), - gp2); - theViewProjection->lineSampleToWorld(rect.lr(), - gp3); - theViewProjection->lineSampleToWorld(rect.ll(), - gp4); - - ossimDrect boundsRect( ossimDpt(gp1.lond(), - gp1.latd()), - ossimDpt(gp2.lond(), - gp2.latd()), - ossimDpt(gp3.lond(), - gp3.latd()), - ossimDpt(gp4.lond(), - gp4.latd()), - OSSIM_RIGHT_HANDED); - - boundsMin[0] = boundsRect.ul().x; - boundsMin[1] = boundsRect.lr().y; - - boundsMax[0] = boundsRect.lr().x; - boundsMax[1] = boundsRect.ul().y; - - int n; - int *array=(int*)NULL; - - array = ossim_SHPTreeFindLikelyShapes(theTree, - boundsMin, - boundsMax, - &n); - - theImage->setCurrentImageData(tile); - if(n&&array) - { - for(int i = 0; i < n; ++i) - { - std::multimap<int, ossimAnnotationObject*>::iterator iter = theShapeCache.find(array[i]); - while( ((*iter).first == array[i]) && (iter != theShapeCache.end()) ) - { - (*iter).second->draw(*theImage); - ++iter; - } - } - - free(array); - } - } -} - -void ossimEsriShapeFileFilter::transformObjects(ossimProjection* projection) -{ - std::multimap<int, ossimAnnotationObject*>::iterator iter = theShapeCache.begin(); - - - ossimProjection* proj = theViewProjection; - if(projection) - { - proj = projection; - } - - if(!proj) return; - - while(iter != theShapeCache.end()) - { - ossimGeoAnnotationObject* obj = PTR_CAST(ossimGeoAnnotationObject, - (*iter).second); - if(obj) - { - obj->transform(proj); - } - ++iter; - } - - computeBoundingRect(); -} - -void ossimEsriShapeFileFilter::setProjection(ossimProjection* projection, - bool ownsProjectionFlag) -{ - removeViewProjection(); - - theViewProjection = projection; - theOwnsViewProjectionFlag = ownsProjectionFlag; - - transformObjects(); -} - -bool ossimEsriShapeFileFilter::getImageGeometry(ossimKeywordlist& kwl, - const char* prefix) -{ - if(theViewProjection) - { - return theViewProjection->saveState(kwl, prefix); - } - else - { - ossimImageSourceInterface* input = PTR_CAST(ossimImageSourceInterface, getInput(0)); - if(input) - { - return input->getImageGeometry(kwl, prefix); - } - else - { - kwl.add(prefix, - ossimKeywordNames::TYPE_KW, - "ossimEquDistCylProjection", - true); - kwl.add(prefix, - ossimKeywordNames::DECIMAL_DEGREES_PER_PIXEL_LAT, - .1, - true); - kwl.add(prefix, - ossimKeywordNames::DECIMAL_DEGREES_PER_PIXEL_LON, - .1, - true); - kwl.add(prefix, - ossimKeywordNames::CENTRAL_MERIDIAN_KW, - 0.0, - true); - kwl.add(prefix, - ossimKeywordNames::ORIGIN_LATITUDE_KW, - 0.0, - true); - kwl.add(prefix, - ossimKeywordNames::DATUM_KW, - "WGE", - true); - return true; - } - } - - return false; -} - -void ossimEsriShapeFileFilter::removeViewProjection() -{ - if(theViewProjection&&theOwnsViewProjectionFlag) - { - delete theViewProjection; - } - - theViewProjection = NULL; -} - -void ossimEsriShapeFileFilter::deleteCache() -{ - std::multimap<int, ossimAnnotationObject*>::iterator iter = theShapeCache.begin(); - - - while(iter != theShapeCache.end()) - { - if((*iter).second) - { - delete (*iter).second; - } - ++iter; - } - - theShapeCache.clear(); -} - -void ossimEsriShapeFileFilter::checkAndSetDefaultView() -{ - if(!theViewProjection) - { - ossimKeywordlist tempKwl; - getImageGeometry(tempKwl); - - theViewProjection = ossimProjectionFactoryRegistry::instance()->createProjection(tempKwl); - - if(theViewProjection) - { - transformObjects(); - } - } -} - -bool ossimEsriShapeFileFilter::loadShapeFile(const ossimFilename& shapeFile) -{ - if(theTree) - { - ossim_SHPDestroyTree(theTree); - theTree = (ossim_SHPTree*)NULL; - } - theShapeFile.open(shapeFile); - deleteCache(); - deleteAll(); - - if(theShapeFile.isOpen()) - { - theShapeFile.getBounds(theMinArray[0],theMinArray[1],theMinArray[2],theMinArray[3], - theMaxArray[0],theMaxArray[1],theMaxArray[2],theMaxArray[3]); - - theTree = ossim_SHPCreateTree(theShapeFile.getHandle(), - 2, - theMaxQuadTreeLevels, - theMinArray, - theMaxArray); - - ossimShapeObject obj; - for(int index = 0 ; index < theShapeFile.getNumberOfShapes(); ++index) - { - obj.loadShape(theShapeFile, - index); - - if(obj.isLoaded()) - { - switch(obj.getType()) - { - case ossim_SHPT_POLYGON: - case ossim_SHPT_POLYGONZ: - { - loadPolygon(obj); - break; - } - case ossim_SHPT_POINT: - case ossim_SHPT_POINTZ: - { - loadPoint(obj); - break; - } - case ossim_SHPT_ARC: - case ossim_SHPT_ARCZ: - { - loadArc(obj); - break; - } - case ossim_SHPT_NULL: - { - break; - } - default: - { - ossimNotify(ossimNotifyLevel_WARN) - << "ossimEsriShapeFileFilter::loadShapeFile\n" - << "SHAPE " << obj.getTypeByName() - << " Not supported" << endl; - break; - } - } - } - } - - theCurrentObject = theShapeCache .begin(); - if(theViewProjection) - { - transformObjects(); - } - else - { - checkAndSetDefaultView(); - } - } - - return true; -} - -void ossimEsriShapeFileFilter::loadPolygon(ossimShapeObject& obj) -{ - int starti = 0; - int endi = 0; - if(obj.getNumberOfParts() > 1) - { - starti = obj.getShapeObject()->panPartStart[0]; - endi = obj.getShapeObject()->panPartStart[1]; - } - else - { - starti = 0; - endi = obj.getShapeObject()->nVertices; - } - - vector<ossimGpt> groundPolygon; - for(ossim_uint32 part = 0; part < obj.getNumberOfParts(); ++part) - { - if(obj.getPartType(part) != ossim_SHPP_RING) - { - ossimNotify(ossimNotifyLevel_WARN) - << "ossimEsriShapeFileFilter::loadPolygon\n" - << "Part = " << obj.getPartByName(part) - << " not supported for shape = " - << obj.getTypeByName() << endl; - break; - } - groundPolygon.clear(); - for(ossim_int32 vertexNumber = starti; vertexNumber < endi; ++vertexNumber) - { - groundPolygon.push_back(ossimGpt(obj.getShapeObject()->padfY[vertexNumber], - obj.getShapeObject()->padfX[vertexNumber])); - - } - starti = endi; - if((part + 2) < obj.getNumberOfParts()) - { - endi = obj.getShapeObject()->panPartStart[part+2]; - } - else - { - endi = obj.getShapeObject()->nVertices; - } - - ossimRgbVector color; - - if(theFillFlag) - { - color = theBrushColor; - } - else - { - color = thePenColor; - } - - if(theBorderSize != 0.0) - { - ossimGeoPolygon tempPoly(groundPolygon); - ossimGeoPolygon tempPoly2; - - tempPoly.stretchOut(tempPoly2, - theBorderSize); - groundPolygon = tempPoly2.getVertexList(); - - } - - ossimGeoAnnotationObject *newGeoObj = new ossimGeoAnnotationPolyObject(groundPolygon, - theFillFlag, - color.getR(), - color.getG(), - color.getB(), - theThickness); - newGeoObj->setName(theFeatureName); - theShapeCache.insert(make_pair(obj.getId(), - newGeoObj)); - } -} - -void ossimEsriShapeFileFilter::loadPoint(ossimShapeObject& obj) -{ - int n = obj.getNumberOfVertices(); - - if(n) - { - ossimGpt gpt(obj.getShapeObject()->padfY[0], - obj.getShapeObject()->padfX[0]); - - ossimRgbVector color; - - if(theFillFlag) - { - color = theBrushColor; - } - else - { - color = thePenColor; - } - ossimGeoAnnotationEllipseObject *newGeoObj = - new ossimGeoAnnotationEllipseObject(gpt, - thePointWidthHeight, - theFillFlag, - color.getR(), - color.getG(), - color.getB(), - theThickness); - newGeoObj->setEllipseWidthHeightUnitType(OSSIM_PIXEL); - newGeoObj->setName(theFeatureName); - theShapeCache.insert(make_pair(obj.getId(), - newGeoObj)); - - } -} - -void ossimEsriShapeFileFilter::loadArc(ossimShapeObject& obj) -{ - int starti = 0; - int endi = 0; - if(obj.getNumberOfParts() > 1) - { - starti = obj.getShapeObject()->panPartStart[0]; - endi = obj.getShapeObject()->panPartStart[1]; - } - else - { - starti = 0; - endi = obj.getShapeObject()->nVertices; - } - - vector<ossimGpt> groundPolygon; - for(ossim_uint32 part = 0; part < obj.getNumberOfParts(); ++part) - { - if(obj.getPartType(part) != ossim_SHPP_RING) - { - ossimNotify(ossimNotifyLevel_WARN) - << "ossimEsriShapeFileFilter::loadArc\n" - << "Part = " << obj.getPartByName(part) - << " not supported for shape = " - << obj.getTypeByName() << endl; - break; - } - groundPolygon.clear(); - for(ossim_int32 vertexNumber = starti; vertexNumber < endi; ++vertexNumber) - { - groundPolygon.push_back(ossimGpt(obj.getShapeObject()->padfY[vertexNumber], - obj.getShapeObject()->padfX[vertexNumber])); - - } - starti = endi; - if((part + 2) < obj.getNumberOfParts()) - { - endi = obj.getShapeObject()->panPartStart[part+2]; - } - else - { - endi = obj.getShapeObject()->nVertices; - } - - ossimRgbVector color; - - if(theFillFlag) - { - color = theBrushColor; - } - else - { - color = thePenColor; - } - - ossimGeoAnnotationObject *newGeoObj = new ossimGeoAnnotationPolyLineObject(groundPolygon, - color.getR(), - color.getG(), - color.getB(), - theThickness); - newGeoObj->setName(theFeatureName); - theShapeCache.insert(make_pair(obj.getId(), - newGeoObj)); - } -} - -bool ossimEsriShapeFileFilter::saveState(ossimKeywordlist& kwl, - const char* prefix)const -{ - ossimString s; - - kwl.add(prefix, - ossimKeywordNames::FILENAME_KW, - theShapeFile.getFilename(), - true); - - kwl.add(prefix, - ossimKeywordNames::MAX_QUADTREE_LEVELS_KW, - theMaxQuadTreeLevels, - true); - - s = ossimString::toString((int)thePenColor.getR()) + " " + - ossimString::toString((int)thePenColor.getG()) + " " + - ossimString::toString((int)thePenColor.getB()); - - kwl.add(prefix, - ossimKeywordNames::PEN_COLOR_KW, - s.c_str(), - true); - - s = ossimString::toString((int)theBrushColor.getR()) + " " + - ossimString::toString((int)theBrushColor.getG()) + " " + - ossimString::toString((int)theBrushColor.getB()); - - kwl.add(prefix, - ossimKeywordNames::BRUSH_COLOR_KW, - s.c_str(), - true); - - kwl.add(prefix, - ossimKeywordNames::FILL_FLAG_KW, - (int)theFillFlag, - true); - - kwl.add(prefix, - ossimKeywordNames::FEATURE_NAME_KW, - theFeatureName.c_str(), - true); - - kwl.add(prefix, - ossimKeywordNames::THICKNESS_KW, - theThickness, - true); - - ossimString border; - border = ossimString::toString(theBorderSize); - border += " degrees"; - kwl.add(prefix, - ossimKeywordNames::BORDER_SIZE_KW, - border, - true); - - s = ossimString::toString((int)thePointWidthHeight.x) + " " + - ossimString::toString((int)thePointWidthHeight.y) + " "; - - kwl.add(prefix, - ossimKeywordNames::POINT_WIDTH_HEIGHT_KW, - s.c_str(), - true); - - if(theViewProjection) - { - ossimString newPrefix = prefix; - newPrefix += "view_proj."; - theViewProjection->saveState(kwl, - newPrefix.c_str()); - } - - return ossimAnnotationSource::saveState(kwl, prefix); -} - -bool ossimEsriShapeFileFilter::loadState(const ossimKeywordlist& kwl, - const char* prefix) -{ - - const char* quadLevels = kwl.find(prefix, ossimKeywordNames::MAX_QUADTREE_LEVELS_KW); - const char* filename = kwl.find(prefix, ossimKeywordNames::FILENAME_KW); - const char* penColor = kwl.find(prefix, ossimKeywordNames::PEN_COLOR_KW); - const char* brushColor = kwl.find(prefix, ossimKeywordNames::BRUSH_COLOR_KW); - const char* featureName = kwl.find(prefix, ossimKeywordNames::FEATURE_NAME_KW); - const char* fillFlag = kwl.find(prefix, ossimKeywordNames::FILL_FLAG_KW); - const char* thickness = kwl.find(prefix, ossimKeywordNames::THICKNESS_KW); - const char* pointWh = kwl.find(prefix, ossimKeywordNames::POINT_WIDTH_HEIGHT_KW); - const char* border_size = kwl.find(prefix, ossimKeywordNames::BORDER_SIZE_KW); - - deleteCache(); - - if(thickness) - { - theThickness = ossimString(thickness).toLong(); - } - if(quadLevels) - { - theMaxQuadTreeLevels = ossimString(quadLevels).toLong(); - } - - if(penColor) - { - int r, g, b; - istringstream s(penColor); - s>>r>>g>>b; - thePenColor = ossimRgbVector((ossim_uint8)r, (ossim_uint8)g, (ossim_uint8)b); - } - - if(brushColor) - { - int r, g, b; - istringstream s(brushColor); - s>>r>>g>>b; - theBrushColor = ossimRgbVector((ossim_uint8)r, (ossim_uint8)g, (ossim_uint8)b); - } - if(pointWh) - { - double w, h; - istringstream s(pointWh); - s>>w>>h; - thePointWidthHeight = ossimDpt(w, h); - } - - if(fillFlag) - { - theFillFlag = ossimString(fillFlag).toBool(); - } - - if(border_size) - { - istringstream input(border_size); - - ossimString s; - input >> s; - - theBorderSize = s.toDouble(); - - ossimString s2; - - input >> s2; - - s2 = s2.upcase(); - - if(s2 == "US") - { - theBorderSizeUnits = OSSIM_US_SURVEY_FEET; - } - else if(s2 == "METERS") - { - theBorderSizeUnits = OSSIM_METERS; - } - else if(s2 == "FEET") - { - theBorderSizeUnits = OSSIM_FEET; - } - else - { - theBorderSizeUnits = OSSIM_DEGREES; - } - ossimUnitConversionTool unitConvert(theBorderSize, - theBorderSizeUnits); - - theBorderSize = unitConvert.getValue(OSSIM_DEGREES); - theBorderSizeUnits = OSSIM_DEGREES; - } - else - { - theBorderSize = 0.0; - theBorderSizeUnits = OSSIM_DEGREES; - } - - theFeatureName = featureName; - - removeViewProjection(); - - ossimString newPrefix = prefix; - newPrefix += "view_proj."; - - theViewProjection = ossimProjectionFactoryRegistry::instance()->createProjection(kwl, - newPrefix.c_str()); - theOwnsViewProjectionFlag = true; - - if(filename) - { - loadShapeFile(ossimFilename(filename)); - } - - checkAndSetDefaultView(); - - - return ossimAnnotationSource::loadState(kwl, prefix); -} diff --git a/Utilities/otbossim/src/ossim/imaging/ossimImageShapeFileIndex.cpp b/Utilities/otbossim/src/ossim/imaging/ossimImageShapeFileIndex.cpp deleted file mode 100644 index 90dd48d374..0000000000 --- a/Utilities/otbossim/src/ossim/imaging/ossimImageShapeFileIndex.cpp +++ /dev/null @@ -1,197 +0,0 @@ -#include <ossim/imaging/ossimImageShapeFileIndex.h> -#include <ossim/imaging/ossimImageHandlerRegistry.h> -#include <ossim/imaging/ossimImageHandler.h> -#include <ossim/projection/ossimProjectionFactoryRegistry.h> -#include <ossim/projection/ossimProjection.h> -#include <ossim/base/ossimTrace.h> - -#include <ossim/vec/shapefil.h> - -static ossimTrace traceDebug("ossimImageShapeFileIndex:debug"); - -ossimImageShapeFileIndex::ossimImageShapeFileIndex(const ossimFilename& shapeFilename) - :theGlobalMinx(1.0/DBL_EPSILON), - theGlobalMiny(1.0/DBL_EPSILON), - theGlobalMaxx(-1.0/DBL_EPSILON), - theGlobalMaxy(-1.0/DBL_EPSILON) -{ - setFilename(shapeFilename); -} - -void ossimImageShapeFileIndex::setFilename(const ossimFilename& shapeFilename) -{ - theFilename = shapeFilename; - theFilename = theFilename.setExtension(""); -} - -void ossimImageShapeFileIndex::add(const ossimFilename& filename, - const ossim_int32 entry, // default to all entries - const ossimString& groupName) -{ - if(traceDebug()) - { - ossimNotify(ossimNotifyLevel_DEBUG) << "ossimImageShapeFileIndex::add: Entered ...." << std::endl; - } - ossimRefPtr<ossimImageHandler> h = ossimImageHandlerRegistry::instance()->open(filename); - ossimRefPtr<ossimProjection> proj; - - if(h.valid()) - { - std::vector<ossim_uint32> entryList; - if(entry < 0) - { - h->getEntryList(entryList); - } - else - { - entryList.push_back(static_cast<ossim_uint32>(entry)); - } - - ossim_uint32 idx = 0; - for(idx = 0; idx < entryList.size(); ++idx) - { - ossimKeywordlist kwl; - if(h->setCurrentEntry(entryList[idx])) - { - ossimIrect bounds = h->getBoundingRect(); - - h->getImageGeometry(kwl); - proj = ossimProjectionFactoryRegistry::instance()->createProjection(kwl); - - if(proj.valid()) - { - if(traceDebug()) - { - ossimNotify(ossimNotifyLevel_DEBUG) << "Adding file: " << filename << std::endl - << " entry: " << entryList[idx] << std::endl; - } - std::vector<ossimDpt> points; - ossim_float64 minx; - ossim_float64 miny; - ossim_float64 maxx; - ossim_float64 maxy; - ossimGpt ulgpt; - ossimGpt urgpt; - ossimGpt lrgpt; - ossimGpt llgpt; - const ossimDatum* datum = ossimDatumFactory::instance()->wgs84(); - proj->lineSampleToWorld(bounds.ul(), ulgpt); - proj->lineSampleToWorld(bounds.ur(), urgpt); - proj->lineSampleToWorld(bounds.lr(), lrgpt); - proj->lineSampleToWorld(bounds.ll(), llgpt); - - ulgpt.changeDatum(datum); - urgpt.changeDatum(datum); - lrgpt.changeDatum(datum); - llgpt.changeDatum(datum); - - points.push_back(ossimDpt(ulgpt)); - points.push_back(ossimDpt(urgpt)); - points.push_back(ossimDpt(lrgpt)); - points.push_back(ossimDpt(llgpt)); - - ossimDrect rect(points, OSSIM_RIGHT_HANDED); - - minx = rect.ll().x; - miny = rect.ll().y; - maxx = rect.ur().x; - maxy = rect.ur().y; - - if(minx < theGlobalMinx) theGlobalMinx = minx; - if(maxx > theGlobalMaxx) theGlobalMaxx = maxx; - if(miny < theGlobalMiny) theGlobalMiny = miny; - if(maxy > theGlobalMaxy) theGlobalMaxy = maxy; - - theRecords.push_back(new ossimImageShapeFileIndexRecord(filename, - entryList[idx], - groupName, - minx, - miny, - maxx, - maxy)); - } - } - } - } - if(traceDebug()) - { - ossimNotify(ossimNotifyLevel_DEBUG) << "ossimImageShapeFileIndex::add: Leaving ...." << std::endl; - } -} - -void ossimImageShapeFileIndex::build(ossim_uint32 maxDepth)const -{ - if(theRecords.size()) - { - ossim_SHPHandle hSHP = ossim_SHPCreate( theFilename.c_str(), ossim_SHPT_POLYGON); - ossim_DBFHandle hDBF = ossim_DBFCreate( theFilename.c_str()); - - ossim_DBFAddField(hDBF, "GROUP", FTString, 256, 0); - ossim_DBFAddField(hDBF, "FILENAME", FTString, 256, 0); - ossim_DBFAddField(hDBF, "ENTRY", FTInteger, 10, 0); - ossim_DBFAddField(hDBF, "DATUM", FTString, 16, 0); - - double* x = new double[4]; - double* y = new double[4]; - int nVertices = 4; - ossim_uint32 idx = 0; - int iRecord = 0; - for(idx = 0; idx < theRecords.size(); ++idx) - { - x[0] = theRecords[idx]->theMinx; - x[1] = theRecords[idx]->theMaxx; - x[2] = theRecords[idx]->theMaxx; - x[3] = theRecords[idx]->theMinx; - - y[0] = theRecords[idx]->theMaxy; - y[1] = theRecords[idx]->theMaxy; - y[2] = theRecords[idx]->theMiny; - y[3] = theRecords[idx]->theMiny; - - ossim_SHPObject* obj = ossim_SHPCreateSimpleObject(ossim_SHPT_POLYGON, - nVertices, - x, - y, - 0); - ossim_SHPWriteObject( hSHP, -1, obj ); - iRecord = ossim_DBFGetRecordCount( hDBF ); - ossim_DBFWriteStringAttribute(hDBF, iRecord, 0, theRecords[idx]->theGroupName.c_str()); - ossim_DBFWriteStringAttribute(hDBF, iRecord, 1, theRecords[idx]->theFilename.c_str()); - ossim_DBFWriteIntegerAttribute(hDBF, iRecord, 2, (int)(theRecords[idx]->theEntry)); - ossim_DBFWriteStringAttribute(hDBF, iRecord, 3, "WGE"); - ossim_SHPDestroyObject(obj); - } - - ossim_DBFClose(hDBF); - ossim_SHPTree * shpTree = 0; - double minV[4] = {0.0,0.0,0.0,0.0}; - double maxV[4] = {0.0,0.0,0.0,0.0}; - - minV[0] = theGlobalMinx; - minV[1] = theGlobalMiny; - - maxV[0] = theGlobalMaxx; - maxV[1] = theGlobalMaxy; - if(maxDepth>1) - { - if(traceDebug()) - { - ossimNotify(ossimNotifyLevel_DEBUG) << "building quadtree with " << maxDepth << " levels." << std::endl - << "minx = " << theGlobalMinx << std::endl - << "miny = " << theGlobalMiny << std::endl - << "maxx = " << theGlobalMaxx << std::endl - << "maxy = " << theGlobalMaxy << std::endl; - } - shpTree = ossim_SHPCreateTree(hSHP, 2, maxDepth, minV, maxV); - } - - if(shpTree) - { - ossim_SHPWriteTree(shpTree, (theFilename+".qtree").c_str()); - ossim_SHPDestroyTree(shpTree); - } - ossim_SHPClose(hSHP); - } - -} - diff --git a/Utilities/otbossim/src/ossim/imaging/ossimImageSourceInterface.cpp b/Utilities/otbossim/src/ossim/imaging/ossimImageSourceInterface.cpp deleted file mode 100644 index 51a2e25dfe..0000000000 --- a/Utilities/otbossim/src/ossim/imaging/ossimImageSourceInterface.cpp +++ /dev/null @@ -1,18 +0,0 @@ -//******************************************************************* -// Copyright (C) 2000 ImageLinks Inc. -// -// License: LGPL -// -// See LICENSE.txt file in the top level directory for more details. -// -// Author: Garrett Potts -// -//************************************************************************* -// $Id: ossimImageSourceInterface.cpp 9094 2006-06-13 19:12:40Z dburken $ -#include <ossim/imaging/ossimImageSourceInterface.h> - -RTTI_DEF(ossimImageSourceInterface, "ossimImageSourceInterface"); - -ossimImageSourceInterface::~ossimImageSourceInterface() -{ -} diff --git a/Utilities/otbossim/src/ossim/vec/dbfopen.c b/Utilities/otbossim/src/ossim/vec/dbfopen.c deleted file mode 100644 index 1ec330cd4f..0000000000 --- a/Utilities/otbossim/src/ossim/vec/dbfopen.c +++ /dev/null @@ -1,1552 +0,0 @@ -/****************************************************************************** - * $Id: dbfopen.c 9094 2006-06-13 19:12:40Z dburken $ - * - * Project: Shapelib - * Purpose: Implementation of .dbf access API documented in dbf_api.html. - * Author: Frank Warmerdam, warmerdam@pobox.com - * - ****************************************************************************** - * Copyright (c) 1999, Frank Warmerdam - * - * This software is available under the following "MIT Style" license, - * or at the option of the licensee under the LGPL (see LICENSE.LGPL). This - * option is discussed in more detail in shapelib.html. - * - * -- - * - * 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. - ****************************************************************************** - * - * $Log$ - * Revision 1.6 2006/06/13 19:11:32 dburken - * Global include path change. - * - * Revision 1.5 2005/10/08 12:57:26 gpotts - * Added adiitional patches - * - * Revision 1.59 2005/03/14 15:20:28 fwarmerdam - * Fixed last change. - * - * Revision 1.58 2005/03/14 15:18:54 fwarmerdam - * Treat very wide fields with no decimals as double. This is - * more than 32bit integer fields. - * - * Revision 1.57 2005/02/10 20:16:54 fwarmerdam - * Make the pszStringField buffer for ossim_DBFReadAttribute() static char [256] - * as per bug 306. - * - * Revision 1.56 2005/02/10 20:07:56 fwarmerdam - * Fixed bug 305 in ossim_DBFCloneEmpty() - header length problem. - * - * Revision 1.55 2004/09/26 20:23:46 fwarmerdam - * avoid warnings with rcsid and signed/unsigned stuff - * - * Revision 1.54 2004/09/15 16:26:10 fwarmerdam - * Treat all blank numeric fields as null too. - * - * Revision 1.53 2003/12/29 00:00:30 fwarmerdam - * mark ossim_DBFWriteAttributeDirectly as ossim_SHPAPI_CALL - * - * Revision 1.52 2003/07/08 15:20:03 warmerda - * avoid warnings about downcasting to unsigned char - * - * Revision 1.51 2003/07/08 13:50:15 warmerda - * ossim_DBFIsAttributeNULL check for pszValue==NULL - bug 360 - * - * Revision 1.50 2003/04/21 18:58:25 warmerda - * ensure current record is flushed at same time as header is updated - * - * Revision 1.49 2003/04/21 18:30:37 warmerda - * added header write/update public methods - * - * Revision 1.48 2003/03/10 14:51:27 warmerda - * ossim_DBFWrite* calls now return FALSE if they have to truncate - * - * Revision 1.47 2002/11/20 03:32:22 warmerda - * Ensure field name in ossim_DBFGetFieldIndex() is properly terminated. - * - * Revision 1.46 2002/10/09 13:10:21 warmerda - * Added check that width is positive. - * - * Revision 1.45 2002/09/29 00:00:08 warmerda - * added FTLogical and logical attribute read/write calls - * - * Revision 1.44 2002/05/07 13:46:11 warmerda - * Added ossim_DBFWriteAttributeDirectly(). - * - * Revision 1.43 2002/02/13 19:39:21 warmerda - * Fix casting issues in ossim_DBFCloneEmpty(). - * - * Revision 1.42 2002/01/15 14:36:07 warmerda - * updated email address - * - * Revision 1.41 2002/01/15 14:31:49 warmerda - * compute rather than copying nHeaderLength in ossim_DBFCloneEmpty() - * - * Revision 1.40 2002/01/09 04:32:35 warmerda - * fixed to read correct amount of header - * - * Revision 1.39 2001/12/11 22:41:03 warmerda - * improve io related error checking when reading header - * - * Revision 1.38 2001/11/28 16:07:31 warmerda - * Cleanup to avoid compiler warnings as suggested by Richard Hash. - * - * Revision 1.37 2001/07/04 05:18:09 warmerda - * do last fix properly - * - * Revision 1.36 2001/07/04 05:16:09 warmerda - * fixed fieldname comparison in ossim_DBFGetFieldIndex - * - * Revision 1.35 2001/06/22 02:10:06 warmerda - * fixed NULL shape support with help from Jim Matthews - * - * Revision 1.33 2001/05/31 19:20:13 warmerda - * added ossim_DBFGetFieldIndex() - * - * Revision 1.32 2001/05/31 18:15:40 warmerda - * Added support for NULL fields in ossim_DBF files - * - * Revision 1.31 2001/05/23 13:36:52 warmerda - * added use of ossim_SHPAPI_CALL - * - * Revision 1.30 2000/12/05 14:43:38 warmerda - * DBReadAttribute() white space trimming bug fix - * - * Revision 1.29 2000/10/05 14:36:44 warmerda - * fix bug with writing very wide numeric fields - * - * Revision 1.28 2000/09/25 14:18:07 warmerda - * Added some casts of strlen() return result to fix warnings on some - * systems, as submitted by Daniel. - * - * Revision 1.27 2000/09/25 14:15:51 warmerda - * added ossim_DBFGetNativeFieldType() - * - * Revision 1.26 2000/07/07 13:39:45 warmerda - * removed unused variables, and added system include files - * - * Revision 1.25 2000/05/29 18:19:13 warmerda - * avoid use of uchar, and adding casting fix - * - * Revision 1.24 2000/05/23 13:38:27 warmerda - * Added error checks on return results of fread() and fseek(). - * - * Revision 1.23 2000/05/23 13:25:49 warmerda - * Avoid crashing if field or record are out of range in dbfread*attribute(). - * - * Revision 1.22 1999/12/15 13:47:24 warmerda - * Added stdlib.h to ensure that atof() is prototyped. - * - * Revision 1.21 1999/12/13 17:25:46 warmerda - * Added support for upper case .DBF extention. - * - * Revision 1.20 1999/11/30 16:32:11 warmerda - * Use atof() instead of sscanf(). - * - * Revision 1.19 1999/11/05 14:12:04 warmerda - * updated license terms - * - * Revision 1.18 1999/07/27 00:53:28 warmerda - * ensure that whole old field value clear on write of string - * - * Revision 1.1 1999/07/05 18:58:07 warmerda - * New - * - * Revision 1.17 1999/06/11 19:14:12 warmerda - * Fixed some memory leaks. - * - * Revision 1.16 1999/06/11 19:04:11 warmerda - * Remoted some unused variables. - * - * Revision 1.15 1999/05/11 03:19:28 warmerda - * added new Tuple api, and improved extension handling - add from candrsn - * - * Revision 1.14 1999/05/04 15:01:48 warmerda - * Added 'F' support. - * - * Revision 1.13 1999/03/23 17:38:59 warmerda - * ossim_DBFAddField() now actually does return the new field number, or -1 if - * it fails. - * - * Revision 1.12 1999/03/06 02:54:46 warmerda - * Added logic to convert shapefile name to dbf filename in ossim_DBFOpen() - * for convenience. - * - * Revision 1.11 1998/12/31 15:30:34 warmerda - * Improved the interchangability of numeric and string attributes. Add - * white space trimming option for attributes. - * - * Revision 1.10 1998/12/03 16:36:44 warmerda - * Use r+b instead of rb+ for binary access. - * - * Revision 1.9 1998/12/03 15:34:23 warmerda - * Updated copyright message. - * - * Revision 1.8 1997/12/04 15:40:15 warmerda - * Added newline character after field definitions. - * - * Revision 1.7 1997/03/06 14:02:10 warmerda - * Ensure bUpdated is initialized. - * - * Revision 1.6 1996/02/12 04:54:41 warmerda - * Ensure that ossim_DBFWriteAttribute() returns TRUE if it succeeds. - * - * Revision 1.5 1995/10/21 03:15:12 warmerda - * Changed to use binary file access, and ensure that the - * field name field is zero filled, and limited to 10 chars. - * - * Revision 1.4 1995/08/24 18:10:42 warmerda - * Added use of SfRealloc() to avoid pre-ANSI realloc() functions such - * as on the Sun. - * - * Revision 1.3 1995/08/04 03:15:16 warmerda - * Fixed up header. - * - * Revision 1.2 1995/08/04 03:14:43 warmerda - * Added header. - */ - -#include <ossim/vec/shapefil.h> - -#include <math.h> -#include <stdlib.h> -#include <ctype.h> -#include <string.h> - -ossim_SHP_CVSID("$Id: dbfopen.c 9094 2006-06-13 19:12:40Z dburken $") - -#ifndef FALSE -# define FALSE 0 -# define TRUE 1 -#endif - -/************************************************************************/ -/* SfRealloc() */ -/* */ -/* A realloc cover function that will access a NULL pointer as */ -/* a valid input. */ -/************************************************************************/ - -static void * SfRealloc( void * pMem, int nNewSize ) - -{ - if( pMem == NULL ) - return( (void *) malloc(nNewSize) ); - else - return( (void *) realloc(pMem,nNewSize) ); -} - -/************************************************************************/ -/* ossim_DBFWriteHeader() */ -/* */ -/* This is called to write out the file header, and field */ -/* descriptions before writing any actual data records. This */ -/* also computes all the ossim_DBFDataSet field offset/size/decimals */ -/* and so forth values. */ -/************************************************************************/ - -static void ossim_DBFWriteHeader(ossim_DBFHandle psDBF) - -{ - unsigned char abyHeader[XBASE_FLDHDR_SZ]; - int i; - - if( !psDBF->bNoHeader ) - return; - - psDBF->bNoHeader = FALSE; - -/* -------------------------------------------------------------------- */ -/* Initialize the file header information. */ -/* -------------------------------------------------------------------- */ - for( i = 0; i < XBASE_FLDHDR_SZ; i++ ) - abyHeader[i] = 0; - - abyHeader[0] = 0x03; /* memo field? - just copying */ - - /* write out a dummy date */ - abyHeader[1] = 95; /* YY */ - abyHeader[2] = 7; /* MM */ - abyHeader[3] = 26; /* DD */ - - /* record count preset at zero */ - - abyHeader[8] = (unsigned char) (psDBF->nHeaderLength % 256); - abyHeader[9] = (unsigned char) (psDBF->nHeaderLength / 256); - - abyHeader[10] = (unsigned char) (psDBF->nRecordLength % 256); - abyHeader[11] = (unsigned char) (psDBF->nRecordLength / 256); - -/* -------------------------------------------------------------------- */ -/* Write the initial 32 byte file header, and all the field */ -/* descriptions. */ -/* -------------------------------------------------------------------- */ - fseek( psDBF->fp, 0, 0 ); - fwrite( abyHeader, XBASE_FLDHDR_SZ, 1, psDBF->fp ); - fwrite( psDBF->pszHeader, XBASE_FLDHDR_SZ, psDBF->nFields, psDBF->fp ); - -/* -------------------------------------------------------------------- */ -/* Write out the newline character if there is room for it. */ -/* -------------------------------------------------------------------- */ - if( psDBF->nHeaderLength > 32*psDBF->nFields + 32 ) - { - char cNewline; - - cNewline = 0x0d; - fwrite( &cNewline, 1, 1, psDBF->fp ); - } -} - -/************************************************************************/ -/* ossim_DBFFlushRecord() */ -/* */ -/* Write out the current record if there is one. */ -/************************************************************************/ - -static void ossim_DBFFlushRecord( ossim_DBFHandle psDBF ) - -{ - int nRecordOffset; - - if( psDBF->bCurrentRecordModified && psDBF->nCurrentRecord > -1 ) - { - psDBF->bCurrentRecordModified = FALSE; - - nRecordOffset = psDBF->nRecordLength * psDBF->nCurrentRecord - + psDBF->nHeaderLength; - - fseek( psDBF->fp, nRecordOffset, 0 ); - fwrite( psDBF->pszCurrentRecord, psDBF->nRecordLength, 1, psDBF->fp ); - } -} - -/************************************************************************/ -/* ossim_DBFUpdateHeader() */ -/************************************************************************/ - -void ossim_SHPAPI_CALL - ossim_DBFUpdateHeader( ossim_DBFHandle psDBF ) - -{ - unsigned char abyFileHeader[32]; - - if( psDBF->bNoHeader ) - ossim_DBFWriteHeader( psDBF ); - - ossim_DBFFlushRecord( psDBF ); - - fseek( psDBF->fp, 0, 0 ); - fread( abyFileHeader, 32, 1, psDBF->fp ); - - abyFileHeader[4] = (unsigned char) (psDBF->nRecords % 256); - abyFileHeader[5] = (unsigned char) ((psDBF->nRecords/256) % 256); - abyFileHeader[6] = (unsigned char) ((psDBF->nRecords/(256*256)) % 256); - abyFileHeader[7] = (unsigned char) ((psDBF->nRecords/(256*256*256)) % 256); - - fseek( psDBF->fp, 0, 0 ); - fwrite( abyFileHeader, 32, 1, psDBF->fp ); - - fflush( psDBF->fp ); -} - -/************************************************************************/ -/* ossim_DBFOpen() */ -/* */ -/* Open a .dbf file. */ -/************************************************************************/ - -ossim_DBFHandle ossim_SHPAPI_CALL - ossim_DBFOpen( const char * pszFilename, const char * pszAccess ) - -{ - ossim_DBFHandle psDBF; - unsigned char *pabyBuf; - int nFields, nHeadLen, nRecLen, iField, i; - char *pszBasename, *pszFullname; - -/* -------------------------------------------------------------------- */ -/* We only allow the access strings "rb" and "r+". */ -/* -------------------------------------------------------------------- */ - if( strcmp(pszAccess,"r") != 0 && strcmp(pszAccess,"r+") != 0 - && strcmp(pszAccess,"rb") != 0 && strcmp(pszAccess,"rb+") != 0 - && strcmp(pszAccess,"r+b") != 0 ) - return( NULL ); - - if( strcmp(pszAccess,"r") == 0 ) - pszAccess = "rb"; - - if( strcmp(pszAccess,"r+") == 0 ) - pszAccess = "rb+"; - -/* -------------------------------------------------------------------- */ -/* Compute the base (layer) name. If there is any extension */ -/* on the passed in filename we will strip it off. */ -/* -------------------------------------------------------------------- */ - pszBasename = (char *) malloc(strlen(pszFilename)+5); - strcpy( pszBasename, pszFilename ); - for( i = strlen(pszBasename)-1; - i > 0 && pszBasename[i] != '.' && pszBasename[i] != '/' - && pszBasename[i] != '\\'; - i-- ) {} - - if( pszBasename[i] == '.' ) - pszBasename[i] = '\0'; - - pszFullname = (char *) malloc(strlen(pszBasename) + 5); - sprintf( pszFullname, "%s.dbf", pszBasename ); - - psDBF = (ossim_DBFHandle) calloc( 1, sizeof(ossim_DBFInfo) ); - psDBF->fp = fopen( pszFullname, pszAccess ); - - if( psDBF->fp == NULL ) - { - sprintf( pszFullname, "%s.DBF", pszBasename ); - psDBF->fp = fopen(pszFullname, pszAccess ); - } - - free( pszBasename ); - free( pszFullname ); - - if( psDBF->fp == NULL ) - { - free( psDBF ); - return( NULL ); - } - - psDBF->bNoHeader = FALSE; - psDBF->nCurrentRecord = -1; - psDBF->bCurrentRecordModified = FALSE; - -/* -------------------------------------------------------------------- */ -/* Read Table Header info */ -/* -------------------------------------------------------------------- */ - pabyBuf = (unsigned char *) malloc(500); - if( fread( pabyBuf, 32, 1, psDBF->fp ) != 1 ) - { - fclose( psDBF->fp ); - free( pabyBuf ); - free( psDBF ); - return NULL; - } - - psDBF->nRecords = - pabyBuf[4] + pabyBuf[5]*256 + pabyBuf[6]*256*256 + pabyBuf[7]*256*256*256; - - psDBF->nHeaderLength = nHeadLen = pabyBuf[8] + pabyBuf[9]*256; - psDBF->nRecordLength = nRecLen = pabyBuf[10] + pabyBuf[11]*256; - - psDBF->nFields = nFields = (nHeadLen - 32) / 32; - - psDBF->pszCurrentRecord = (char *) malloc(nRecLen); - -/* -------------------------------------------------------------------- */ -/* Read in Field Definitions */ -/* -------------------------------------------------------------------- */ - - pabyBuf = (unsigned char *) SfRealloc(pabyBuf,nHeadLen); - psDBF->pszHeader = (char *) pabyBuf; - - fseek( psDBF->fp, 32, 0 ); - if( fread( pabyBuf, nHeadLen-32, 1, psDBF->fp ) != 1 ) - { - fclose( psDBF->fp ); - free( pabyBuf ); - free( psDBF ); - return NULL; - } - - psDBF->panFieldOffset = (int *) malloc(sizeof(int) * nFields); - psDBF->panFieldSize = (int *) malloc(sizeof(int) * nFields); - psDBF->panFieldDecimals = (int *) malloc(sizeof(int) * nFields); - psDBF->pachFieldType = (char *) malloc(sizeof(char) * nFields); - - for( iField = 0; iField < nFields; iField++ ) - { - unsigned char *pabyFInfo; - - pabyFInfo = pabyBuf+iField*32; - - if( pabyFInfo[11] == 'N' || pabyFInfo[11] == 'F' ) - { - psDBF->panFieldSize[iField] = pabyFInfo[16]; - psDBF->panFieldDecimals[iField] = pabyFInfo[17]; - } - else - { - psDBF->panFieldSize[iField] = pabyFInfo[16] + pabyFInfo[17]*256; - psDBF->panFieldDecimals[iField] = 0; - } - - psDBF->pachFieldType[iField] = (char) pabyFInfo[11]; - if( iField == 0 ) - psDBF->panFieldOffset[iField] = 1; - else - psDBF->panFieldOffset[iField] = - psDBF->panFieldOffset[iField-1] + psDBF->panFieldSize[iField-1]; - } - - return( psDBF ); -} - -/************************************************************************/ -/* ossim_DBFClose() */ -/************************************************************************/ - -void ossim_SHPAPI_CALL - ossim_DBFClose(ossim_DBFHandle psDBF) -{ -/* -------------------------------------------------------------------- */ -/* Write out header if not already written. */ -/* -------------------------------------------------------------------- */ - if( psDBF->bNoHeader ) - ossim_DBFWriteHeader( psDBF ); - - ossim_DBFFlushRecord( psDBF ); - -/* -------------------------------------------------------------------- */ -/* Update last access date, and number of records if we have */ -/* write access. */ -/* -------------------------------------------------------------------- */ - if( psDBF->bUpdated ) - ossim_DBFUpdateHeader( psDBF ); - -/* -------------------------------------------------------------------- */ -/* Close, and free resources. */ -/* -------------------------------------------------------------------- */ - fclose( psDBF->fp ); - - if( psDBF->panFieldOffset != NULL ) - { - free( psDBF->panFieldOffset ); - free( psDBF->panFieldSize ); - free( psDBF->panFieldDecimals ); - free( psDBF->pachFieldType ); - } - - free( psDBF->pszHeader ); - free( psDBF->pszCurrentRecord ); - - free( psDBF ); -} - -/************************************************************************/ -/* ossim_DBFCreate() */ -/* */ -/* Create a new .dbf file. */ -/************************************************************************/ - -ossim_DBFHandle ossim_SHPAPI_CALL - ossim_DBFCreate( const char * pszFilename ) - -{ - ossim_DBFHandle psDBF; - FILE *fp; - char *pszFullname, *pszBasename; - int i; - -/* -------------------------------------------------------------------- */ -/* Compute the base (layer) name. If there is any extension */ -/* on the passed in filename we will strip it off. */ -/* -------------------------------------------------------------------- */ - pszBasename = (char *) malloc(strlen(pszFilename)+5); - strcpy( pszBasename, pszFilename ); - for( i = strlen(pszBasename)-1; - i > 0 && pszBasename[i] != '.' && pszBasename[i] != '/' - && pszBasename[i] != '\\'; - i-- ) {} - - if( pszBasename[i] == '.' ) - pszBasename[i] = '\0'; - - pszFullname = (char *) malloc(strlen(pszBasename) + 5); - sprintf( pszFullname, "%s.dbf", pszBasename ); - free( pszBasename ); - -/* -------------------------------------------------------------------- */ -/* Create the file. */ -/* -------------------------------------------------------------------- */ - fp = fopen( pszFullname, "wb" ); - if( fp == NULL ) - return( NULL ); - - fputc( 0, fp ); - fclose( fp ); - - fp = fopen( pszFullname, "rb+" ); - if( fp == NULL ) - return( NULL ); - - free( pszFullname ); - -/* -------------------------------------------------------------------- */ -/* Create the info structure. */ -/* -------------------------------------------------------------------- */ - psDBF = (ossim_DBFHandle) malloc(sizeof(ossim_DBFInfo)); - - psDBF->fp = fp; - psDBF->nRecords = 0; - psDBF->nFields = 0; - psDBF->nRecordLength = 1; - psDBF->nHeaderLength = 33; - - psDBF->panFieldOffset = NULL; - psDBF->panFieldSize = NULL; - psDBF->panFieldDecimals = NULL; - psDBF->pachFieldType = NULL; - psDBF->pszHeader = NULL; - - psDBF->nCurrentRecord = -1; - psDBF->bCurrentRecordModified = FALSE; - psDBF->pszCurrentRecord = NULL; - - psDBF->bNoHeader = TRUE; - - return( psDBF ); -} - -/************************************************************************/ -/* ossim_DBFAddField() */ -/* */ -/* Add a field to a newly created .dbf file before any records */ -/* are written. */ -/************************************************************************/ - -int ossim_SHPAPI_CALL - ossim_DBFAddField(ossim_DBFHandle psDBF, const char * pszFieldName, - ossim_DBFFieldType eType, int nWidth, int nDecimals ) - -{ - char *pszFInfo; - int i; - -/* -------------------------------------------------------------------- */ -/* Do some checking to ensure we can add records to this file. */ -/* -------------------------------------------------------------------- */ - if( psDBF->nRecords > 0 ) - return( -1 ); - - if( !psDBF->bNoHeader ) - return( -1 ); - - if( eType != FTDouble && nDecimals != 0 ) - return( -1 ); - - if( nWidth < 1 ) - return -1; - -/* -------------------------------------------------------------------- */ -/* SfRealloc all the arrays larger to hold the additional field */ -/* information. */ -/* -------------------------------------------------------------------- */ - psDBF->nFields++; - - psDBF->panFieldOffset = (int *) - SfRealloc( psDBF->panFieldOffset, sizeof(int) * psDBF->nFields ); - - psDBF->panFieldSize = (int *) - SfRealloc( psDBF->panFieldSize, sizeof(int) * psDBF->nFields ); - - psDBF->panFieldDecimals = (int *) - SfRealloc( psDBF->panFieldDecimals, sizeof(int) * psDBF->nFields ); - - psDBF->pachFieldType = (char *) - SfRealloc( psDBF->pachFieldType, sizeof(char) * psDBF->nFields ); - -/* -------------------------------------------------------------------- */ -/* Assign the new field information fields. */ -/* -------------------------------------------------------------------- */ - psDBF->panFieldOffset[psDBF->nFields-1] = psDBF->nRecordLength; - psDBF->nRecordLength += nWidth; - psDBF->panFieldSize[psDBF->nFields-1] = nWidth; - psDBF->panFieldDecimals[psDBF->nFields-1] = nDecimals; - - if( eType == FTLogical ) - psDBF->pachFieldType[psDBF->nFields-1] = 'L'; - else if( eType == FTString ) - psDBF->pachFieldType[psDBF->nFields-1] = 'C'; - else - psDBF->pachFieldType[psDBF->nFields-1] = 'N'; - -/* -------------------------------------------------------------------- */ -/* Extend the required header information. */ -/* -------------------------------------------------------------------- */ - psDBF->nHeaderLength += 32; - psDBF->bUpdated = FALSE; - - psDBF->pszHeader = (char *) SfRealloc(psDBF->pszHeader,psDBF->nFields*32); - - pszFInfo = psDBF->pszHeader + 32 * (psDBF->nFields-1); - - for( i = 0; i < 32; i++ ) - pszFInfo[i] = '\0'; - - if( (int) strlen(pszFieldName) < 10 ) - strncpy( pszFInfo, pszFieldName, strlen(pszFieldName)); - else - strncpy( pszFInfo, pszFieldName, 10); - - pszFInfo[11] = psDBF->pachFieldType[psDBF->nFields-1]; - - if( eType == FTString ) - { - pszFInfo[16] = (unsigned char) (nWidth % 256); - pszFInfo[17] = (unsigned char) (nWidth / 256); - } - else - { - pszFInfo[16] = (unsigned char) nWidth; - pszFInfo[17] = (unsigned char) nDecimals; - } - -/* -------------------------------------------------------------------- */ -/* Make the current record buffer appropriately larger. */ -/* -------------------------------------------------------------------- */ - psDBF->pszCurrentRecord = (char *) SfRealloc(psDBF->pszCurrentRecord, - psDBF->nRecordLength); - - return( psDBF->nFields-1 ); -} - -/************************************************************************/ -/* ossim_DBFReadAttribute() */ -/* */ -/* Read one of the attribute fields of a record. */ -/************************************************************************/ - -static void *ossim_DBFReadAttribute(ossim_DBFHandle psDBF, int hEntity, int iField, - char chReqType ) - -{ - int nRecordOffset; - unsigned char *pabyRec; - void *pReturnField = NULL; - - static double dDoubleField; - static char szStringField[257]; - -/* -------------------------------------------------------------------- */ -/* Verify selection. */ -/* -------------------------------------------------------------------- */ - if( hEntity < 0 || hEntity >= psDBF->nRecords ) - return( NULL ); - - if( iField < 0 || iField >= psDBF->nFields ) - return( NULL ); - -/* -------------------------------------------------------------------- */ -/* Have we read the record? */ -/* -------------------------------------------------------------------- */ - if( psDBF->nCurrentRecord != hEntity ) - { - ossim_DBFFlushRecord( psDBF ); - - nRecordOffset = psDBF->nRecordLength * hEntity + psDBF->nHeaderLength; - - if( fseek( psDBF->fp, nRecordOffset, 0 ) != 0 ) - { - fprintf( stderr, "fseek(%d) failed on ossim_DBF file.\n", - nRecordOffset ); - return NULL; - } - - if( fread( psDBF->pszCurrentRecord, psDBF->nRecordLength, - 1, psDBF->fp ) != 1 ) - { - fprintf( stderr, "fread(%d) failed on ossim_DBF file.\n", - psDBF->nRecordLength ); - return NULL; - } - - psDBF->nCurrentRecord = hEntity; - } - - pabyRec = (unsigned char *) psDBF->pszCurrentRecord; - -/* -------------------------------------------------------------------- */ -/* Extract the requested field. */ -/* -------------------------------------------------------------------- */ - strncpy( szStringField, - ((const char *) pabyRec) + psDBF->panFieldOffset[iField], - psDBF->panFieldSize[iField] ); - szStringField[psDBF->panFieldSize[iField]] = '\0'; - - pReturnField = szStringField; - -/* -------------------------------------------------------------------- */ -/* Decode the field. */ -/* -------------------------------------------------------------------- */ - if( chReqType == 'N' ) - { - dDoubleField = atof(szStringField); - - pReturnField = &dDoubleField; - } - -/* -------------------------------------------------------------------- */ -/* Should we trim white space off the string attribute value? */ -/* -------------------------------------------------------------------- */ -#ifdef TRIM_DBF_WHITESPACE - else - { - char *pchSrc, *pchDst; - - pchDst = pchSrc = szStringField; - while( *pchSrc == ' ' ) - pchSrc++; - - while( *pchSrc != '\0' ) - *(pchDst++) = *(pchSrc++); - *pchDst = '\0'; - - while( pchDst != szStringField && *(--pchDst) == ' ' ) - *pchDst = '\0'; - } -#endif - - return( pReturnField ); -} - -/************************************************************************/ -/* ossim_DBFReadIntAttribute() */ -/* */ -/* Read an integer attribute. */ -/************************************************************************/ - -int ossim_SHPAPI_CALL - ossim_DBFReadIntegerAttribute( ossim_DBFHandle psDBF, int iRecord, int iField ) - -{ - double *pdValue; - - pdValue = (double *) ossim_DBFReadAttribute( psDBF, iRecord, iField, 'N' ); - - if( pdValue == NULL ) - return 0; - else - return( (int) *pdValue ); -} - -/************************************************************************/ -/* ossim_DBFReadDoubleAttribute() */ -/* */ -/* Read a double attribute. */ -/************************************************************************/ - -double ossim_SHPAPI_CALL - ossim_DBFReadDoubleAttribute( ossim_DBFHandle psDBF, int iRecord, int iField ) - -{ - double *pdValue; - - pdValue = (double *) ossim_DBFReadAttribute( psDBF, iRecord, iField, 'N' ); - - if( pdValue == NULL ) - return 0.0; - else - return( *pdValue ); -} - -/************************************************************************/ -/* ossim_DBFReadStringAttribute() */ -/* */ -/* Read a string attribute. */ -/************************************************************************/ - -const char ossim_SHPAPI_CALL1(*) - ossim_DBFReadStringAttribute( ossim_DBFHandle psDBF, int iRecord, int iField ) - -{ - return( (const char *) ossim_DBFReadAttribute( psDBF, iRecord, iField, 'C' ) ); -} - -/************************************************************************/ -/* ossim_DBFReadLogicalAttribute() */ -/* */ -/* Read a logical attribute. */ -/************************************************************************/ - -const char ossim_SHPAPI_CALL1(*) - ossim_DBFReadLogicalAttribute( ossim_DBFHandle psDBF, int iRecord, int iField ) - -{ - return( (const char *) ossim_DBFReadAttribute( psDBF, iRecord, iField, 'L' ) ); -} - -/************************************************************************/ -/* ossim_DBFIsAttributeNULL() */ -/* */ -/* Return TRUE if value for field is NULL. */ -/* */ -/* Contributed by Jim Matthews. */ -/************************************************************************/ - -int ossim_SHPAPI_CALL - ossim_DBFIsAttributeNULL( ossim_DBFHandle psDBF, int iRecord, int iField ) - -{ - const char *pszValue; - int i; - - pszValue = ossim_DBFReadStringAttribute( psDBF, iRecord, iField ); - - if( pszValue == NULL ) - return TRUE; - - switch(psDBF->pachFieldType[iField]) - { - case 'N': - case 'F': - /* - ** We accept all asterisks or all blanks as NULL - ** though according to the spec I think it should be all - ** asterisks. - */ - if( pszValue[0] == '*' ) - return TRUE; - - for( i = 0; pszValue[i] != '\0'; i++ ) - { - if( pszValue[i] != ' ' ) - return FALSE; - } - return TRUE; - - case 'D': - /* NULL date fields have value "00000000" */ - return strncmp(pszValue,"00000000",8) == 0; - - case 'L': - /* NULL boolean fields have value "?" */ - return pszValue[0] == '?'; - - default: - /* empty string fields are considered NULL */ - return strlen(pszValue) == 0; - } -} - -/************************************************************************/ -/* ossim_DBFGetFieldCount() */ -/* */ -/* Return the number of fields in this table. */ -/************************************************************************/ - -int ossim_SHPAPI_CALL - ossim_DBFGetFieldCount( ossim_DBFHandle psDBF ) - -{ - return( psDBF->nFields ); -} - -/************************************************************************/ -/* ossim_DBFGetRecordCount() */ -/* */ -/* Return the number of records in this table. */ -/************************************************************************/ - -int ossim_SHPAPI_CALL - ossim_DBFGetRecordCount( ossim_DBFHandle psDBF ) - -{ - return( psDBF->nRecords ); -} - -/************************************************************************/ -/* ossim_DBFGetFieldInfo() */ -/* */ -/* Return any requested information about the field. */ -/************************************************************************/ - -ossim_DBFFieldType ossim_SHPAPI_CALL - ossim_DBFGetFieldInfo( ossim_DBFHandle psDBF, int iField, char * pszFieldName, - int * pnWidth, int * pnDecimals ) - -{ - if( iField < 0 || iField >= psDBF->nFields ) - return( FTInvalid ); - - if( pnWidth != NULL ) - *pnWidth = psDBF->panFieldSize[iField]; - - if( pnDecimals != NULL ) - *pnDecimals = psDBF->panFieldDecimals[iField]; - - if( pszFieldName != NULL ) - { - int i; - - strncpy( pszFieldName, (char *) psDBF->pszHeader+iField*32, 11 ); - pszFieldName[11] = '\0'; - for( i = 10; i > 0 && pszFieldName[i] == ' '; i-- ) - pszFieldName[i] = '\0'; - } - - if ( psDBF->pachFieldType[iField] == 'L' ) - return( FTLogical); - - else if( psDBF->pachFieldType[iField] == 'N' - || psDBF->pachFieldType[iField] == 'F' - || psDBF->pachFieldType[iField] == 'D' ) - { - if( psDBF->panFieldDecimals[iField] > 0 - || psDBF->panFieldSize[iField] > 10 ) - return( FTDouble ); - else - return( FTInteger ); - } - else - { - return( FTString ); - } -} - -/************************************************************************/ -/* ossim_DBFWriteAttribute() */ -/* */ -/* Write an attribute record to the file. */ -/************************************************************************/ - -static int ossim_DBFWriteAttribute(ossim_DBFHandle psDBF, int hEntity, int iField, - void * pValue ) - -{ - int nRecordOffset, i, j, nRetResult = TRUE; - unsigned char *pabyRec; - char szSField[400], szFormat[20]; - -/* -------------------------------------------------------------------- */ -/* Is this a valid record? */ -/* -------------------------------------------------------------------- */ - if( hEntity < 0 || hEntity > psDBF->nRecords ) - return( FALSE ); - - if( psDBF->bNoHeader ) - ossim_DBFWriteHeader(psDBF); - -/* -------------------------------------------------------------------- */ -/* Is this a brand new record? */ -/* -------------------------------------------------------------------- */ - if( hEntity == psDBF->nRecords ) - { - ossim_DBFFlushRecord( psDBF ); - - psDBF->nRecords++; - for( i = 0; i < psDBF->nRecordLength; i++ ) - psDBF->pszCurrentRecord[i] = ' '; - - psDBF->nCurrentRecord = hEntity; - } - -/* -------------------------------------------------------------------- */ -/* Is this an existing record, but different than the last one */ -/* we accessed? */ -/* -------------------------------------------------------------------- */ - if( psDBF->nCurrentRecord != hEntity ) - { - ossim_DBFFlushRecord( psDBF ); - - nRecordOffset = psDBF->nRecordLength * hEntity + psDBF->nHeaderLength; - - fseek( psDBF->fp, nRecordOffset, 0 ); - fread( psDBF->pszCurrentRecord, psDBF->nRecordLength, 1, psDBF->fp ); - - psDBF->nCurrentRecord = hEntity; - } - - pabyRec = (unsigned char *) psDBF->pszCurrentRecord; - - psDBF->bCurrentRecordModified = TRUE; - psDBF->bUpdated = TRUE; - -/* -------------------------------------------------------------------- */ -/* Translate NULL value to valid ossim_DBF file representation. */ -/* */ -/* Contributed by Jim Matthews. */ -/* -------------------------------------------------------------------- */ - if( pValue == NULL ) - { - switch(psDBF->pachFieldType[iField]) - { - case 'N': - case 'F': - /* NULL numeric fields have value "****************" */ - memset( (char *) (pabyRec+psDBF->panFieldOffset[iField]), '*', - psDBF->panFieldSize[iField] ); - break; - - case 'D': - /* NULL date fields have value "00000000" */ - memset( (char *) (pabyRec+psDBF->panFieldOffset[iField]), '0', - psDBF->panFieldSize[iField] ); - break; - - case 'L': - /* NULL boolean fields have value "?" */ - memset( (char *) (pabyRec+psDBF->panFieldOffset[iField]), '?', - psDBF->panFieldSize[iField] ); - break; - - default: - /* empty string fields are considered NULL */ - memset( (char *) (pabyRec+psDBF->panFieldOffset[iField]), '\0', - psDBF->panFieldSize[iField] ); - break; - } - return TRUE; - } - -/* -------------------------------------------------------------------- */ -/* Assign all the record fields. */ -/* -------------------------------------------------------------------- */ - switch( psDBF->pachFieldType[iField] ) - { - case 'D': - case 'N': - case 'F': - if( psDBF->panFieldDecimals[iField] == 0 ) - { - int nWidth = psDBF->panFieldSize[iField]; - - if( (int) sizeof(szSField)-2 < nWidth ) - nWidth = sizeof(szSField)-2; - - sprintf( szFormat, "%%%dd", nWidth ); - sprintf(szSField, szFormat, (int) *((double *) pValue) ); - if( (int)strlen(szSField) > psDBF->panFieldSize[iField] ) - { - szSField[psDBF->panFieldSize[iField]] = '\0'; - nRetResult = FALSE; - } - - strncpy((char *) (pabyRec+psDBF->panFieldOffset[iField]), - szSField, strlen(szSField) ); - } - else - { - int nWidth = psDBF->panFieldSize[iField]; - - if( (int) sizeof(szSField)-2 < nWidth ) - nWidth = sizeof(szSField)-2; - - sprintf( szFormat, "%%%d.%df", - nWidth, psDBF->panFieldDecimals[iField] ); - sprintf(szSField, szFormat, *((double *) pValue) ); - if( (int) strlen(szSField) > psDBF->panFieldSize[iField] ) - { - szSField[psDBF->panFieldSize[iField]] = '\0'; - nRetResult = FALSE; - } - strncpy((char *) (pabyRec+psDBF->panFieldOffset[iField]), - szSField, strlen(szSField) ); - } - break; - - case 'L': - if (psDBF->panFieldSize[iField] >= 1 && - (*(char*)pValue == 'F' || *(char*)pValue == 'T')) - *(pabyRec+psDBF->panFieldOffset[iField]) = *(char*)pValue; - break; - - default: - if( (int) strlen((char *) pValue) > psDBF->panFieldSize[iField] ) - { - j = psDBF->panFieldSize[iField]; - nRetResult = FALSE; - } - else - { - memset( pabyRec+psDBF->panFieldOffset[iField], ' ', - psDBF->panFieldSize[iField] ); - j = strlen((char *) pValue); - } - - strncpy((char *) (pabyRec+psDBF->panFieldOffset[iField]), - (char *) pValue, j ); - break; - } - - return( nRetResult ); -} - -/************************************************************************/ -/* ossim_DBFWriteAttributeDirectly() */ -/* */ -/* Write an attribute record to the file, but without any */ -/* reformatting based on type. The provided buffer is written */ -/* as is to the field position in the record. */ -/************************************************************************/ - -int ossim_SHPAPI_CALL - ossim_DBFWriteAttributeDirectly(ossim_DBFHandle psDBF, int hEntity, int iField, - void * pValue ) - -{ - int nRecordOffset, i, j; - unsigned char *pabyRec; - -/* -------------------------------------------------------------------- */ -/* Is this a valid record? */ -/* -------------------------------------------------------------------- */ - if( hEntity < 0 || hEntity > psDBF->nRecords ) - return( FALSE ); - - if( psDBF->bNoHeader ) - ossim_DBFWriteHeader(psDBF); - -/* -------------------------------------------------------------------- */ -/* Is this a brand new record? */ -/* -------------------------------------------------------------------- */ - if( hEntity == psDBF->nRecords ) - { - ossim_DBFFlushRecord( psDBF ); - - psDBF->nRecords++; - for( i = 0; i < psDBF->nRecordLength; i++ ) - psDBF->pszCurrentRecord[i] = ' '; - - psDBF->nCurrentRecord = hEntity; - } - -/* -------------------------------------------------------------------- */ -/* Is this an existing record, but different than the last one */ -/* we accessed? */ -/* -------------------------------------------------------------------- */ - if( psDBF->nCurrentRecord != hEntity ) - { - ossim_DBFFlushRecord( psDBF ); - - nRecordOffset = psDBF->nRecordLength * hEntity + psDBF->nHeaderLength; - - fseek( psDBF->fp, nRecordOffset, 0 ); - fread( psDBF->pszCurrentRecord, psDBF->nRecordLength, 1, psDBF->fp ); - - psDBF->nCurrentRecord = hEntity; - } - - pabyRec = (unsigned char *) psDBF->pszCurrentRecord; - -/* -------------------------------------------------------------------- */ -/* Assign all the record fields. */ -/* -------------------------------------------------------------------- */ - if( (int)strlen((char *) pValue) > psDBF->panFieldSize[iField] ) - j = psDBF->panFieldSize[iField]; - else - { - memset( pabyRec+psDBF->panFieldOffset[iField], ' ', - psDBF->panFieldSize[iField] ); - j = strlen((char *) pValue); - } - - strncpy((char *) (pabyRec+psDBF->panFieldOffset[iField]), - (char *) pValue, j ); - - psDBF->bCurrentRecordModified = TRUE; - psDBF->bUpdated = TRUE; - - return( TRUE ); -} - -/************************************************************************/ -/* ossim_DBFWriteDoubleAttribute() */ -/* */ -/* Write a double attribute. */ -/************************************************************************/ - -int ossim_SHPAPI_CALL - ossim_DBFWriteDoubleAttribute( ossim_DBFHandle psDBF, int iRecord, int iField, - double dValue ) - -{ - return( ossim_DBFWriteAttribute( psDBF, iRecord, iField, (void *) &dValue ) ); -} - -/************************************************************************/ -/* ossim_DBFWriteIntegerAttribute() */ -/* */ -/* Write a integer attribute. */ -/************************************************************************/ - -int ossim_SHPAPI_CALL - ossim_DBFWriteIntegerAttribute( ossim_DBFHandle psDBF, int iRecord, int iField, - int nValue ) - -{ - double dValue = nValue; - - return( ossim_DBFWriteAttribute( psDBF, iRecord, iField, (void *) &dValue ) ); -} - -/************************************************************************/ -/* ossim_DBFWriteStringAttribute() */ -/* */ -/* Write a string attribute. */ -/************************************************************************/ - -int ossim_SHPAPI_CALL - ossim_DBFWriteStringAttribute( ossim_DBFHandle psDBF, int iRecord, int iField, - const char * pszValue ) - -{ - return( ossim_DBFWriteAttribute( psDBF, iRecord, iField, (void *) pszValue ) ); -} - -/************************************************************************/ -/* ossim_DBFWriteNULLAttribute() */ -/* */ -/* Write a string attribute. */ -/************************************************************************/ - -int ossim_SHPAPI_CALL - ossim_DBFWriteNULLAttribute( ossim_DBFHandle psDBF, int iRecord, int iField ) - -{ - return( ossim_DBFWriteAttribute( psDBF, iRecord, iField, NULL ) ); -} - -/************************************************************************/ -/* ossim_DBFWriteLogicalAttribute() */ -/* */ -/* Write a logical attribute. */ -/************************************************************************/ - -int ossim_SHPAPI_CALL - ossim_DBFWriteLogicalAttribute( ossim_DBFHandle psDBF, int iRecord, int iField, - const char lValue) - -{ - return( ossim_DBFWriteAttribute( psDBF, iRecord, iField, (void *) (&lValue) ) ); -} - -/************************************************************************/ -/* ossim_DBFWriteTuple() */ -/* */ -/* Write an attribute record to the file. */ -/************************************************************************/ - -int ossim_SHPAPI_CALL - ossim_DBFWriteTuple(ossim_DBFHandle psDBF, int hEntity, void * pRawTuple ) - -{ - int nRecordOffset, i; - unsigned char *pabyRec; - -/* -------------------------------------------------------------------- */ -/* Is this a valid record? */ -/* -------------------------------------------------------------------- */ - if( hEntity < 0 || hEntity > psDBF->nRecords ) - return( FALSE ); - - if( psDBF->bNoHeader ) - ossim_DBFWriteHeader(psDBF); - -/* -------------------------------------------------------------------- */ -/* Is this a brand new record? */ -/* -------------------------------------------------------------------- */ - if( hEntity == psDBF->nRecords ) - { - ossim_DBFFlushRecord( psDBF ); - - psDBF->nRecords++; - for( i = 0; i < psDBF->nRecordLength; i++ ) - psDBF->pszCurrentRecord[i] = ' '; - - psDBF->nCurrentRecord = hEntity; - } - -/* -------------------------------------------------------------------- */ -/* Is this an existing record, but different than the last one */ -/* we accessed? */ -/* -------------------------------------------------------------------- */ - if( psDBF->nCurrentRecord != hEntity ) - { - ossim_DBFFlushRecord( psDBF ); - - nRecordOffset = psDBF->nRecordLength * hEntity + psDBF->nHeaderLength; - - fseek( psDBF->fp, nRecordOffset, 0 ); - fread( psDBF->pszCurrentRecord, psDBF->nRecordLength, 1, psDBF->fp ); - - psDBF->nCurrentRecord = hEntity; - } - - pabyRec = (unsigned char *) psDBF->pszCurrentRecord; - - memcpy ( pabyRec, pRawTuple, psDBF->nRecordLength ); - - psDBF->bCurrentRecordModified = TRUE; - psDBF->bUpdated = TRUE; - - return( TRUE ); -} - -/************************************************************************/ -/* ossim_DBFReadTuple() */ -/* */ -/* Read one of the attribute fields of a record. */ -/************************************************************************/ - -const char ossim_SHPAPI_CALL1(*) - ossim_DBFReadTuple(ossim_DBFHandle psDBF, int hEntity ) - -{ - int nRecordOffset; - unsigned char *pabyRec; - static char *pReturnTuple = NULL; - - static int nTupleLen = 0; - -/* -------------------------------------------------------------------- */ -/* Have we read the record? */ -/* -------------------------------------------------------------------- */ - if( hEntity < 0 || hEntity >= psDBF->nRecords ) - return( NULL ); - - if( psDBF->nCurrentRecord != hEntity ) - { - ossim_DBFFlushRecord( psDBF ); - - nRecordOffset = psDBF->nRecordLength * hEntity + psDBF->nHeaderLength; - - fseek( psDBF->fp, nRecordOffset, 0 ); - fread( psDBF->pszCurrentRecord, psDBF->nRecordLength, 1, psDBF->fp ); - - psDBF->nCurrentRecord = hEntity; - } - - pabyRec = (unsigned char *) psDBF->pszCurrentRecord; - - if ( nTupleLen < psDBF->nRecordLength) { - nTupleLen = psDBF->nRecordLength; - pReturnTuple = (char *) SfRealloc(pReturnTuple, psDBF->nRecordLength); - } - - memcpy ( pReturnTuple, pabyRec, psDBF->nRecordLength ); - - return( pReturnTuple ); -} - -/************************************************************************/ -/* ossim_DBFCloneEmpty() */ -/* */ -/* Read one of the attribute fields of a record. */ -/************************************************************************/ - -ossim_DBFHandle ossim_SHPAPI_CALL - ossim_DBFCloneEmpty(ossim_DBFHandle psDBF, const char * pszFilename ) -{ - ossim_DBFHandle newDBF; - - newDBF = ossim_DBFCreate ( pszFilename ); - if ( newDBF == NULL ) return ( NULL ); - - newDBF->nFields = psDBF->nFields; - newDBF->nRecordLength = psDBF->nRecordLength; - newDBF->nHeaderLength = psDBF->nHeaderLength; - - newDBF->pszHeader = (char *) malloc ( newDBF->nHeaderLength ); - memcpy ( newDBF->pszHeader, psDBF->pszHeader, newDBF->nHeaderLength ); - - newDBF->panFieldOffset = (int *) malloc ( sizeof(int) * psDBF->nFields ); - memcpy ( newDBF->panFieldOffset, psDBF->panFieldOffset, sizeof(int) * psDBF->nFields ); - newDBF->panFieldSize = (int *) malloc ( sizeof(int) * psDBF->nFields ); - memcpy ( newDBF->panFieldSize, psDBF->panFieldSize, sizeof(int) * psDBF->nFields ); - newDBF->panFieldDecimals = (int *) malloc ( sizeof(int) * psDBF->nFields ); - memcpy ( newDBF->panFieldDecimals, psDBF->panFieldDecimals, sizeof(int) * psDBF->nFields ); - newDBF->pachFieldType = (char *) malloc ( sizeof(int) * psDBF->nFields ); - memcpy ( newDBF->pachFieldType, psDBF->pachFieldType, sizeof(int) * psDBF->nFields ); - - newDBF->bNoHeader = TRUE; - newDBF->bUpdated = TRUE; - - ossim_DBFWriteHeader ( newDBF ); - ossim_DBFClose ( newDBF ); - - newDBF = ossim_DBFOpen ( pszFilename, "rb+" ); - - return ( newDBF ); -} - -/************************************************************************/ -/* ossim_DBFGetNativeFieldType() */ -/* */ -/* Return the DBase field type for the specified field. */ -/* */ -/* Value can be one of: 'C' (String), 'D' (Date), 'F' (Float), */ -/* 'N' (Numeric, with or without decimal), */ -/* 'L' (Logical), */ -/* 'M' (Memo: 10 digits .DBT block ptr) */ -/************************************************************************/ - -char ossim_SHPAPI_CALL - ossim_DBFGetNativeFieldType( ossim_DBFHandle psDBF, int iField ) - -{ - if( iField >=0 && iField < psDBF->nFields ) - return psDBF->pachFieldType[iField]; - - return ' '; -} - -/************************************************************************/ -/* str_to_upper() */ -/************************************************************************/ - -static void str_to_upper (char *string) -{ - int len; - short i = -1; - - len = strlen (string); - - while (++i < len) - if (isalpha(string[i]) && islower(string[i])) - string[i] = (char) toupper ((int)string[i]); -} - -/************************************************************************/ -/* ossim_DBFGetFieldIndex() */ -/* */ -/* Get the index number for a field in a .dbf file. */ -/* */ -/* Contributed by Jim Matthews. */ -/************************************************************************/ - -int ossim_SHPAPI_CALL - ossim_DBFGetFieldIndex(ossim_DBFHandle psDBF, const char *pszFieldName) - -{ - char name[12], name1[12], name2[12]; - int i; - - strncpy(name1, pszFieldName,11); - name1[11] = '\0'; - str_to_upper(name1); - - for( i = 0; i < ossim_DBFGetFieldCount(psDBF); i++ ) - { - ossim_DBFGetFieldInfo( psDBF, i, name, NULL, NULL ); - strncpy(name2,name,11); - str_to_upper(name2); - - if(!strncmp(name1,name2,10)) - return(i); - } - return(-1); -} diff --git a/Utilities/otbossim/src/ossim/vec/ossimShapeDatabase.cpp b/Utilities/otbossim/src/ossim/vec/ossimShapeDatabase.cpp deleted file mode 100644 index 5ed5a2831d..0000000000 --- a/Utilities/otbossim/src/ossim/vec/ossimShapeDatabase.cpp +++ /dev/null @@ -1,268 +0,0 @@ - -#include <iomanip> - -#include <ossim/vec/ossimShapeDatabase.h> -#include <ossim/vec/ossimShapeFile.h> - - - -ossimString ossimShapeDatabaseField::fieldTypeAsString()const -{ - switch(theFieldType) - { - case FTString: - { - return "String"; - } - case FTInteger: - { - return "Integer"; - } - case FTDouble: - { - return "Double"; - } - default: - { - return "Unknown"; - } - }; - - return ""; - -} - - -ossim_int32 ossimShapeDatabaseRecord::getFieldIdx(const ossimString& name, - bool caseInsensitive)const -{ - ossimString searchString = name; - if(caseInsensitive) searchString = searchString.downcase(); - ossim_int32 idx = 0; - for(idx = 0; idx < (int)theFieldArray.size(); ++idx) - { - if(caseInsensitive) - { - if(ossimString(theFieldArray[idx].theName).downcase() == searchString) - { - return idx; - } - } - else - { - if(theFieldArray[idx].theName == searchString) - { - return idx; - } - } - } - return -1; -} - -ossimShapeDatabase::ossimShapeDatabase() - :theHandle(NULL), - theFilename("") -{ - theRecordNumber = -1; -} - -ossimShapeDatabase::~ossimShapeDatabase() -{ - close(); -} - -bool ossimShapeDatabase::open(const ossimFilename& file, - const ossimString& flags) -{ - if(isOpen()) close(); - - theHandle = ossim_DBFOpen(file.c_str(), flags.c_str()); - if(theHandle) - { - theFilename = file; - theRecordNumber = -1; - } - - return (theHandle != NULL); -} - -void ossimShapeDatabase::close() -{ - if(isOpen()) - { - ossim_DBFClose(theHandle); - theHandle = NULL; - theRecordNumber = -1; - } -} -int ossimShapeDatabase::getNumberOfRecords()const -{ - if(isOpen()) - { - return theHandle->nRecords; - } - - return 0; -} -bool ossimShapeDatabase::getRecord(ossimShapeDatabaseRecord& result) -{ - if(isOpen()&&( (theRecordNumber < theHandle->nRecords) )) - { - if(result.getNumberOfFields() != theHandle->nFields) - { - result.setNumberOfFields(theHandle->nFields); - } - - char name[1024] = {'\0'}; - int width = 0; - int decimals = 0; - int iField = 0; - std::vector<int> fieldWidths; - - for(iField = 0; iField < theHandle->nFields; ++iField) - { - ossim_DBFFieldType fieldType = ossim_DBFGetFieldInfo(theHandle, - iField, - name, - &width, - &decimals); - ossimShapeDatabaseField field; - field.theName = name; - field.theWidth = width; - field.theDecimals = decimals; - field.theFieldType = fieldType; - - ossimString key = "field"; - key+=ossimString::toString(iField+1); - key+=(ossimString(".")+name+":"); - - switch(fieldType) - { - case FTString: - { - field.theValue = ossim_DBFReadStringAttribute(theHandle, theRecordNumber, iField); - break; - } - case FTInteger: - { - field.theValue = ossimString::toString(ossim_DBFReadIntegerAttribute(theHandle, theRecordNumber, iField)); - break; - } - case FTDouble: - { - field.theValue = ossimString::toString(ossim_DBFReadDoubleAttribute(theHandle, theRecordNumber, iField)); - break; - } - case FTLogical: - { - break; - } - case FTInvalid: - { - break; - } - } - - result.setField(field, - iField); - } - return true; - } - - return false; -} - -void ossimShapeDatabase::print(std::ostream& out)const -{ - if(isOpen()) - { - out << std::setw(15)<<setiosflags(std::ios::left) - <<"DB filename:" << theFilename << std::endl - << std::setw(15)<<setiosflags(std::ios::left) - <<"records:" << theHandle->nRecords << std::endl - << std::setw(15)<<setiosflags(std::ios::left) - <<"fields:" << theHandle->nFields << std::endl; - - char name[1024] = {'\0'}; - int width = 0; - int decimals = 0; - int iField = 0; - std::vector<int> fieldWidths; - - - for(iField = 0; iField < theHandle->nFields; ++iField) - { - ossim_DBFFieldType fieldType = ossim_DBFGetFieldInfo(theHandle, - iField, - name, - &width, - &decimals); - ossimString s = "field " + ossimString::toString(iField+1) + " name:"; - switch(fieldType) - { - case FTString: - case FTInteger: - case FTDouble: - { - out << std::setw(15) << setiosflags(std::ios::left) << s.c_str() << name << std::endl; - break; - } - default: - { - out << std::setw(15) << setiosflags(std::ios::left) << s.c_str() << "INVALID"<<std::endl; - break; - } - } - } - for(int iShape = 0; iShape < theHandle->nRecords; ++iShape) - { - for(iField = 0; iField < theHandle->nFields; ++iField) - { - ossim_DBFFieldType fieldType = ossim_DBFGetFieldInfo(theHandle, - iField, - name, - &width, - &decimals); - - ossimString key = "field"; - key+=ossimString::toString(iField+1); - key+=(ossimString(".")+name+":"); - - switch(fieldType) - { - case FTString: - { - - out << std::setw(25) << setiosflags(std::ios::left) << key.c_str() - << ossim_DBFReadStringAttribute(theHandle, iShape, iField) <<std::endl; - - break; - } - case FTInteger: - { - out << std::setw(25) << setiosflags(std::ios::left) << key.c_str() - << ossim_DBFReadIntegerAttribute(theHandle, iShape, iField) << std::endl; - - break; - } - case FTDouble: - { - out << std::setw(25) << setiosflags(std::ios::left) << key.c_str() - << ossim_DBFReadDoubleAttribute(theHandle, iShape, iField) << std::endl; - - break; - } - case FTLogical: - { - break; - } - case FTInvalid: - { - break; - } - } - } - out << "_________________________________"<<std::endl; - } - } -} diff --git a/Utilities/otbossim/src/ossim/vec/ossimShapeFile.cpp b/Utilities/otbossim/src/ossim/vec/ossimShapeFile.cpp deleted file mode 100644 index 2b15932ea2..0000000000 --- a/Utilities/otbossim/src/ossim/vec/ossimShapeFile.cpp +++ /dev/null @@ -1,220 +0,0 @@ -//******************************************************************* -// License: See top level LICENSE.txt file. -// -// Author: Garrett Potts -// -// Description: This class extends the stl's string class. -// -//******************************************************************** -// $Id: ossimShapeFile.cpp 9963 2006-11-28 21:11:01Z gpotts $ -// - -#include <iomanip> -#include <ossim/vec/ossimShapeFile.h> - - - -std::ostream& operator<<(std::ostream& out, - const ossimShapeObject& rhs) -{ - if(rhs.isLoaded()) - { - double minx, miny, minz, minm; - double maxx, maxy, maxz, maxm; - ossim_uint32 i = 0; - - rhs.getBounds(minx, miny, minz, minm, - maxx, maxy, maxz, maxm); - - out << std::setw(15) << setiosflags(std::ios::left)<<"type:"<<rhs.getTypeByName() << std::endl - << std::setw(15) << setiosflags(std::ios::left)<<"id:"<<rhs.getId()<<std::endl - << std::setw(15) << setiosflags(std::ios::left)<<"minx:"<<minx <<std::endl - << std::setw(15) << setiosflags(std::ios::left)<<"miny:"<<miny <<std::endl - << std::setw(15) << setiosflags(std::ios::left)<<"minz:"<<minz <<std::endl - << std::setw(15) << setiosflags(std::ios::left)<<"minm:"<<minm <<std::endl - << std::setw(15) << setiosflags(std::ios::left)<<"maxx:"<<maxx <<std::endl - << std::setw(15) << setiosflags(std::ios::left)<<"maxy:"<<maxy <<std::endl - << std::setw(15) << setiosflags(std::ios::left)<<"maxz:"<<maxz <<std::endl - << std::setw(15) << setiosflags(std::ios::left)<<"maxm:"<<maxm <<std::endl - << std::setw(15) << setiosflags(std::ios::left)<<"parts:"<<rhs.getNumberOfParts()<<std::endl - << std::setw(15) << setiosflags(std::ios::left)<<"vertices:"<<rhs.getNumberOfVertices(); - - if(rhs.getNumberOfParts()) - { - out << std::endl; - for(i = 0; i < rhs.getNumberOfParts()-1; ++i) - { - ossimString s1 = "part start "; - ossimString s2 = "part type "; - s1 += (ossimString::toString(i+1)+":"); - s2 += (ossimString::toString(i+1)+":"); - - out << std::setw(15) << setiosflags(std::ios::left) << s1.c_str() << rhs.theShape->panPartStart[i]<<std::endl; - out << std::setw(15) << setiosflags(std::ios::left) << s2.c_str() << ossim_SHPPartTypeName(rhs.theShape->panPartType[i])<<std::endl; - } - ossimString s1 = "part start "; - ossimString s2 = "part type "; - - s1 += (ossimString::toString(rhs.getNumberOfParts())+":"); - out << std::setw(15) << setiosflags(std::ios::left) << s1.c_str() << rhs.theShape->panPartStart[i]<<std::endl; - out << std::setw(15) << setiosflags(std::ios::left) << s2.c_str() << ossim_SHPPartTypeName(rhs.theShape->panPartType[i]); - } - - out << std::setw(0); - - } - return out; -} - -void ossimShapeObject::getBoundingRect(ossimDrect& result, - ossimCoordSysOrientMode orient)const -{ - double minx, miny, maxx, maxy; - - if(theShape) - { - getBounds(minx, miny, maxx, maxy); - - if(orient == OSSIM_RIGHT_HANDED) - { - result = ossimDrect(minx, maxy, maxx, miny, orient); - } - else - { - result = ossimDrect(minx, miny, maxx, maxy, orient); - } - } - else - { - result = ossimDrect(0,0,0,0,orient); - result.makeNan(); - } -} - -void ossimShapeObject::setShape(ossim_SHPObject* obj) -{ - if(theShape) - { - ossim_SHPDestroyObject(theShape); - theShape = NULL; - } - - theShape = obj; -} - -bool ossimShapeObject::loadShape(const ossimShapeFile& shapeFile, - long shapeRecord) -{ - if(theShape) - { - ossim_SHPDestroyObject(theShape); - theShape = NULL; - } - if(shapeFile.isOpen()) - { - theShape = ossim_SHPReadObject(shapeFile.getHandle(), - shapeRecord); - theIndex = shapeRecord; - } - else - { - theIndex = -1; - } - return (theShape != (ossim_SHPObject*)NULL); -} - - -ossimShapeFile::ossimShapeFile() - :theHandle(NULL) -{ -} - -ossimShapeFile::~ossimShapeFile() -{ - close(); -} - -void ossimShapeFile::close() -{ - if(theHandle) - { - ossim_SHPClose(theHandle); - theHandle = NULL; - } -} - -bool ossimShapeFile::open(const ossimFilename& file, - const ossimString& flags) -{ - if(isOpen()) close(); - - theHandle = ossim_SHPOpen( file.c_str(), - flags.c_str()); - if(isOpen()) - { - theFilename = file; - } - - return (theHandle != NULL); -} - - - -void ossimShapeFile::print(std::ostream& out)const -{ - if(isOpen()) - { - out << std::setw(15) << setiosflags(std::ios::left)<<"Shp filename:" << theFilename << std::endl; - out << std::setw(15) << setiosflags(std::ios::left)<<"Record count:" << theHandle->nRecords << std::endl; - out << std::setw(15) << setiosflags(std::ios::left)<<"File type:" << getShapeTypeString().c_str() << std::endl; - out << std::setw(15) << setiosflags(std::ios::left)<<"minx:" << theHandle->adBoundsMin[0] << std::endl; - out << std::setw(15) << setiosflags(std::ios::left)<<"miny:" << theHandle->adBoundsMin[1] << std::endl; - out << std::setw(15) << setiosflags(std::ios::left)<<"minz:" << theHandle->adBoundsMin[2] << std::endl; - out << std::setw(15) << setiosflags(std::ios::left)<<"minm:" << theHandle->adBoundsMin[3] << std::endl; - out << std::setw(15) << setiosflags(std::ios::left)<<"maxx:" << theHandle->adBoundsMax[0] << std::endl; - out << std::setw(15) << setiosflags(std::ios::left)<<"maxy:" << theHandle->adBoundsMax[1] << std::endl; - out << std::setw(15) << setiosflags(std::ios::left)<<"maxz:" << theHandle->adBoundsMax[2] << std::endl; - out << std::setw(15) << setiosflags(std::ios::left)<<"maxm:" << theHandle->adBoundsMax[3] << std::endl; - - ossimShapeObject shape; - - if(theHandle->nRecords) - { - out << std::setw(30) << std::setfill('_') << "" << std::setfill(' ')<<std::endl; - } - for(int i=0; i < theHandle->nRecords; ++i) - { - if(shape.loadShape(*this, i)) - { - out << shape << std::endl; - out << std::setw(30) << std::setfill('_') << ""<<std::setfill(' ')<<std::endl; - } - } - } -} - - -ossimString ossimShapeFile::getShapeTypeString()const -{ - if(theHandle) - { - return ossim_SHPTypeName(theHandle->nShapeType); - } - return ""; -} - -void ossimShapeFile::getBoundingRect(ossimDrect& result, - ossimCoordSysOrientMode orient)const -{ - double minx, miny, maxx, maxy; - - getBounds(minx, miny, maxx, maxy); - if(orient == OSSIM_RIGHT_HANDED) - { - result = ossimDrect(minx, maxy, maxx, miny, orient); - } - else - { - result = ossimDrect(minx, miny, maxx, maxy, orient); - } -} diff --git a/Utilities/otbossim/src/ossim/vec/shpopen.c b/Utilities/otbossim/src/ossim/vec/shpopen.c deleted file mode 100644 index a8aa5a1e10..0000000000 --- a/Utilities/otbossim/src/ossim/vec/shpopen.c +++ /dev/null @@ -1,2021 +0,0 @@ -/****************************************************************************** - * $Id: shpopen.c 9094 2006-06-13 19:12:40Z dburken $ - * - * Project: Shapelib - * Purpose: Implementation of core Shapefile read/write functions. - * Author: Frank Warmerdam, warmerdam@pobox.com - * - ****************************************************************************** - * Copyright (c) 1999, 2001, Frank Warmerdam - * - * This software is available under the following "MIT Style" license, - * or at the option of the licensee under the LGPL (see LICENSE.LGPL). This - * option is discussed in more detail in shapelib.html. - * - * -- - * - * 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. - ****************************************************************************** - * - * $Log$ - * Revision 1.6 2006/06/13 19:11:33 dburken - * Global include path change. - * - * Revision 1.5 2005/10/08 12:57:26 gpotts - * Added adiitional patches - * - * Revision 1.46 2005/02/11 17:17:46 fwarmerdam - * added panPartStart[0] validation - * - * Revision 1.45 2004/09/26 20:09:48 fwarmerdam - * const correctness changes - * - * Revision 1.44 2003/12/29 00:18:39 fwarmerdam - * added error checking for failed IO and optional CPL error reporting - * - * Revision 1.43 2003/12/01 16:20:08 warmerda - * be careful of zero vertex shapes - * - * Revision 1.42 2003/12/01 14:58:27 warmerda - * added degenerate object check in ossim_SHPRewindObject() - * - * Revision 1.41 2003/07/08 15:22:43 warmerda - * avoid warning - * - * Revision 1.40 2003/04/21 18:30:37 warmerda - * added header write/update public methods - * - * Revision 1.39 2002/08/26 06:46:56 warmerda - * avoid c++ comments - * - * Revision 1.38 2002/05/07 16:43:39 warmerda - * Removed debugging printf. - * - * Revision 1.37 2002/04/10 17:35:22 warmerda - * fixed bug in ring reversal code - * - * Revision 1.36 2002/04/10 16:59:54 warmerda - * added ossim_SHPRewindObject - * - * Revision 1.35 2001/12/07 15:10:44 warmerda - * fix if .shx fails to open - * - * Revision 1.34 2001/11/01 16:29:55 warmerda - * move pabyRec into ossim_SHPInfo for thread safety - * - * Revision 1.33 2001/07/03 12:18:15 warmerda - * Improved cleanup if SHX not found, provied by Riccardo Cohen. - * - * Revision 1.32 2001/06/22 01:58:07 warmerda - * be more careful about establishing initial bounds in face of NULL shapes - * - * Revision 1.31 2001/05/31 19:35:29 warmerda - * added support for writing null shapes - * - * Revision 1.30 2001/05/28 12:46:29 warmerda - * Add some checking on reasonableness of record count when opening. - * - * Revision 1.29 2001/05/23 13:36:52 warmerda - * added use of ossim_SHPAPI_CALL - * - * Revision 1.28 2001/02/06 22:25:06 warmerda - * fixed memory leaks when ossim_SHPOpen() fails - * - * Revision 1.27 2000/07/18 15:21:33 warmerda - * added better enforcement of -1 for append in ossim_SHPWriteObject - * - * Revision 1.26 2000/02/16 16:03:51 warmerda - * added null shape support - * - * Revision 1.25 1999/12/15 13:47:07 warmerda - * Fixed record size settings in .shp file (was 4 words too long) - * Added stdlib.h. - * - * Revision 1.24 1999/11/05 14:12:04 warmerda - * updated license terms - * - * Revision 1.23 1999/07/27 00:53:46 warmerda - * added support for rewriting shapes - * - * Revision 1.22 1999/06/11 19:19:11 warmerda - * Cleanup pabyRec static buffer on ossim_SHPClose(). - * - * Revision 1.21 1999/06/02 14:57:56 kshih - * Remove unused variables - * - * Revision 1.20 1999/04/19 21:04:17 warmerda - * Fixed syntax error. - * - * Revision 1.19 1999/04/19 21:01:57 warmerda - * Force access string to binary in ossim_SHPOpen(). - * - * Revision 1.18 1999/04/01 18:48:07 warmerda - * Try upper case extensions if lower case doesn't work. - * - * Revision 1.17 1998/12/31 15:29:39 warmerda - * Disable writing measure values to multipatch objects if - * DISABLE_MULTIPATCH_MEASURE is defined. - * - * Revision 1.16 1998/12/16 05:14:33 warmerda - * Added support to write MULTIPATCH. Fixed reading Z coordinate of - * MULTIPATCH. Fixed record size written for all feature types. - * - * Revision 1.15 1998/12/03 16:35:29 warmerda - * r+b is proper binary access string, not rb+. - * - * Revision 1.14 1998/12/03 15:47:56 warmerda - * Fixed setting of nVertices in ossim_SHPCreateObject(). - * - * Revision 1.13 1998/12/03 15:33:54 warmerda - * Made ossim_SHPCalculateExtents() separately callable. - * - * Revision 1.12 1998/11/11 20:01:50 warmerda - * Fixed bug writing ArcM/Z, and PolygonM/Z for big endian machines. - * - * Revision 1.11 1998/11/09 20:56:44 warmerda - * Fixed up handling of file wide bounds. - * - * Revision 1.10 1998/11/09 20:18:51 warmerda - * Converted to support 3D shapefiles, and use of ossim_SHPObject. - * - * Revision 1.9 1998/02/24 15:09:05 warmerda - * Fixed memory leak. - * - * Revision 1.8 1997/12/04 15:40:29 warmerda - * Fixed byte swapping of record number, and record length fields in the - * .shp file. - * - * Revision 1.7 1995/10/21 03:15:58 warmerda - * Added support for binary file access, the magic cookie 9997 - * and tried to improve the int32 selection logic for 16bit systems. - * - * Revision 1.6 1995/09/04 04:19:41 warmerda - * Added fix for file bounds. - * - * Revision 1.5 1995/08/25 15:16:44 warmerda - * Fixed a couple of problems with big endian systems ... one with bounds - * and the other with multipart polygons. - * - * Revision 1.4 1995/08/24 18:10:17 warmerda - * Switch to use SfRealloc() to avoid problems with pre-ANSI realloc() - * functions (such as on the Sun). - * - * Revision 1.3 1995/08/23 02:23:15 warmerda - * Added support for reading bounds, and fixed up problems in setting the - * file wide bounds. - * - * Revision 1.2 1995/08/04 03:16:57 warmerda - * Added header. - * - */ - -#include <ossim/vec/shapefil.h> - -#include <math.h> -#include <limits.h> -#include <assert.h> -#include <stdlib.h> -#include <string.h> -#include <stdio.h> - -ossim_SHP_CVSID("$Id: shpopen.c 9094 2006-06-13 19:12:40Z dburken $") - -typedef unsigned char uchar; - -#if UINT_MAX == 65535 -typedef long int32; -#else -typedef int int32; -#endif - -#ifndef FALSE -# define FALSE 0 -# define TRUE 1 -#endif - -#define ByteCopy( a, b, c ) memcpy( b, a, c ) -#ifndef MAX -# define MIN(a,b) ((a<b) ? a : b) -# define MAX(a,b) ((a>b) ? a : b) -#endif - -static int bBigEndian; - - -/************************************************************************/ -/* SwapWord() */ -/* */ -/* Swap a 2, 4 or 8 byte word. */ -/************************************************************************/ - -static void SwapWord( int length, void * wordP ) - -{ - int i; - uchar temp; - - for( i=0; i < length/2; i++ ) - { - temp = ((uchar *) wordP)[i]; - ((uchar *)wordP)[i] = ((uchar *) wordP)[length-i-1]; - ((uchar *) wordP)[length-i-1] = temp; - } -} - -/************************************************************************/ -/* SfRealloc() */ -/* */ -/* A realloc cover function that will access a NULL pointer as */ -/* a valid input. */ -/************************************************************************/ - -static void * SfRealloc( void * pMem, int nNewSize ) - -{ - if( pMem == NULL ) - return( (void *) malloc(nNewSize) ); - else - return( (void *) realloc(pMem,nNewSize) ); -} - -/************************************************************************/ -/* ossim_SHPWriteHeader() */ -/* */ -/* Write out a header for the .shp and .shx files as well as the */ -/* contents of the index (.shx) file. */ -/************************************************************************/ - -void ossim_SHPWriteHeader( ossim_SHPHandle psSHP ) - -{ - uchar abyHeader[100]; - int i; - int32 i32; - double dValue; - int32 *panSHX; - -/* -------------------------------------------------------------------- */ -/* Prepare header block for .shp file. */ -/* -------------------------------------------------------------------- */ - for( i = 0; i < 100; i++ ) - abyHeader[i] = 0; - - abyHeader[2] = 0x27; /* magic cookie */ - abyHeader[3] = 0x0a; - - i32 = psSHP->nFileSize/2; /* file size */ - ByteCopy( &i32, abyHeader+24, 4 ); - if( !bBigEndian ) SwapWord( 4, abyHeader+24 ); - - i32 = 1000; /* version */ - ByteCopy( &i32, abyHeader+28, 4 ); - if( bBigEndian ) SwapWord( 4, abyHeader+28 ); - - i32 = psSHP->nShapeType; /* shape type */ - ByteCopy( &i32, abyHeader+32, 4 ); - if( bBigEndian ) SwapWord( 4, abyHeader+32 ); - - dValue = psSHP->adBoundsMin[0]; /* set bounds */ - ByteCopy( &dValue, abyHeader+36, 8 ); - if( bBigEndian ) SwapWord( 8, abyHeader+36 ); - - dValue = psSHP->adBoundsMin[1]; - ByteCopy( &dValue, abyHeader+44, 8 ); - if( bBigEndian ) SwapWord( 8, abyHeader+44 ); - - dValue = psSHP->adBoundsMax[0]; - ByteCopy( &dValue, abyHeader+52, 8 ); - if( bBigEndian ) SwapWord( 8, abyHeader+52 ); - - dValue = psSHP->adBoundsMax[1]; - ByteCopy( &dValue, abyHeader+60, 8 ); - if( bBigEndian ) SwapWord( 8, abyHeader+60 ); - - dValue = psSHP->adBoundsMin[2]; /* z */ - ByteCopy( &dValue, abyHeader+68, 8 ); - if( bBigEndian ) SwapWord( 8, abyHeader+68 ); - - dValue = psSHP->adBoundsMax[2]; - ByteCopy( &dValue, abyHeader+76, 8 ); - if( bBigEndian ) SwapWord( 8, abyHeader+76 ); - - dValue = psSHP->adBoundsMin[3]; /* m */ - ByteCopy( &dValue, abyHeader+84, 8 ); - if( bBigEndian ) SwapWord( 8, abyHeader+84 ); - - dValue = psSHP->adBoundsMax[3]; - ByteCopy( &dValue, abyHeader+92, 8 ); - if( bBigEndian ) SwapWord( 8, abyHeader+92 ); - -/* -------------------------------------------------------------------- */ -/* Write .shp file header. */ -/* -------------------------------------------------------------------- */ - if( fseek( psSHP->fpSHP, 0, 0 ) != 0 - || fwrite( abyHeader, 100, 1, psSHP->fpSHP ) != 1 ) - { -#ifdef USE_CPL - CPLError( CE_Failure, CPLE_OpenFailed, - "Failure writing .shp header." ); -#endif - return; - } - -/* -------------------------------------------------------------------- */ -/* Prepare, and write .shx file header. */ -/* -------------------------------------------------------------------- */ - i32 = (psSHP->nRecords * 2 * sizeof(int32) + 100)/2; /* file size */ - ByteCopy( &i32, abyHeader+24, 4 ); - if( !bBigEndian ) SwapWord( 4, abyHeader+24 ); - - if( fseek( psSHP->fpSHX, 0, 0 ) != 0 - || fwrite( abyHeader, 100, 1, psSHP->fpSHX ) != 1 ) - { -#ifdef USE_CPL - CPLError( CE_Failure, CPLE_OpenFailed, - "Failure writing .shx header." ); -#endif - return; - } - -/* -------------------------------------------------------------------- */ -/* Write out the .shx contents. */ -/* -------------------------------------------------------------------- */ - panSHX = (int32 *) malloc(sizeof(int32) * 2 * psSHP->nRecords); - - for( i = 0; i < psSHP->nRecords; i++ ) - { - panSHX[i*2 ] = psSHP->panRecOffset[i]/2; - panSHX[i*2+1] = psSHP->panRecSize[i]/2; - if( !bBigEndian ) SwapWord( 4, panSHX+i*2 ); - if( !bBigEndian ) SwapWord( 4, panSHX+i*2+1 ); - } - - if( (int)fwrite( panSHX, sizeof(int32)*2, psSHP->nRecords, psSHP->fpSHX ) - != psSHP->nRecords ) - { -#ifdef USE_CPL - CPLError( CE_Failure, CPLE_OpenFailed, - "Failure writing .shx contents." ); -#endif - } - - free( panSHX ); - -/* -------------------------------------------------------------------- */ -/* Flush to disk. */ -/* -------------------------------------------------------------------- */ - fflush( psSHP->fpSHP ); - fflush( psSHP->fpSHX ); -} - -/************************************************************************/ -/* shpopen() */ -/* */ -/* Open the .shp and .shx files based on the basename of the */ -/* files or either file name. */ -/************************************************************************/ - -ossim_SHPHandle ossim_SHPAPI_CALL - ossim_SHPOpen( const char * pszLayer, const char * pszAccess ) - -{ - char *pszFullname, *pszBasename; - ossim_SHPHandle psSHP; - - uchar *pabyBuf; - int i; - double dValue; - -/* -------------------------------------------------------------------- */ -/* Ensure the access string is one of the legal ones. We */ -/* ensure the result string indicates binary to avoid common */ -/* problems on Windows. */ -/* -------------------------------------------------------------------- */ - if( strcmp(pszAccess,"rb+") == 0 || strcmp(pszAccess,"r+b") == 0 - || strcmp(pszAccess,"r+") == 0 ) - pszAccess = "r+b"; - else - pszAccess = "rb"; - -/* -------------------------------------------------------------------- */ -/* Establish the byte order on this machine. */ -/* -------------------------------------------------------------------- */ - i = 1; - if( *((uchar *) &i) == 1 ) - bBigEndian = FALSE; - else - bBigEndian = TRUE; - -/* -------------------------------------------------------------------- */ -/* Initialize the info structure. */ -/* -------------------------------------------------------------------- */ - psSHP = (ossim_SHPHandle) calloc(sizeof(ossim_SHPInfo),1); - - psSHP->bUpdated = FALSE; - -/* -------------------------------------------------------------------- */ -/* Compute the base (layer) name. If there is any extension */ -/* on the passed in filename we will strip it off. */ -/* -------------------------------------------------------------------- */ - pszBasename = (char *) malloc(strlen(pszLayer)+5); - strcpy( pszBasename, pszLayer ); - for( i = strlen(pszBasename)-1; - i > 0 && pszBasename[i] != '.' && pszBasename[i] != '/' - && pszBasename[i] != '\\'; - i-- ) {} - - if( pszBasename[i] == '.' ) - pszBasename[i] = '\0'; - -/* -------------------------------------------------------------------- */ -/* Open the .shp and .shx files. Note that files pulled from */ -/* a PC to Unix with upper case filenames won't work! */ -/* -------------------------------------------------------------------- */ - pszFullname = (char *) malloc(strlen(pszBasename) + 5); - sprintf( pszFullname, "%s.shp", pszBasename ); - psSHP->fpSHP = fopen(pszFullname, pszAccess ); - if( psSHP->fpSHP == NULL ) - { - sprintf( pszFullname, "%s.SHP", pszBasename ); - psSHP->fpSHP = fopen(pszFullname, pszAccess ); - } - - if( psSHP->fpSHP == NULL ) - { -#ifdef USE_CPL - CPLError( CE_Failure, CPLE_OpenFailed, - "Unable to open %s.shp or %s.SHP.", - pszBasename, pszBasename ); -#endif - free( psSHP ); - free( pszBasename ); - free( pszFullname ); - return( NULL ); - } - - sprintf( pszFullname, "%s.shx", pszBasename ); - psSHP->fpSHX = fopen(pszFullname, pszAccess ); - if( psSHP->fpSHX == NULL ) - { - sprintf( pszFullname, "%s.SHX", pszBasename ); - psSHP->fpSHX = fopen(pszFullname, pszAccess ); - } - - if( psSHP->fpSHX == NULL ) - { -#ifdef USE_CPL - CPLError( CE_Failure, CPLE_OpenFailed, - "Unable to open %s.shx or %s.SHX.", - pszBasename, pszBasename ); -#endif - fclose( psSHP->fpSHP ); - free( psSHP ); - free( pszBasename ); - free( pszFullname ); - return( NULL ); - } - - free( pszFullname ); - free( pszBasename ); - -/* -------------------------------------------------------------------- */ -/* Read the file size from the ossim_SHP file. */ -/* -------------------------------------------------------------------- */ - pabyBuf = (uchar *) malloc(100); - fread( pabyBuf, 100, 1, psSHP->fpSHP ); - - psSHP->nFileSize = (pabyBuf[24] * 256 * 256 * 256 - + pabyBuf[25] * 256 * 256 - + pabyBuf[26] * 256 - + pabyBuf[27]) * 2; - -/* -------------------------------------------------------------------- */ -/* Read SHX file Header info */ -/* -------------------------------------------------------------------- */ - if( fread( pabyBuf, 100, 1, psSHP->fpSHX ) != 1 - || pabyBuf[0] != 0 - || pabyBuf[1] != 0 - || pabyBuf[2] != 0x27 - || (pabyBuf[3] != 0x0a && pabyBuf[3] != 0x0d) ) - { -#ifdef USE_CPL - CPLError( CE_Failure, CPLE_AppDefined, - ".shx file is unreadable, or corrupt." ); -#endif - fclose( psSHP->fpSHP ); - fclose( psSHP->fpSHX ); - free( psSHP ); - - return( NULL ); - } - - psSHP->nRecords = pabyBuf[27] + pabyBuf[26] * 256 - + pabyBuf[25] * 256 * 256 + pabyBuf[24] * 256 * 256 * 256; - psSHP->nRecords = (psSHP->nRecords*2 - 100) / 8; - - psSHP->nShapeType = pabyBuf[32]; - - if( psSHP->nRecords < 0 || psSHP->nRecords > 256000000 ) - { -#ifdef USE_CPL - CPLError( CE_Failure, CPLE_AppDefined, - "Record count in .shp header is %d, which seems\n" - "unreasonable. Assuming header is corrupt.", - psSHP->nRecords ); -#endif - fclose( psSHP->fpSHP ); - fclose( psSHP->fpSHX ); - free( psSHP ); - - return( NULL ); - } - -/* -------------------------------------------------------------------- */ -/* Read the bounds. */ -/* -------------------------------------------------------------------- */ - if( bBigEndian ) SwapWord( 8, pabyBuf+36 ); - memcpy( &dValue, pabyBuf+36, 8 ); - psSHP->adBoundsMin[0] = dValue; - - if( bBigEndian ) SwapWord( 8, pabyBuf+44 ); - memcpy( &dValue, pabyBuf+44, 8 ); - psSHP->adBoundsMin[1] = dValue; - - if( bBigEndian ) SwapWord( 8, pabyBuf+52 ); - memcpy( &dValue, pabyBuf+52, 8 ); - psSHP->adBoundsMax[0] = dValue; - - if( bBigEndian ) SwapWord( 8, pabyBuf+60 ); - memcpy( &dValue, pabyBuf+60, 8 ); - psSHP->adBoundsMax[1] = dValue; - - if( bBigEndian ) SwapWord( 8, pabyBuf+68 ); /* z */ - memcpy( &dValue, pabyBuf+68, 8 ); - psSHP->adBoundsMin[2] = dValue; - - if( bBigEndian ) SwapWord( 8, pabyBuf+76 ); - memcpy( &dValue, pabyBuf+76, 8 ); - psSHP->adBoundsMax[2] = dValue; - - if( bBigEndian ) SwapWord( 8, pabyBuf+84 ); /* z */ - memcpy( &dValue, pabyBuf+84, 8 ); - psSHP->adBoundsMin[3] = dValue; - - if( bBigEndian ) SwapWord( 8, pabyBuf+92 ); - memcpy( &dValue, pabyBuf+92, 8 ); - psSHP->adBoundsMax[3] = dValue; - - free( pabyBuf ); - -/* -------------------------------------------------------------------- */ -/* Read the .shx file to get the offsets to each record in */ -/* the .shp file. */ -/* -------------------------------------------------------------------- */ - psSHP->nMaxRecords = psSHP->nRecords; - - psSHP->panRecOffset = - (int *) malloc(sizeof(int) * MAX(1,psSHP->nMaxRecords) ); - psSHP->panRecSize = - (int *) malloc(sizeof(int) * MAX(1,psSHP->nMaxRecords) ); - - pabyBuf = (uchar *) malloc(8 * MAX(1,psSHP->nRecords) ); - if( (int) fread( pabyBuf, 8, psSHP->nRecords, psSHP->fpSHX ) - != psSHP->nRecords ) - { -#ifdef USE_CPL - CPLError( CE_Failure, CPLE_AppDefined, - "Failed to read all values for %d records in .shx file.", - psSHP->nRecords ); -#endif - /* SHX is short or unreadable for some reason. */ - fclose( psSHP->fpSHP ); - fclose( psSHP->fpSHX ); - free( psSHP->panRecOffset ); - free( psSHP->panRecSize ); - free( psSHP ); - - return( NULL ); - } - - for( i = 0; i < psSHP->nRecords; i++ ) - { - int32 nOffset, nLength; - - memcpy( &nOffset, pabyBuf + i * 8, 4 ); - if( !bBigEndian ) SwapWord( 4, &nOffset ); - - memcpy( &nLength, pabyBuf + i * 8 + 4, 4 ); - if( !bBigEndian ) SwapWord( 4, &nLength ); - - psSHP->panRecOffset[i] = nOffset*2; - psSHP->panRecSize[i] = nLength*2; - } - free( pabyBuf ); - - return( psSHP ); -} - -/************************************************************************/ -/* ossim_SHPClose() */ -/* */ -/* Close the .shp and .shx files. */ -/************************************************************************/ - -void ossim_SHPAPI_CALL - ossim_SHPClose(ossim_SHPHandle psSHP ) - -{ - if( psSHP == NULL ) - return; - -/* -------------------------------------------------------------------- */ -/* Update the header if we have modified anything. */ -/* -------------------------------------------------------------------- */ - if( psSHP->bUpdated ) - ossim_SHPWriteHeader( psSHP ); - -/* -------------------------------------------------------------------- */ -/* Free all resources, and close files. */ -/* -------------------------------------------------------------------- */ - free( psSHP->panRecOffset ); - free( psSHP->panRecSize ); - - fclose( psSHP->fpSHX ); - fclose( psSHP->fpSHP ); - - if( psSHP->pabyRec != NULL ) - { - free( psSHP->pabyRec ); - } - - free( psSHP ); -} - -/************************************************************************/ -/* ossim_SHPGetInfo() */ -/* */ -/* Fetch general information about the shape file. */ -/************************************************************************/ - -void ossim_SHPAPI_CALL - ossim_SHPGetInfo(ossim_SHPHandle psSHP, int * pnEntities, int * pnShapeType, - double * padfMinBound, double * padfMaxBound ) - -{ - int i; - - if( psSHP == NULL ) - return; - - if( pnEntities != NULL ) - *pnEntities = psSHP->nRecords; - - if( pnShapeType != NULL ) - *pnShapeType = psSHP->nShapeType; - - for( i = 0; i < 4; i++ ) - { - if( padfMinBound != NULL ) - padfMinBound[i] = psSHP->adBoundsMin[i]; - if( padfMaxBound != NULL ) - padfMaxBound[i] = psSHP->adBoundsMax[i]; - } -} - -/************************************************************************/ -/* ossim_SHPCreate() */ -/* */ -/* Create a new shape file and return a handle to the open */ -/* shape file with read/write access. */ -/************************************************************************/ - -ossim_SHPHandle ossim_SHPAPI_CALL - ossim_SHPCreate( const char * pszLayer, int nShapeType ) - -{ - char *pszBasename, *pszFullname; - int i; - FILE *fpSHP, *fpSHX; - uchar abyHeader[100]; - int32 i32; - double dValue; - -/* -------------------------------------------------------------------- */ -/* Establish the byte order on this system. */ -/* -------------------------------------------------------------------- */ - i = 1; - if( *((uchar *) &i) == 1 ) - bBigEndian = FALSE; - else - bBigEndian = TRUE; - -/* -------------------------------------------------------------------- */ -/* Compute the base (layer) name. If there is any extension */ -/* on the passed in filename we will strip it off. */ -/* -------------------------------------------------------------------- */ - pszBasename = (char *) malloc(strlen(pszLayer)+5); - strcpy( pszBasename, pszLayer ); - for( i = strlen(pszBasename)-1; - i > 0 && pszBasename[i] != '.' && pszBasename[i] != '/' - && pszBasename[i] != '\\'; - i-- ) {} - - if( pszBasename[i] == '.' ) - pszBasename[i] = '\0'; - -/* -------------------------------------------------------------------- */ -/* Open the two files so we can write their headers. */ -/* -------------------------------------------------------------------- */ - pszFullname = (char *) malloc(strlen(pszBasename) + 5); - sprintf( pszFullname, "%s.shp", pszBasename ); - fpSHP = fopen(pszFullname, "wb" ); - if( fpSHP == NULL ) - { -#ifdef USE_CPL - CPLError( CE_Failure, CPLE_AppDefined, - "Failed to create file %s.", - pszFullname ); -#endif - return( NULL ); - } - - sprintf( pszFullname, "%s.shx", pszBasename ); - fpSHX = fopen(pszFullname, "wb" ); - if( fpSHX == NULL ) - { -#ifdef USE_CPL - CPLError( CE_Failure, CPLE_AppDefined, - "Failed to create file %s.", - pszFullname ); -#endif - return( NULL ); - } - - free( pszFullname ); - free( pszBasename ); - -/* -------------------------------------------------------------------- */ -/* Prepare header block for .shp file. */ -/* -------------------------------------------------------------------- */ - for( i = 0; i < 100; i++ ) - abyHeader[i] = 0; - - abyHeader[2] = 0x27; /* magic cookie */ - abyHeader[3] = 0x0a; - - i32 = 50; /* file size */ - ByteCopy( &i32, abyHeader+24, 4 ); - if( !bBigEndian ) SwapWord( 4, abyHeader+24 ); - - i32 = 1000; /* version */ - ByteCopy( &i32, abyHeader+28, 4 ); - if( bBigEndian ) SwapWord( 4, abyHeader+28 ); - - i32 = nShapeType; /* shape type */ - ByteCopy( &i32, abyHeader+32, 4 ); - if( bBigEndian ) SwapWord( 4, abyHeader+32 ); - - dValue = 0.0; /* set bounds */ - ByteCopy( &dValue, abyHeader+36, 8 ); - ByteCopy( &dValue, abyHeader+44, 8 ); - ByteCopy( &dValue, abyHeader+52, 8 ); - ByteCopy( &dValue, abyHeader+60, 8 ); - -/* -------------------------------------------------------------------- */ -/* Write .shp file header. */ -/* -------------------------------------------------------------------- */ - if( fwrite( abyHeader, 100, 1, fpSHP ) != 1 ) - { -#ifdef USE_CPL - CPLError( CE_Failure, CPLE_AppDefined, - "Failed to write .shp header." ); -#endif - return NULL; - } - -/* -------------------------------------------------------------------- */ -/* Prepare, and write .shx file header. */ -/* -------------------------------------------------------------------- */ - i32 = 50; /* file size */ - ByteCopy( &i32, abyHeader+24, 4 ); - if( !bBigEndian ) SwapWord( 4, abyHeader+24 ); - - if( fwrite( abyHeader, 100, 1, fpSHX ) != 1 ) - { -#ifdef USE_CPL - CPLError( CE_Failure, CPLE_AppDefined, - "Failed to write .shx header." ); -#endif - return NULL; - } - -/* -------------------------------------------------------------------- */ -/* Close the files, and then open them as regular existing files. */ -/* -------------------------------------------------------------------- */ - fclose( fpSHP ); - fclose( fpSHX ); - - return( ossim_SHPOpen( pszLayer, "r+b" ) ); -} - -/************************************************************************/ -/* _SHPSetBounds() */ -/* */ -/* Compute a bounds rectangle for a shape, and set it into the */ -/* indicated location in the record. */ -/************************************************************************/ - -static void _SHPSetBounds( uchar * pabyRec, ossim_SHPObject * psShape ) - -{ - ByteCopy( &(psShape->dfXMin), pabyRec + 0, 8 ); - ByteCopy( &(psShape->dfYMin), pabyRec + 8, 8 ); - ByteCopy( &(psShape->dfXMax), pabyRec + 16, 8 ); - ByteCopy( &(psShape->dfYMax), pabyRec + 24, 8 ); - - if( bBigEndian ) - { - SwapWord( 8, pabyRec + 0 ); - SwapWord( 8, pabyRec + 8 ); - SwapWord( 8, pabyRec + 16 ); - SwapWord( 8, pabyRec + 24 ); - } -} - -/************************************************************************/ -/* ossim_SHPComputeExtents() */ -/* */ -/* Recompute the extents of a shape. Automatically done by */ -/* ossim_SHPCreateObject(). */ -/************************************************************************/ - -void ossim_SHPAPI_CALL - ossim_SHPComputeExtents( ossim_SHPObject * psObject ) - -{ - int i; - -/* -------------------------------------------------------------------- */ -/* Build extents for this object. */ -/* -------------------------------------------------------------------- */ - if( psObject->nVertices > 0 ) - { - psObject->dfXMin = psObject->dfXMax = psObject->padfX[0]; - psObject->dfYMin = psObject->dfYMax = psObject->padfY[0]; - psObject->dfZMin = psObject->dfZMax = psObject->padfZ[0]; - psObject->dfMMin = psObject->dfMMax = psObject->padfM[0]; - } - - for( i = 0; i < psObject->nVertices; i++ ) - { - psObject->dfXMin = MIN(psObject->dfXMin, psObject->padfX[i]); - psObject->dfYMin = MIN(psObject->dfYMin, psObject->padfY[i]); - psObject->dfZMin = MIN(psObject->dfZMin, psObject->padfZ[i]); - psObject->dfMMin = MIN(psObject->dfMMin, psObject->padfM[i]); - - psObject->dfXMax = MAX(psObject->dfXMax, psObject->padfX[i]); - psObject->dfYMax = MAX(psObject->dfYMax, psObject->padfY[i]); - psObject->dfZMax = MAX(psObject->dfZMax, psObject->padfZ[i]); - psObject->dfMMax = MAX(psObject->dfMMax, psObject->padfM[i]); - } -} - -/************************************************************************/ -/* ossim_SHPCreateObject() */ -/* */ -/* Create a shape object. It should be freed with */ -/* ossim_SHPDestroyObject(). */ -/************************************************************************/ - -ossim_SHPObject ossim_SHPAPI_CALL1(*) - ossim_SHPCreateObject( int nSHPType, int nShapeId, int nParts, - const int * panPartStart, const int * panPartType, - int nVertices, const double *padfX, const double *padfY, - const double * padfZ, const double * padfM ) - -{ - ossim_SHPObject *psObject; - int i, bHasM, bHasZ; - - psObject = (ossim_SHPObject *) calloc(1,sizeof(ossim_SHPObject)); - psObject->nSHPType = nSHPType; - psObject->nShapeId = nShapeId; - -/* -------------------------------------------------------------------- */ -/* Establish whether this shape type has M, and Z values. */ -/* -------------------------------------------------------------------- */ - if( nSHPType == ossim_SHPT_ARCM - || nSHPType == ossim_SHPT_POINTM - || nSHPType == ossim_SHPT_POLYGONM - || nSHPType == ossim_SHPT_MULTIPOINTM ) - { - bHasM = TRUE; - bHasZ = FALSE; - } - else if( nSHPType == ossim_SHPT_ARCZ - || nSHPType == ossim_SHPT_POINTZ - || nSHPType == ossim_SHPT_POLYGONZ - || nSHPType == ossim_SHPT_MULTIPOINTZ - || nSHPType == ossim_SHPT_MULTIPATCH ) - { - bHasM = TRUE; - bHasZ = TRUE; - } - else - { - bHasM = FALSE; - bHasZ = FALSE; - } - -/* -------------------------------------------------------------------- */ -/* Capture parts. Note that part type is optional, and */ -/* defaults to ring. */ -/* -------------------------------------------------------------------- */ - if( nSHPType == ossim_SHPT_ARC || nSHPType == ossim_SHPT_POLYGON - || nSHPType == ossim_SHPT_ARCM || nSHPType == ossim_SHPT_POLYGONM - || nSHPType == ossim_SHPT_ARCZ || nSHPType == ossim_SHPT_POLYGONZ - || nSHPType == ossim_SHPT_MULTIPATCH ) - { - psObject->nParts = MAX(1,nParts); - - psObject->panPartStart = (int *) - malloc(sizeof(int) * psObject->nParts); - psObject->panPartType = (int *) - malloc(sizeof(int) * psObject->nParts); - - psObject->panPartStart[0] = 0; - psObject->panPartType[0] = ossim_SHPP_RING; - - for( i = 0; i < nParts; i++ ) - { - psObject->panPartStart[i] = panPartStart[i]; - - if( panPartType != NULL ) - psObject->panPartType[i] = panPartType[i]; - else - psObject->panPartType[i] = ossim_SHPP_RING; - } - - if( psObject->panPartStart[0] != 0 ) - { -#ifdef USE_CPL - CPLError( CE_Failure, CPLE_AppDefined, - "panPartStart[0] != 0, patching internally. Please fix your code!\n" ); -#else - fprintf( stderr, "panPartStart[0] != 0, patching internally. Please fix your code!\n" ); -#endif - psObject->panPartStart[0] = 0; - } - } - -/* -------------------------------------------------------------------- */ -/* Capture vertices. Note that Z and M are optional, but X and */ -/* Y are not. */ -/* -------------------------------------------------------------------- */ - if( nVertices > 0 ) - { - psObject->padfX = (double *) calloc(sizeof(double),nVertices); - psObject->padfY = (double *) calloc(sizeof(double),nVertices); - psObject->padfZ = (double *) calloc(sizeof(double),nVertices); - psObject->padfM = (double *) calloc(sizeof(double),nVertices); - - assert( padfX != NULL ); - assert( padfY != NULL ); - - for( i = 0; i < nVertices; i++ ) - { - psObject->padfX[i] = padfX[i]; - psObject->padfY[i] = padfY[i]; - if( padfZ != NULL && bHasZ ) - psObject->padfZ[i] = padfZ[i]; - if( padfM != NULL && bHasM ) - psObject->padfM[i] = padfM[i]; - } - } - -/* -------------------------------------------------------------------- */ -/* Compute the extents. */ -/* -------------------------------------------------------------------- */ - psObject->nVertices = nVertices; - ossim_SHPComputeExtents( psObject ); - - return( psObject ); -} - -/************************************************************************/ -/* ossim_SHPCreateSimpleObject() */ -/* */ -/* Create a simple (common) shape object. Destroy with */ -/* ossim_SHPDestroyObject(). */ -/************************************************************************/ - -ossim_SHPObject ossim_SHPAPI_CALL1(*) - ossim_SHPCreateSimpleObject( int nSHPType, int nVertices, - const double * padfX, const double * padfY, - const double * padfZ ) - -{ - return( ossim_SHPCreateObject( nSHPType, -1, 0, NULL, NULL, - nVertices, padfX, padfY, padfZ, NULL ) ); -} - -/************************************************************************/ -/* ossim_SHPWriteObject() */ -/* */ -/* Write out the vertices of a new structure. Note that it is */ -/* only possible to write vertices at the end of the file. */ -/************************************************************************/ - -int ossim_SHPAPI_CALL - ossim_SHPWriteObject(ossim_SHPHandle psSHP, int nShapeId, ossim_SHPObject * psObject ) - -{ - int nRecordOffset, i, nRecordSize=0; - uchar *pabyRec; - int32 i32; - - psSHP->bUpdated = TRUE; - -/* -------------------------------------------------------------------- */ -/* Ensure that shape object matches the type of the file it is */ -/* being written to. */ -/* -------------------------------------------------------------------- */ - assert( psObject->nSHPType == psSHP->nShapeType - || psObject->nSHPType == ossim_SHPT_NULL ); - -/* -------------------------------------------------------------------- */ -/* Ensure that -1 is used for appends. Either blow an */ -/* assertion, or if they are disabled, set the shapeid to -1 */ -/* for appends. */ -/* -------------------------------------------------------------------- */ - assert( nShapeId == -1 - || (nShapeId >= 0 && nShapeId < psSHP->nRecords) ); - - if( nShapeId != -1 && nShapeId >= psSHP->nRecords ) - nShapeId = -1; - -/* -------------------------------------------------------------------- */ -/* Add the new entity to the in memory index. */ -/* -------------------------------------------------------------------- */ - if( nShapeId == -1 && psSHP->nRecords+1 > psSHP->nMaxRecords ) - { - psSHP->nMaxRecords =(int) ( psSHP->nMaxRecords * 1.3 + 100); - - psSHP->panRecOffset = (int *) - SfRealloc(psSHP->panRecOffset,sizeof(int) * psSHP->nMaxRecords ); - psSHP->panRecSize = (int *) - SfRealloc(psSHP->panRecSize,sizeof(int) * psSHP->nMaxRecords ); - } - -/* -------------------------------------------------------------------- */ -/* Initialize record. */ -/* -------------------------------------------------------------------- */ - pabyRec = (uchar *) malloc(psObject->nVertices * 4 * sizeof(double) - + psObject->nParts * 8 + 128); - -/* -------------------------------------------------------------------- */ -/* Extract vertices for a Polygon or Arc. */ -/* -------------------------------------------------------------------- */ - if( psObject->nSHPType == ossim_SHPT_POLYGON - || psObject->nSHPType == ossim_SHPT_POLYGONZ - || psObject->nSHPType == ossim_SHPT_POLYGONM - || psObject->nSHPType == ossim_SHPT_ARC - || psObject->nSHPType == ossim_SHPT_ARCZ - || psObject->nSHPType == ossim_SHPT_ARCM - || psObject->nSHPType == ossim_SHPT_MULTIPATCH ) - { - int32 nPoints, nParts; - int i; - - nPoints = psObject->nVertices; - nParts = psObject->nParts; - - _SHPSetBounds( pabyRec + 12, psObject ); - - if( bBigEndian ) SwapWord( 4, &nPoints ); - if( bBigEndian ) SwapWord( 4, &nParts ); - - ByteCopy( &nPoints, pabyRec + 40 + 8, 4 ); - ByteCopy( &nParts, pabyRec + 36 + 8, 4 ); - - nRecordSize = 52; - - /* - * Write part start positions. - */ - ByteCopy( psObject->panPartStart, pabyRec + 44 + 8, - 4 * psObject->nParts ); - for( i = 0; i < psObject->nParts; i++ ) - { - if( bBigEndian ) SwapWord( 4, pabyRec + 44 + 8 + 4*i ); - nRecordSize += 4; - } - - /* - * Write multipatch part types if needed. - */ - if( psObject->nSHPType == ossim_SHPT_MULTIPATCH ) - { - memcpy( pabyRec + nRecordSize, psObject->panPartType, - 4*psObject->nParts ); - for( i = 0; i < psObject->nParts; i++ ) - { - if( bBigEndian ) SwapWord( 4, pabyRec + nRecordSize ); - nRecordSize += 4; - } - } - - /* - * Write the (x,y) vertex values. - */ - for( i = 0; i < psObject->nVertices; i++ ) - { - ByteCopy( psObject->padfX + i, pabyRec + nRecordSize, 8 ); - ByteCopy( psObject->padfY + i, pabyRec + nRecordSize + 8, 8 ); - - if( bBigEndian ) - SwapWord( 8, pabyRec + nRecordSize ); - - if( bBigEndian ) - SwapWord( 8, pabyRec + nRecordSize + 8 ); - - nRecordSize += 2 * 8; - } - - /* - * Write the Z coordinates (if any). - */ - if( psObject->nSHPType == ossim_SHPT_POLYGONZ - || psObject->nSHPType == ossim_SHPT_ARCZ - || psObject->nSHPType == ossim_SHPT_MULTIPATCH ) - { - ByteCopy( &(psObject->dfZMin), pabyRec + nRecordSize, 8 ); - if( bBigEndian ) SwapWord( 8, pabyRec + nRecordSize ); - nRecordSize += 8; - - ByteCopy( &(psObject->dfZMax), pabyRec + nRecordSize, 8 ); - if( bBigEndian ) SwapWord( 8, pabyRec + nRecordSize ); - nRecordSize += 8; - - for( i = 0; i < psObject->nVertices; i++ ) - { - ByteCopy( psObject->padfZ + i, pabyRec + nRecordSize, 8 ); - if( bBigEndian ) SwapWord( 8, pabyRec + nRecordSize ); - nRecordSize += 8; - } - } - - /* - * Write the M values, if any. - */ - if( psObject->nSHPType == ossim_SHPT_POLYGONM - || psObject->nSHPType == ossim_SHPT_ARCM -#ifndef DISABLE_MULTIPATCH_MEASURE - || psObject->nSHPType == ossim_SHPT_MULTIPATCH -#endif - || psObject->nSHPType == ossim_SHPT_POLYGONZ - || psObject->nSHPType == ossim_SHPT_ARCZ ) - { - ByteCopy( &(psObject->dfMMin), pabyRec + nRecordSize, 8 ); - if( bBigEndian ) SwapWord( 8, pabyRec + nRecordSize ); - nRecordSize += 8; - - ByteCopy( &(psObject->dfMMax), pabyRec + nRecordSize, 8 ); - if( bBigEndian ) SwapWord( 8, pabyRec + nRecordSize ); - nRecordSize += 8; - - for( i = 0; i < psObject->nVertices; i++ ) - { - ByteCopy( psObject->padfM + i, pabyRec + nRecordSize, 8 ); - if( bBigEndian ) SwapWord( 8, pabyRec + nRecordSize ); - nRecordSize += 8; - } - } - } - -/* -------------------------------------------------------------------- */ -/* Extract vertices for a MultiPoint. */ -/* -------------------------------------------------------------------- */ - else if( psObject->nSHPType == ossim_SHPT_MULTIPOINT - || psObject->nSHPType == ossim_SHPT_MULTIPOINTZ - || psObject->nSHPType == ossim_SHPT_MULTIPOINTM ) - { - int32 nPoints; - int i; - - nPoints = psObject->nVertices; - - _SHPSetBounds( pabyRec + 12, psObject ); - - if( bBigEndian ) SwapWord( 4, &nPoints ); - ByteCopy( &nPoints, pabyRec + 44, 4 ); - - for( i = 0; i < psObject->nVertices; i++ ) - { - ByteCopy( psObject->padfX + i, pabyRec + 48 + i*16, 8 ); - ByteCopy( psObject->padfY + i, pabyRec + 48 + i*16 + 8, 8 ); - - if( bBigEndian ) SwapWord( 8, pabyRec + 48 + i*16 ); - if( bBigEndian ) SwapWord( 8, pabyRec + 48 + i*16 + 8 ); - } - - nRecordSize = 48 + 16 * psObject->nVertices; - - if( psObject->nSHPType == ossim_SHPT_MULTIPOINTZ ) - { - ByteCopy( &(psObject->dfZMin), pabyRec + nRecordSize, 8 ); - if( bBigEndian ) SwapWord( 8, pabyRec + nRecordSize ); - nRecordSize += 8; - - ByteCopy( &(psObject->dfZMax), pabyRec + nRecordSize, 8 ); - if( bBigEndian ) SwapWord( 8, pabyRec + nRecordSize ); - nRecordSize += 8; - - for( i = 0; i < psObject->nVertices; i++ ) - { - ByteCopy( psObject->padfZ + i, pabyRec + nRecordSize, 8 ); - if( bBigEndian ) SwapWord( 8, pabyRec + nRecordSize ); - nRecordSize += 8; - } - } - - if( psObject->nSHPType == ossim_SHPT_MULTIPOINTZ - || psObject->nSHPType == ossim_SHPT_MULTIPOINTM ) - { - ByteCopy( &(psObject->dfMMin), pabyRec + nRecordSize, 8 ); - if( bBigEndian ) SwapWord( 8, pabyRec + nRecordSize ); - nRecordSize += 8; - - ByteCopy( &(psObject->dfMMax), pabyRec + nRecordSize, 8 ); - if( bBigEndian ) SwapWord( 8, pabyRec + nRecordSize ); - nRecordSize += 8; - - for( i = 0; i < psObject->nVertices; i++ ) - { - ByteCopy( psObject->padfM + i, pabyRec + nRecordSize, 8 ); - if( bBigEndian ) SwapWord( 8, pabyRec + nRecordSize ); - nRecordSize += 8; - } - } - } - -/* -------------------------------------------------------------------- */ -/* Write point. */ -/* -------------------------------------------------------------------- */ - else if( psObject->nSHPType == ossim_SHPT_POINT - || psObject->nSHPType == ossim_SHPT_POINTZ - || psObject->nSHPType == ossim_SHPT_POINTM ) - { - ByteCopy( psObject->padfX, pabyRec + 12, 8 ); - ByteCopy( psObject->padfY, pabyRec + 20, 8 ); - - if( bBigEndian ) SwapWord( 8, pabyRec + 12 ); - if( bBigEndian ) SwapWord( 8, pabyRec + 20 ); - - nRecordSize = 28; - - if( psObject->nSHPType == ossim_SHPT_POINTZ ) - { - ByteCopy( psObject->padfZ, pabyRec + nRecordSize, 8 ); - if( bBigEndian ) SwapWord( 8, pabyRec + nRecordSize ); - nRecordSize += 8; - } - - if( psObject->nSHPType == ossim_SHPT_POINTZ - || psObject->nSHPType == ossim_SHPT_POINTM ) - { - ByteCopy( psObject->padfM, pabyRec + nRecordSize, 8 ); - if( bBigEndian ) SwapWord( 8, pabyRec + nRecordSize ); - nRecordSize += 8; - } - } - -/* -------------------------------------------------------------------- */ -/* Not much to do for null geometries. */ -/* -------------------------------------------------------------------- */ - else if( psObject->nSHPType == ossim_SHPT_NULL ) - { - nRecordSize = 12; - } - - else - { - /* unknown type */ - assert( FALSE ); - } - -/* -------------------------------------------------------------------- */ -/* Establish where we are going to put this record. If we are */ -/* rewriting and existing record, and it will fit, then put it */ -/* back where the original came from. Otherwise write at the end. */ -/* -------------------------------------------------------------------- */ - if( nShapeId == -1 || psSHP->panRecSize[nShapeId] < nRecordSize-8 ) - { - if( nShapeId == -1 ) - nShapeId = psSHP->nRecords++; - - psSHP->panRecOffset[nShapeId] = nRecordOffset = psSHP->nFileSize; - psSHP->panRecSize[nShapeId] = nRecordSize-8; - psSHP->nFileSize += nRecordSize; - } - else - { - nRecordOffset = psSHP->panRecOffset[nShapeId]; - } - -/* -------------------------------------------------------------------- */ -/* Set the shape type, record number, and record size. */ -/* -------------------------------------------------------------------- */ - i32 = nShapeId+1; /* record # */ - if( !bBigEndian ) SwapWord( 4, &i32 ); - ByteCopy( &i32, pabyRec, 4 ); - - i32 = (nRecordSize-8)/2; /* record size */ - if( !bBigEndian ) SwapWord( 4, &i32 ); - ByteCopy( &i32, pabyRec + 4, 4 ); - - i32 = psObject->nSHPType; /* shape type */ - if( bBigEndian ) SwapWord( 4, &i32 ); - ByteCopy( &i32, pabyRec + 8, 4 ); - -/* -------------------------------------------------------------------- */ -/* Write out record. */ -/* -------------------------------------------------------------------- */ - if( fseek( psSHP->fpSHP, nRecordOffset, 0 ) != 0 - || fwrite( pabyRec, nRecordSize, 1, psSHP->fpSHP ) < 1 ) - { -#ifdef USE_CPL - CPLError( CE_Failure, CPLE_FileIO, - "Error in fseek() or fwrite() writing object to .shp file." ); -#endif - free( pabyRec ); - return -1; - } - - free( pabyRec ); - -/* -------------------------------------------------------------------- */ -/* Expand file wide bounds based on this shape. */ -/* -------------------------------------------------------------------- */ - if( psSHP->adBoundsMin[0] == 0.0 - && psSHP->adBoundsMax[0] == 0.0 - && psSHP->adBoundsMin[1] == 0.0 - && psSHP->adBoundsMax[1] == 0.0 ) - { - if( psObject->nSHPType == ossim_SHPT_NULL || psObject->nVertices == 0 ) - { - psSHP->adBoundsMin[0] = psSHP->adBoundsMax[0] = 0.0; - psSHP->adBoundsMin[1] = psSHP->adBoundsMax[1] = 0.0; - psSHP->adBoundsMin[2] = psSHP->adBoundsMax[2] = 0.0; - psSHP->adBoundsMin[3] = psSHP->adBoundsMax[3] = 0.0; - } - else - { - psSHP->adBoundsMin[0] = psSHP->adBoundsMax[0] = psObject->padfX[0]; - psSHP->adBoundsMin[1] = psSHP->adBoundsMax[1] = psObject->padfY[0]; - psSHP->adBoundsMin[2] = psSHP->adBoundsMax[2] = psObject->padfZ[0]; - psSHP->adBoundsMin[3] = psSHP->adBoundsMax[3] = psObject->padfM[0]; - } - } - - for( i = 0; i < psObject->nVertices; i++ ) - { - psSHP->adBoundsMin[0] = MIN(psSHP->adBoundsMin[0],psObject->padfX[i]); - psSHP->adBoundsMin[1] = MIN(psSHP->adBoundsMin[1],psObject->padfY[i]); - psSHP->adBoundsMin[2] = MIN(psSHP->adBoundsMin[2],psObject->padfZ[i]); - psSHP->adBoundsMin[3] = MIN(psSHP->adBoundsMin[3],psObject->padfM[i]); - psSHP->adBoundsMax[0] = MAX(psSHP->adBoundsMax[0],psObject->padfX[i]); - psSHP->adBoundsMax[1] = MAX(psSHP->adBoundsMax[1],psObject->padfY[i]); - psSHP->adBoundsMax[2] = MAX(psSHP->adBoundsMax[2],psObject->padfZ[i]); - psSHP->adBoundsMax[3] = MAX(psSHP->adBoundsMax[3],psObject->padfM[i]); - } - - return( nShapeId ); -} - -/************************************************************************/ -/* ossim_SHPReadObject() */ -/* */ -/* Read the vertices, parts, and other non-attribute information */ -/* for one shape. */ -/************************************************************************/ - -ossim_SHPObject ossim_SHPAPI_CALL1(*) - ossim_SHPReadObject( ossim_SHPHandle psSHP, int hEntity ) - -{ - ossim_SHPObject *psShape; - -/* -------------------------------------------------------------------- */ -/* Validate the record/entity number. */ -/* -------------------------------------------------------------------- */ - if( hEntity < 0 || hEntity >= psSHP->nRecords ) - return( NULL ); - -/* -------------------------------------------------------------------- */ -/* Ensure our record buffer is large enough. */ -/* -------------------------------------------------------------------- */ - if( psSHP->panRecSize[hEntity]+8 > psSHP->nBufSize ) - { - psSHP->nBufSize = psSHP->panRecSize[hEntity]+8; - psSHP->pabyRec = (uchar *) SfRealloc(psSHP->pabyRec,psSHP->nBufSize); - } - -/* -------------------------------------------------------------------- */ -/* Read the record. */ -/* -------------------------------------------------------------------- */ - if( fseek( psSHP->fpSHP, psSHP->panRecOffset[hEntity], 0 ) != 0 - || fread( psSHP->pabyRec, psSHP->panRecSize[hEntity]+8, 1, - psSHP->fpSHP ) != 1 ) - { -#ifdef USE_CPL - CPLError( CE_Failure, CPLE_FileIO, - "Error in fseek() or fread() reading object from .shp file." ); -#endif - return NULL; - } - -/* -------------------------------------------------------------------- */ -/* Allocate and minimally initialize the object. */ -/* -------------------------------------------------------------------- */ - psShape = (ossim_SHPObject *) calloc(1,sizeof(ossim_SHPObject)); - psShape->nShapeId = hEntity; - - memcpy( &psShape->nSHPType, psSHP->pabyRec + 8, 4 ); - if( bBigEndian ) SwapWord( 4, &(psShape->nSHPType) ); - -/* ==================================================================== */ -/* Extract vertices for a Polygon or Arc. */ -/* ==================================================================== */ - if( psShape->nSHPType == ossim_SHPT_POLYGON || psShape->nSHPType == ossim_SHPT_ARC - || psShape->nSHPType == ossim_SHPT_POLYGONZ - || psShape->nSHPType == ossim_SHPT_POLYGONM - || psShape->nSHPType == ossim_SHPT_ARCZ - || psShape->nSHPType == ossim_SHPT_ARCM - || psShape->nSHPType == ossim_SHPT_MULTIPATCH ) - { - int32 nPoints, nParts; - int i, nOffset; - -/* -------------------------------------------------------------------- */ -/* Get the X/Y bounds. */ -/* -------------------------------------------------------------------- */ - memcpy( &(psShape->dfXMin), psSHP->pabyRec + 8 + 4, 8 ); - memcpy( &(psShape->dfYMin), psSHP->pabyRec + 8 + 12, 8 ); - memcpy( &(psShape->dfXMax), psSHP->pabyRec + 8 + 20, 8 ); - memcpy( &(psShape->dfYMax), psSHP->pabyRec + 8 + 28, 8 ); - - if( bBigEndian ) SwapWord( 8, &(psShape->dfXMin) ); - if( bBigEndian ) SwapWord( 8, &(psShape->dfYMin) ); - if( bBigEndian ) SwapWord( 8, &(psShape->dfXMax) ); - if( bBigEndian ) SwapWord( 8, &(psShape->dfYMax) ); - -/* -------------------------------------------------------------------- */ -/* Extract part/point count, and build vertex and part arrays */ -/* to proper size. */ -/* -------------------------------------------------------------------- */ - memcpy( &nPoints, psSHP->pabyRec + 40 + 8, 4 ); - memcpy( &nParts, psSHP->pabyRec + 36 + 8, 4 ); - - if( bBigEndian ) SwapWord( 4, &nPoints ); - if( bBigEndian ) SwapWord( 4, &nParts ); - - psShape->nVertices = nPoints; - psShape->padfX = (double *) calloc(nPoints,sizeof(double)); - psShape->padfY = (double *) calloc(nPoints,sizeof(double)); - psShape->padfZ = (double *) calloc(nPoints,sizeof(double)); - psShape->padfM = (double *) calloc(nPoints,sizeof(double)); - - psShape->nParts = nParts; - psShape->panPartStart = (int *) calloc(nParts,sizeof(int)); - psShape->panPartType = (int *) calloc(nParts,sizeof(int)); - - for( i = 0; i < nParts; i++ ) - psShape->panPartType[i] = ossim_SHPP_RING; - -/* -------------------------------------------------------------------- */ -/* Copy out the part array from the record. */ -/* -------------------------------------------------------------------- */ - memcpy( psShape->panPartStart, psSHP->pabyRec + 44 + 8, 4 * nParts ); - for( i = 0; i < nParts; i++ ) - { - if( bBigEndian ) SwapWord( 4, psShape->panPartStart+i ); - } - - nOffset = 44 + 8 + 4*nParts; - -/* -------------------------------------------------------------------- */ -/* If this is a multipatch, we will also have parts types. */ -/* -------------------------------------------------------------------- */ - if( psShape->nSHPType == ossim_SHPT_MULTIPATCH ) - { - memcpy( psShape->panPartType, psSHP->pabyRec + nOffset, 4*nParts ); - for( i = 0; i < nParts; i++ ) - { - if( bBigEndian ) SwapWord( 4, psShape->panPartType+i ); - } - - nOffset += 4*nParts; - } - -/* -------------------------------------------------------------------- */ -/* Copy out the vertices from the record. */ -/* -------------------------------------------------------------------- */ - for( i = 0; i < nPoints; i++ ) - { - memcpy(psShape->padfX + i, - psSHP->pabyRec + nOffset + i * 16, - 8 ); - - memcpy(psShape->padfY + i, - psSHP->pabyRec + nOffset + i * 16 + 8, - 8 ); - - if( bBigEndian ) SwapWord( 8, psShape->padfX + i ); - if( bBigEndian ) SwapWord( 8, psShape->padfY + i ); - } - - nOffset += 16*nPoints; - -/* -------------------------------------------------------------------- */ -/* If we have a Z coordinate, collect that now. */ -/* -------------------------------------------------------------------- */ - if( psShape->nSHPType == ossim_SHPT_POLYGONZ - || psShape->nSHPType == ossim_SHPT_ARCZ - || psShape->nSHPType == ossim_SHPT_MULTIPATCH ) - { - memcpy( &(psShape->dfZMin), psSHP->pabyRec + nOffset, 8 ); - memcpy( &(psShape->dfZMax), psSHP->pabyRec + nOffset + 8, 8 ); - - if( bBigEndian ) SwapWord( 8, &(psShape->dfZMin) ); - if( bBigEndian ) SwapWord( 8, &(psShape->dfZMax) ); - - for( i = 0; i < nPoints; i++ ) - { - memcpy( psShape->padfZ + i, - psSHP->pabyRec + nOffset + 16 + i*8, 8 ); - if( bBigEndian ) SwapWord( 8, psShape->padfZ + i ); - } - - nOffset += 16 + 8*nPoints; - } - -/* -------------------------------------------------------------------- */ -/* If we have a M measure value, then read it now. We assume */ -/* that the measure can be present for any shape if the size is */ -/* big enough, but really it will only occur for the Z shapes */ -/* (options), and the M shapes. */ -/* -------------------------------------------------------------------- */ - if( psSHP->panRecSize[hEntity]+8 >= nOffset + 16 + 8*nPoints ) - { - memcpy( &(psShape->dfMMin), psSHP->pabyRec + nOffset, 8 ); - memcpy( &(psShape->dfMMax), psSHP->pabyRec + nOffset + 8, 8 ); - - if( bBigEndian ) SwapWord( 8, &(psShape->dfMMin) ); - if( bBigEndian ) SwapWord( 8, &(psShape->dfMMax) ); - - for( i = 0; i < nPoints; i++ ) - { - memcpy( psShape->padfM + i, - psSHP->pabyRec + nOffset + 16 + i*8, 8 ); - if( bBigEndian ) SwapWord( 8, psShape->padfM + i ); - } - } - - } - -/* ==================================================================== */ -/* Extract vertices for a MultiPoint. */ -/* ==================================================================== */ - else if( psShape->nSHPType == ossim_SHPT_MULTIPOINT - || psShape->nSHPType == ossim_SHPT_MULTIPOINTM - || psShape->nSHPType == ossim_SHPT_MULTIPOINTZ ) - { - int32 nPoints; - int i, nOffset; - - memcpy( &nPoints, psSHP->pabyRec + 44, 4 ); - if( bBigEndian ) SwapWord( 4, &nPoints ); - - psShape->nVertices = nPoints; - psShape->padfX = (double *) calloc(nPoints,sizeof(double)); - psShape->padfY = (double *) calloc(nPoints,sizeof(double)); - psShape->padfZ = (double *) calloc(nPoints,sizeof(double)); - psShape->padfM = (double *) calloc(nPoints,sizeof(double)); - - for( i = 0; i < nPoints; i++ ) - { - memcpy(psShape->padfX+i, psSHP->pabyRec + 48 + 16 * i, 8 ); - memcpy(psShape->padfY+i, psSHP->pabyRec + 48 + 16 * i + 8, 8 ); - - if( bBigEndian ) SwapWord( 8, psShape->padfX + i ); - if( bBigEndian ) SwapWord( 8, psShape->padfY + i ); - } - - nOffset = 48 + 16*nPoints; - -/* -------------------------------------------------------------------- */ -/* Get the X/Y bounds. */ -/* -------------------------------------------------------------------- */ - memcpy( &(psShape->dfXMin), psSHP->pabyRec + 8 + 4, 8 ); - memcpy( &(psShape->dfYMin), psSHP->pabyRec + 8 + 12, 8 ); - memcpy( &(psShape->dfXMax), psSHP->pabyRec + 8 + 20, 8 ); - memcpy( &(psShape->dfYMax), psSHP->pabyRec + 8 + 28, 8 ); - - if( bBigEndian ) SwapWord( 8, &(psShape->dfXMin) ); - if( bBigEndian ) SwapWord( 8, &(psShape->dfYMin) ); - if( bBigEndian ) SwapWord( 8, &(psShape->dfXMax) ); - if( bBigEndian ) SwapWord( 8, &(psShape->dfYMax) ); - -/* -------------------------------------------------------------------- */ -/* If we have a Z coordinate, collect that now. */ -/* -------------------------------------------------------------------- */ - if( psShape->nSHPType == ossim_SHPT_MULTIPOINTZ ) - { - memcpy( &(psShape->dfZMin), psSHP->pabyRec + nOffset, 8 ); - memcpy( &(psShape->dfZMax), psSHP->pabyRec + nOffset + 8, 8 ); - - if( bBigEndian ) SwapWord( 8, &(psShape->dfZMin) ); - if( bBigEndian ) SwapWord( 8, &(psShape->dfZMax) ); - - for( i = 0; i < nPoints; i++ ) - { - memcpy( psShape->padfZ + i, - psSHP->pabyRec + nOffset + 16 + i*8, 8 ); - if( bBigEndian ) SwapWord( 8, psShape->padfZ + i ); - } - - nOffset += 16 + 8*nPoints; - } - -/* -------------------------------------------------------------------- */ -/* If we have a M measure value, then read it now. We assume */ -/* that the measure can be present for any shape if the size is */ -/* big enough, but really it will only occur for the Z shapes */ -/* (options), and the M shapes. */ -/* -------------------------------------------------------------------- */ - if( psSHP->panRecSize[hEntity]+8 >= nOffset + 16 + 8*nPoints ) - { - memcpy( &(psShape->dfMMin), psSHP->pabyRec + nOffset, 8 ); - memcpy( &(psShape->dfMMax), psSHP->pabyRec + nOffset + 8, 8 ); - - if( bBigEndian ) SwapWord( 8, &(psShape->dfMMin) ); - if( bBigEndian ) SwapWord( 8, &(psShape->dfMMax) ); - - for( i = 0; i < nPoints; i++ ) - { - memcpy( psShape->padfM + i, - psSHP->pabyRec + nOffset + 16 + i*8, 8 ); - if( bBigEndian ) SwapWord( 8, psShape->padfM + i ); - } - } - } - -/* ==================================================================== */ -/* Extract vertices for a point. */ -/* ==================================================================== */ - else if( psShape->nSHPType == ossim_SHPT_POINT - || psShape->nSHPType == ossim_SHPT_POINTM - || psShape->nSHPType == ossim_SHPT_POINTZ ) - { - int nOffset; - - psShape->nVertices = 1; - psShape->padfX = (double *) calloc(1,sizeof(double)); - psShape->padfY = (double *) calloc(1,sizeof(double)); - psShape->padfZ = (double *) calloc(1,sizeof(double)); - psShape->padfM = (double *) calloc(1,sizeof(double)); - - memcpy( psShape->padfX, psSHP->pabyRec + 12, 8 ); - memcpy( psShape->padfY, psSHP->pabyRec + 20, 8 ); - - if( bBigEndian ) SwapWord( 8, psShape->padfX ); - if( bBigEndian ) SwapWord( 8, psShape->padfY ); - - nOffset = 20 + 8; - -/* -------------------------------------------------------------------- */ -/* If we have a Z coordinate, collect that now. */ -/* -------------------------------------------------------------------- */ - if( psShape->nSHPType == ossim_SHPT_POINTZ ) - { - memcpy( psShape->padfZ, psSHP->pabyRec + nOffset, 8 ); - - if( bBigEndian ) SwapWord( 8, psShape->padfZ ); - - nOffset += 8; - } - -/* -------------------------------------------------------------------- */ -/* If we have a M measure value, then read it now. We assume */ -/* that the measure can be present for any shape if the size is */ -/* big enough, but really it will only occur for the Z shapes */ -/* (options), and the M shapes. */ -/* -------------------------------------------------------------------- */ - if( psSHP->panRecSize[hEntity]+8 >= nOffset + 8 ) - { - memcpy( psShape->padfM, psSHP->pabyRec + nOffset, 8 ); - - if( bBigEndian ) SwapWord( 8, psShape->padfM ); - } - -/* -------------------------------------------------------------------- */ -/* Since no extents are supplied in the record, we will apply */ -/* them from the single vertex. */ -/* -------------------------------------------------------------------- */ - psShape->dfXMin = psShape->dfXMax = psShape->padfX[0]; - psShape->dfYMin = psShape->dfYMax = psShape->padfY[0]; - psShape->dfZMin = psShape->dfZMax = psShape->padfZ[0]; - psShape->dfMMin = psShape->dfMMax = psShape->padfM[0]; - } - - return( psShape ); -} - -/************************************************************************/ -/* ossim_SHPTypeName() */ -/************************************************************************/ - -const char ossim_SHPAPI_CALL1(*) - ossim_SHPTypeName( int nSHPType ) - -{ - switch( nSHPType ) - { - case ossim_SHPT_NULL: - return "NullShape"; - - case ossim_SHPT_POINT: - return "Point"; - - case ossim_SHPT_ARC: - return "Arc"; - - case ossim_SHPT_POLYGON: - return "Polygon"; - - case ossim_SHPT_MULTIPOINT: - return "MultiPoint"; - - case ossim_SHPT_POINTZ: - return "PointZ"; - - case ossim_SHPT_ARCZ: - return "ArcZ"; - - case ossim_SHPT_POLYGONZ: - return "PolygonZ"; - - case ossim_SHPT_MULTIPOINTZ: - return "MultiPointZ"; - - case ossim_SHPT_POINTM: - return "PointM"; - - case ossim_SHPT_ARCM: - return "ArcM"; - - case ossim_SHPT_POLYGONM: - return "PolygonM"; - - case ossim_SHPT_MULTIPOINTM: - return "MultiPointM"; - - case ossim_SHPT_MULTIPATCH: - return "MultiPatch"; - - default: - return "UnknownShapeType"; - } -} - -/************************************************************************/ -/* ossim_SHPPartTypeName() */ -/************************************************************************/ - -const char ossim_SHPAPI_CALL1(*) - ossim_SHPPartTypeName( int nPartType ) - -{ - switch( nPartType ) - { - case ossim_SHPP_TRISTRIP: - return "TriangleStrip"; - - case ossim_SHPP_TRIFAN: - return "TriangleFan"; - - case ossim_SHPP_OUTERRING: - return "OuterRing"; - - case ossim_SHPP_INNERRING: - return "InnerRing"; - - case ossim_SHPP_FIRSTRING: - return "FirstRing"; - - case ossim_SHPP_RING: - return "Ring"; - - default: - return "UnknownPartType"; - } -} - -/************************************************************************/ -/* ossim_SHPDestroyObject() */ -/************************************************************************/ - -void ossim_SHPAPI_CALL - ossim_SHPDestroyObject( ossim_SHPObject * psShape ) - -{ - if( psShape == NULL ) - return; - - if( psShape->padfX != NULL ) - free( psShape->padfX ); - if( psShape->padfY != NULL ) - free( psShape->padfY ); - if( psShape->padfZ != NULL ) - free( psShape->padfZ ); - if( psShape->padfM != NULL ) - free( psShape->padfM ); - - if( psShape->panPartStart != NULL ) - free( psShape->panPartStart ); - if( psShape->panPartType != NULL ) - free( psShape->panPartType ); - - free( psShape ); -} - -/************************************************************************/ -/* ossim_SHPRewindObject() */ -/* */ -/* Reset the winding of polygon objects to adhere to the */ -/* specification. */ -/************************************************************************/ - -int ossim_SHPAPI_CALL - ossim_SHPRewindObject( ossim_SHPHandle hSHP, ossim_SHPObject * psObject ) - -{ - int iOpRing, bAltered = 0; - -/* -------------------------------------------------------------------- */ -/* Do nothing if this is not a polygon object. */ -/* -------------------------------------------------------------------- */ - if( psObject->nSHPType != ossim_SHPT_POLYGON - && psObject->nSHPType != ossim_SHPT_POLYGONZ - && psObject->nSHPType != ossim_SHPT_POLYGONM ) - return 0; - - if( psObject->nVertices == 0 || psObject->nParts == 0 ) - return 0; - -/* -------------------------------------------------------------------- */ -/* Process each of the rings. */ -/* -------------------------------------------------------------------- */ - for( iOpRing = 0; iOpRing < psObject->nParts; iOpRing++ ) - { - int bInner, iVert, nVertCount, nVertStart, iCheckRing; - double dfSum, dfTestX, dfTestY; - -/* -------------------------------------------------------------------- */ -/* Determine if this ring is an inner ring or an outer ring */ -/* relative to all the other rings. For now we assume the */ -/* first ring is outer and all others are inner, but eventually */ -/* we need to fix this to handle multiple island polygons and */ -/* unordered sets of rings. */ -/* -------------------------------------------------------------------- */ - dfTestX = psObject->padfX[psObject->panPartStart[iOpRing]]; - dfTestY = psObject->padfY[psObject->panPartStart[iOpRing]]; - - bInner = FALSE; - for( iCheckRing = 0; iCheckRing < psObject->nParts; iCheckRing++ ) - { - int iEdge; - - if( iCheckRing == iOpRing ) - continue; - - nVertStart = psObject->panPartStart[iCheckRing]; - - if( iCheckRing == psObject->nParts-1 ) - nVertCount = psObject->nVertices - - psObject->panPartStart[iCheckRing]; - else - nVertCount = psObject->panPartStart[iCheckRing+1] - - psObject->panPartStart[iCheckRing]; - - for( iEdge = 0; iEdge < nVertCount; iEdge++ ) - { - int iNext; - - if( iEdge < nVertCount-1 ) - iNext = iEdge+1; - else - iNext = 0; - - if( (psObject->padfY[iEdge+nVertStart] < dfTestY - && psObject->padfY[iNext+nVertStart] >= dfTestY) - || (psObject->padfY[iNext+nVertStart] < dfTestY - && psObject->padfY[iEdge+nVertStart] >= dfTestY) ) - { - if( psObject->padfX[iEdge+nVertStart] - + (dfTestY - psObject->padfY[iEdge+nVertStart]) - / (psObject->padfY[iNext+nVertStart] - - psObject->padfY[iEdge+nVertStart]) - * (psObject->padfX[iNext+nVertStart] - - psObject->padfX[iEdge+nVertStart]) < dfTestX ) - bInner = !bInner; - } - } - } - -/* -------------------------------------------------------------------- */ -/* Determine the current order of this ring so we will know if */ -/* it has to be reversed. */ -/* -------------------------------------------------------------------- */ - nVertStart = psObject->panPartStart[iOpRing]; - - if( iOpRing == psObject->nParts-1 ) - nVertCount = psObject->nVertices - psObject->panPartStart[iOpRing]; - else - nVertCount = psObject->panPartStart[iOpRing+1] - - psObject->panPartStart[iOpRing]; - - dfSum = 0.0; - for( iVert = nVertStart; iVert < nVertStart+nVertCount-1; iVert++ ) - { - dfSum += psObject->padfX[iVert] * psObject->padfY[iVert+1] - - psObject->padfY[iVert] * psObject->padfX[iVert+1]; - } - - dfSum += psObject->padfX[iVert] * psObject->padfY[nVertStart] - - psObject->padfY[iVert] * psObject->padfX[nVertStart]; - -/* -------------------------------------------------------------------- */ -/* Reverse if necessary. */ -/* -------------------------------------------------------------------- */ - if( (dfSum < 0.0 && bInner) || (dfSum > 0.0 && !bInner) ) - { - int i; - - bAltered++; - for( i = 0; i < nVertCount/2; i++ ) - { - double dfSaved; - - /* Swap X */ - dfSaved = psObject->padfX[nVertStart+i]; - psObject->padfX[nVertStart+i] = - psObject->padfX[nVertStart+nVertCount-i-1]; - psObject->padfX[nVertStart+nVertCount-i-1] = dfSaved; - - /* Swap Y */ - dfSaved = psObject->padfY[nVertStart+i]; - psObject->padfY[nVertStart+i] = - psObject->padfY[nVertStart+nVertCount-i-1]; - psObject->padfY[nVertStart+nVertCount-i-1] = dfSaved; - - /* Swap Z */ - if( psObject->padfZ ) - { - dfSaved = psObject->padfZ[nVertStart+i]; - psObject->padfZ[nVertStart+i] = - psObject->padfZ[nVertStart+nVertCount-i-1]; - psObject->padfZ[nVertStart+nVertCount-i-1] = dfSaved; - } - - /* Swap M */ - if( psObject->padfM ) - { - dfSaved = psObject->padfM[nVertStart+i]; - psObject->padfM[nVertStart+i] = - psObject->padfM[nVertStart+nVertCount-i-1]; - psObject->padfM[nVertStart+nVertCount-i-1] = dfSaved; - } - } - } - } - - return bAltered; -} diff --git a/Utilities/otbossim/src/ossim/vec/shptree.c b/Utilities/otbossim/src/ossim/vec/shptree.c deleted file mode 100644 index 00f49cf92b..0000000000 --- a/Utilities/otbossim/src/ossim/vec/shptree.c +++ /dev/null @@ -1,986 +0,0 @@ -/****************************************************************************** - * $Id: shptree.c 9094 2006-06-13 19:12:40Z dburken $ - * - * Project: Shapelib - * Purpose: Implementation of quadtree building and searching functions. - * Author: Frank Warmerdam, warmerdam@pobox.com - * - ****************************************************************************** - * Copyright (c) 1999, Frank Warmerdam - * - * This software is available under the following "MIT Style" license, - * or at the option of the licensee under the LGPL (see LICENSE.LGPL). This - * option is discussed in more detail in shapelib.html. - * - * -- - * - * 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. - ****************************************************************************** - * - * $Log$ - * Revision 1.6 2006/06/13 19:11:33 dburken - * Global include path change. - * - * Revision 1.5 2005/10/08 12:57:26 gpotts - * Added adiitional patches - * - * Revision 1.10 2005/01/03 22:30:13 fwarmerdam - * added support for saved quadtrees - * - * Revision 1.9 2003/01/28 15:53:41 warmerda - * Avoid build warnings. - * - * Revision 1.8 2002/05/07 13:07:45 warmerda - * use qsort() - patch from Bernhard Herzog - * - * Revision 1.7 2002/01/15 14:36:07 warmerda - * updated email address - * - * Revision 1.6 2001/05/23 13:36:52 warmerda - * added use of ossim_SHPAPI_CALL - * - * Revision 1.5 1999/11/05 14:12:05 warmerda - * updated license terms - * - * Revision 1.4 1999/06/02 18:24:21 warmerda - * added trimming code - * - * Revision 1.3 1999/06/02 17:56:12 warmerda - * added quad'' subnode support for trees - * - * Revision 1.2 1999/05/18 19:11:11 warmerda - * Added example searching capability - * - * Revision 1.1 1999/05/18 17:49:20 warmerda - * New - * - */ - -#include <ossim/vec/shapefil.h> - -#include <math.h> -#include <assert.h> -#include <stdlib.h> -#include <string.h> - -ossim_SHP_CVSID("$Id: shptree.c 9094 2006-06-13 19:12:40Z dburken $") - -#ifndef TRUE -# define TRUE 1 -# define FALSE 0 -#endif - -static int bBigEndian = 0; - - -/* -------------------------------------------------------------------- */ -/* If the following is 0.5, nodes will be split in half. If it */ -/* is 0.6 then each subnode will contain 60% of the parent */ -/* node, with 20% representing overlap. This can be help to */ -/* prevent small objects on a boundary from shifting too high */ -/* up the tree. */ -/* -------------------------------------------------------------------- */ - -#define ossim_SHP_SPLIT_RATIO 0.55 - -/************************************************************************/ -/* SfRealloc() */ -/* */ -/* A realloc cover function that will access a NULL pointer as */ -/* a valid input. */ -/************************************************************************/ - -static void * SfRealloc( void * pMem, int nNewSize ) - -{ - if( pMem == NULL ) - return( (void *) malloc(nNewSize) ); - else - return( (void *) realloc(pMem,nNewSize) ); -} - -/************************************************************************/ -/* ossim_SHPTreeNodeInit() */ -/* */ -/* Initialize a tree node. */ -/************************************************************************/ - -static ossim_SHPTreeNode *ossim_SHPTreeNodeCreate( double * padfBoundsMin, - double * padfBoundsMax ) - -{ - ossim_SHPTreeNode *psTreeNode; - - psTreeNode = (ossim_SHPTreeNode *) malloc(sizeof(ossim_SHPTreeNode)); - - psTreeNode->nShapeCount = 0; - psTreeNode->panShapeIds = NULL; - psTreeNode->papsShapeObj = NULL; - - psTreeNode->nSubNodes = 0; - - if( padfBoundsMin != NULL ) - memcpy( psTreeNode->adfBoundsMin, padfBoundsMin, sizeof(double) * 4 ); - - if( padfBoundsMax != NULL ) - memcpy( psTreeNode->adfBoundsMax, padfBoundsMax, sizeof(double) * 4 ); - - return psTreeNode; -} - - -/************************************************************************/ -/* ossim_SHPCreateTree() */ -/************************************************************************/ - -ossim_SHPTree ossim_SHPAPI_CALL1(*) - ossim_SHPCreateTree( ossim_SHPHandle hSHP, int nDimension, int nMaxDepth, - double *padfBoundsMin, double *padfBoundsMax ) - -{ - ossim_SHPTree *psTree; - - if( padfBoundsMin == NULL && hSHP == NULL ) - return NULL; - -/* -------------------------------------------------------------------- */ -/* Allocate the tree object */ -/* -------------------------------------------------------------------- */ - psTree = (ossim_SHPTree *) malloc(sizeof(ossim_SHPTree)); - - psTree->hSHP = hSHP; - psTree->nMaxDepth = nMaxDepth; - psTree->nDimension = nDimension; - psTree->nTotalCount = 0; - -/* -------------------------------------------------------------------- */ -/* If no max depth was defined, try to select a reasonable one */ -/* that implies approximately 8 shapes per node. */ -/* -------------------------------------------------------------------- */ - if( psTree->nMaxDepth == 0 && hSHP != NULL ) - { - int nMaxNodeCount = 1; - int nShapeCount; - - ossim_SHPGetInfo( hSHP, &nShapeCount, NULL, NULL, NULL ); - while( nMaxNodeCount*4 < nShapeCount ) - { - psTree->nMaxDepth += 1; - nMaxNodeCount = nMaxNodeCount * 2; - } - } - -/* -------------------------------------------------------------------- */ -/* Allocate the root node. */ -/* -------------------------------------------------------------------- */ - psTree->psRoot = ossim_SHPTreeNodeCreate( padfBoundsMin, padfBoundsMax ); - -/* -------------------------------------------------------------------- */ -/* Assign the bounds to the root node. If none are passed in, */ -/* use the bounds of the provided file otherwise the create */ -/* function will have already set the bounds. */ -/* -------------------------------------------------------------------- */ - if( padfBoundsMin == NULL ) - { - ossim_SHPGetInfo( hSHP, NULL, NULL, - psTree->psRoot->adfBoundsMin, - psTree->psRoot->adfBoundsMax ); - } - -/* -------------------------------------------------------------------- */ -/* If we have a file, insert all it's shapes into the tree. */ -/* -------------------------------------------------------------------- */ - if( hSHP != NULL ) - { - int iShape, nShapeCount; - - ossim_SHPGetInfo( hSHP, &nShapeCount, NULL, NULL, NULL ); - - for( iShape = 0; iShape < nShapeCount; iShape++ ) - { - ossim_SHPObject *psShape; - - psShape = ossim_SHPReadObject( hSHP, iShape ); - ossim_SHPTreeAddShapeId( psTree, psShape ); - ossim_SHPDestroyObject( psShape ); - } - } - - return psTree; -} - -/************************************************************************/ -/* ossim_SHPDestroyTreeNode() */ -/************************************************************************/ - -static void ossim_SHPDestroyTreeNode( ossim_SHPTreeNode * psTreeNode ) - -{ - int i; - - for( i = 0; i < psTreeNode->nSubNodes; i++ ) - { - if( psTreeNode->apsSubNode[i] != NULL ) - ossim_SHPDestroyTreeNode( psTreeNode->apsSubNode[i] ); - } - - if( psTreeNode->panShapeIds != NULL ) - free( psTreeNode->panShapeIds ); - - if( psTreeNode->papsShapeObj != NULL ) - { - for( i = 0; i < psTreeNode->nShapeCount; i++ ) - { - if( psTreeNode->papsShapeObj[i] != NULL ) - ossim_SHPDestroyObject( psTreeNode->papsShapeObj[i] ); - } - - free( psTreeNode->papsShapeObj ); - } - - free( psTreeNode ); -} - -/************************************************************************/ -/* ossim_SHPDestroyTree() */ -/************************************************************************/ - -void ossim_SHPAPI_CALL - ossim_SHPDestroyTree( ossim_SHPTree * psTree ) - -{ - ossim_SHPDestroyTreeNode( psTree->psRoot ); - free( psTree ); -} - -/************************************************************************/ -/* ossim_SHPCheckBoundsOverlap() */ -/* */ -/* Do the given boxes overlap at all? */ -/************************************************************************/ - -int ossim_SHPAPI_CALL - ossim_SHPCheckBoundsOverlap( double * padfBox1Min, double * padfBox1Max, - double * padfBox2Min, double * padfBox2Max, - int nDimension ) - -{ - int iDim; - - for( iDim = 0; iDim < nDimension; iDim++ ) - { - if( padfBox2Max[iDim] < padfBox1Min[iDim] ) - return FALSE; - - if( padfBox1Max[iDim] < padfBox2Min[iDim] ) - return FALSE; - } - - return TRUE; -} - -/************************************************************************/ -/* ossim_SHPCheckObjectContained() */ -/* */ -/* Does the given shape fit within the indicated extents? */ -/************************************************************************/ - -static int ossim_SHPCheckObjectContained( ossim_SHPObject * psObject, int nDimension, - double * padfBoundsMin, double * padfBoundsMax ) - -{ - if( psObject->dfXMin < padfBoundsMin[0] - || psObject->dfXMax > padfBoundsMax[0] ) - return FALSE; - - if( psObject->dfYMin < padfBoundsMin[1] - || psObject->dfYMax > padfBoundsMax[1] ) - return FALSE; - - if( nDimension == 2 ) - return TRUE; - - if( psObject->dfZMin < padfBoundsMin[2] - || psObject->dfZMax < padfBoundsMax[2] ) - return FALSE; - - if( nDimension == 3 ) - return TRUE; - - if( psObject->dfMMin < padfBoundsMin[3] - || psObject->dfMMax < padfBoundsMax[3] ) - return FALSE; - - return TRUE; -} - -/************************************************************************/ -/* ossim_SHPTreeSplitBounds() */ -/* */ -/* Split a region into two subregion evenly, cutting along the */ -/* longest dimension. */ -/************************************************************************/ - -void ossim_SHPAPI_CALL - ossim_SHPTreeSplitBounds( double *padfBoundsMinIn, double *padfBoundsMaxIn, - double *padfBoundsMin1, double * padfBoundsMax1, - double *padfBoundsMin2, double * padfBoundsMax2 ) - -{ -/* -------------------------------------------------------------------- */ -/* The output bounds will be very similar to the input bounds, */ -/* so just copy over to start. */ -/* -------------------------------------------------------------------- */ - memcpy( padfBoundsMin1, padfBoundsMinIn, sizeof(double) * 4 ); - memcpy( padfBoundsMax1, padfBoundsMaxIn, sizeof(double) * 4 ); - memcpy( padfBoundsMin2, padfBoundsMinIn, sizeof(double) * 4 ); - memcpy( padfBoundsMax2, padfBoundsMaxIn, sizeof(double) * 4 ); - -/* -------------------------------------------------------------------- */ -/* Split in X direction. */ -/* -------------------------------------------------------------------- */ - if( (padfBoundsMaxIn[0] - padfBoundsMinIn[0]) - > (padfBoundsMaxIn[1] - padfBoundsMinIn[1]) ) - { - double dfRange = padfBoundsMaxIn[0] - padfBoundsMinIn[0]; - - padfBoundsMax1[0] = padfBoundsMinIn[0] + dfRange * ossim_SHP_SPLIT_RATIO; - padfBoundsMin2[0] = padfBoundsMaxIn[0] - dfRange * ossim_SHP_SPLIT_RATIO; - } - -/* -------------------------------------------------------------------- */ -/* Otherwise split in Y direction. */ -/* -------------------------------------------------------------------- */ - else - { - double dfRange = padfBoundsMaxIn[1] - padfBoundsMinIn[1]; - - padfBoundsMax1[1] = padfBoundsMinIn[1] + dfRange * ossim_SHP_SPLIT_RATIO; - padfBoundsMin2[1] = padfBoundsMaxIn[1] - dfRange * ossim_SHP_SPLIT_RATIO; - } -} - -/************************************************************************/ -/* ossim_SHPTreeNodeAddShapeId() */ -/************************************************************************/ - -static int - ossim_SHPTreeNodeAddShapeId( ossim_SHPTreeNode * psTreeNode, ossim_SHPObject * psObject, - int nMaxDepth, int nDimension ) - -{ - int i; - -/* -------------------------------------------------------------------- */ -/* If there are subnodes, then consider wiether this object */ -/* will fit in them. */ -/* -------------------------------------------------------------------- */ - if( nMaxDepth > 1 && psTreeNode->nSubNodes > 0 ) - { - for( i = 0; i < psTreeNode->nSubNodes; i++ ) - { - if( ossim_SHPCheckObjectContained(psObject, nDimension, - psTreeNode->apsSubNode[i]->adfBoundsMin, - psTreeNode->apsSubNode[i]->adfBoundsMax)) - { - return ossim_SHPTreeNodeAddShapeId( psTreeNode->apsSubNode[i], - psObject, nMaxDepth-1, - nDimension ); - } - } - } - -/* -------------------------------------------------------------------- */ -/* Otherwise, consider creating four subnodes if could fit into */ -/* them, and adding to the appropriate subnode. */ -/* -------------------------------------------------------------------- */ -#if MAX_SUBNODE == 4 - else if( nMaxDepth > 1 && psTreeNode->nSubNodes == 0 ) - { - double adfBoundsMinH1[4], adfBoundsMaxH1[4]; - double adfBoundsMinH2[4], adfBoundsMaxH2[4]; - double adfBoundsMin1[4], adfBoundsMax1[4]; - double adfBoundsMin2[4], adfBoundsMax2[4]; - double adfBoundsMin3[4], adfBoundsMax3[4]; - double adfBoundsMin4[4], adfBoundsMax4[4]; - - ossim_SHPTreeSplitBounds( psTreeNode->adfBoundsMin, - psTreeNode->adfBoundsMax, - adfBoundsMinH1, adfBoundsMaxH1, - adfBoundsMinH2, adfBoundsMaxH2 ); - - ossim_SHPTreeSplitBounds( adfBoundsMinH1, adfBoundsMaxH1, - adfBoundsMin1, adfBoundsMax1, - adfBoundsMin2, adfBoundsMax2 ); - - ossim_SHPTreeSplitBounds( adfBoundsMinH2, adfBoundsMaxH2, - adfBoundsMin3, adfBoundsMax3, - adfBoundsMin4, adfBoundsMax4 ); - - if( ossim_SHPCheckObjectContained(psObject, nDimension, - adfBoundsMin1, adfBoundsMax1) - || ossim_SHPCheckObjectContained(psObject, nDimension, - adfBoundsMin2, adfBoundsMax2) - || ossim_SHPCheckObjectContained(psObject, nDimension, - adfBoundsMin3, adfBoundsMax3) - || ossim_SHPCheckObjectContained(psObject, nDimension, - adfBoundsMin4, adfBoundsMax4) ) - { - psTreeNode->nSubNodes = 4; - psTreeNode->apsSubNode[0] = ossim_SHPTreeNodeCreate( adfBoundsMin1, - adfBoundsMax1 ); - psTreeNode->apsSubNode[1] = ossim_SHPTreeNodeCreate( adfBoundsMin2, - adfBoundsMax2 ); - psTreeNode->apsSubNode[2] = ossim_SHPTreeNodeCreate( adfBoundsMin3, - adfBoundsMax3 ); - psTreeNode->apsSubNode[3] = ossim_SHPTreeNodeCreate( adfBoundsMin4, - adfBoundsMax4 ); - - /* recurse back on this node now that it has subnodes */ - return( ossim_SHPTreeNodeAddShapeId( psTreeNode, psObject, - nMaxDepth, nDimension ) ); - } - } -#endif /* MAX_SUBNODE == 4 */ - -/* -------------------------------------------------------------------- */ -/* Otherwise, consider creating two subnodes if could fit into */ -/* them, and adding to the appropriate subnode. */ -/* -------------------------------------------------------------------- */ -#if MAX_SUBNODE == 2 - else if( nMaxDepth > 1 && psTreeNode->nSubNodes == 0 ) - { - double adfBoundsMin1[4], adfBoundsMax1[4]; - double adfBoundsMin2[4], adfBoundsMax2[4]; - - ossim_SHPTreeSplitBounds( psTreeNode->adfBoundsMin, psTreeNode->adfBoundsMax, - adfBoundsMin1, adfBoundsMax1, - adfBoundsMin2, adfBoundsMax2 ); - - if( ossim_SHPCheckObjectContained(psObject, nDimension, - adfBoundsMin1, adfBoundsMax1)) - { - psTreeNode->nSubNodes = 2; - psTreeNode->apsSubNode[0] = ossim_SHPTreeNodeCreate( adfBoundsMin1, - adfBoundsMax1 ); - psTreeNode->apsSubNode[1] = ossim_SHPTreeNodeCreate( adfBoundsMin2, - adfBoundsMax2 ); - - return( ossim_SHPTreeNodeAddShapeId( psTreeNode->apsSubNode[0], psObject, - nMaxDepth - 1, nDimension ) ); - } - else if( ossim_SHPCheckObjectContained(psObject, nDimension, - adfBoundsMin2, adfBoundsMax2) ) - { - psTreeNode->nSubNodes = 2; - psTreeNode->apsSubNode[0] = ossim_SHPTreeNodeCreate( adfBoundsMin1, - adfBoundsMax1 ); - psTreeNode->apsSubNode[1] = ossim_SHPTreeNodeCreate( adfBoundsMin2, - adfBoundsMax2 ); - - return( ossim_SHPTreeNodeAddShapeId( psTreeNode->apsSubNode[1], psObject, - nMaxDepth - 1, nDimension ) ); - } - } -#endif /* MAX_SUBNODE == 2 */ - -/* -------------------------------------------------------------------- */ -/* If none of that worked, just add it to this nodes list. */ -/* -------------------------------------------------------------------- */ - psTreeNode->nShapeCount++; - - psTreeNode->panShapeIds = (int *) - SfRealloc( psTreeNode->panShapeIds, - sizeof(int) * psTreeNode->nShapeCount ); - psTreeNode->panShapeIds[psTreeNode->nShapeCount-1] = psObject->nShapeId; - - if( psTreeNode->papsShapeObj != NULL ) - { - psTreeNode->papsShapeObj = (ossim_SHPObject **) - SfRealloc( psTreeNode->papsShapeObj, - sizeof(void *) * psTreeNode->nShapeCount ); - psTreeNode->papsShapeObj[psTreeNode->nShapeCount-1] = NULL; - } - - return TRUE; -} - -/************************************************************************/ -/* ossim_SHPTreeAddShapeId() */ -/* */ -/* Add a shape to the tree, but don't keep a pointer to the */ -/* object data, just keep the shapeid. */ -/************************************************************************/ - -int ossim_SHPAPI_CALL - ossim_SHPTreeAddShapeId( ossim_SHPTree * psTree, ossim_SHPObject * psObject ) - -{ - psTree->nTotalCount++; - - return( ossim_SHPTreeNodeAddShapeId( psTree->psRoot, psObject, - psTree->nMaxDepth, psTree->nDimension ) ); -} - -/************************************************************************/ -/* ossim_SHPTreeCollectShapesIds() */ -/* */ -/* Work function implementing ossim_SHPTreeFindLikelyShapes() on a */ -/* tree node by tree node basis. */ -/************************************************************************/ - -void ossim_SHPAPI_CALL - ossim_SHPTreeCollectShapeIds( ossim_SHPTree *hTree, ossim_SHPTreeNode * psTreeNode, - double * padfBoundsMin, double * padfBoundsMax, - int * pnShapeCount, int * pnMaxShapes, - int ** ppanShapeList ) - -{ - int i; - -/* -------------------------------------------------------------------- */ -/* Does this node overlap the area of interest at all? If not, */ -/* return without adding to the list at all. */ -/* -------------------------------------------------------------------- */ - if( !ossim_SHPCheckBoundsOverlap( psTreeNode->adfBoundsMin, - psTreeNode->adfBoundsMax, - padfBoundsMin, - padfBoundsMax, - hTree->nDimension ) ) - return; - -/* -------------------------------------------------------------------- */ -/* Grow the list to hold the shapes on this node. */ -/* -------------------------------------------------------------------- */ - if( *pnShapeCount + psTreeNode->nShapeCount > *pnMaxShapes ) - { - *pnMaxShapes = (*pnShapeCount + psTreeNode->nShapeCount) * 2 + 20; - *ppanShapeList = (int *) - SfRealloc(*ppanShapeList,sizeof(int) * *pnMaxShapes); - } - -/* -------------------------------------------------------------------- */ -/* Add the local nodes shapeids to the list. */ -/* -------------------------------------------------------------------- */ - for( i = 0; i < psTreeNode->nShapeCount; i++ ) - { - (*ppanShapeList)[(*pnShapeCount)++] = psTreeNode->panShapeIds[i]; - } - -/* -------------------------------------------------------------------- */ -/* Recurse to subnodes if they exist. */ -/* -------------------------------------------------------------------- */ - for( i = 0; i < psTreeNode->nSubNodes; i++ ) - { - if( psTreeNode->apsSubNode[i] != NULL ) - ossim_SHPTreeCollectShapeIds( hTree, psTreeNode->apsSubNode[i], - padfBoundsMin, padfBoundsMax, - pnShapeCount, pnMaxShapes, - ppanShapeList ); - } -} - -/************************************************************************/ -/* ossim_SHPTreeFindLikelyShapes() */ -/* */ -/* Find all shapes within tree nodes for which the tree node */ -/* bounding box overlaps the search box. The return value is */ -/* an array of shapeids terminated by a -1. The shapeids will */ -/* be in order, as hopefully this will result in faster (more */ -/* sequential) reading from the file. */ -/************************************************************************/ - -/* helper for qsort */ -static int -compare_ints( const void * a, const void * b) -{ - return (*(int*)a) - (*(int*)b); -} - -int ossim_SHPAPI_CALL1(*) - ossim_SHPTreeFindLikelyShapes( ossim_SHPTree * hTree, - double * padfBoundsMin, double * padfBoundsMax, - int * pnShapeCount ) - -{ - int *panShapeList=NULL, nMaxShapes = 0; - -/* -------------------------------------------------------------------- */ -/* Perform the search by recursive descent. */ -/* -------------------------------------------------------------------- */ - *pnShapeCount = 0; - - ossim_SHPTreeCollectShapeIds( hTree, hTree->psRoot, - padfBoundsMin, padfBoundsMax, - pnShapeCount, &nMaxShapes, - &panShapeList ); - -/* -------------------------------------------------------------------- */ -/* Sort the id array */ -/* -------------------------------------------------------------------- */ - - qsort(panShapeList, *pnShapeCount, sizeof(int), compare_ints); - - return panShapeList; -} - -/************************************************************************/ -/* ossim_SHPTreeNodeTrim() */ -/* */ -/* This is the recurve version of ossim_SHPTreeTrimExtraNodes() that */ -/* walks the tree cleaning it up. */ -/************************************************************************/ - -static int ossim_SHPTreeNodeTrim( ossim_SHPTreeNode * psTreeNode ) - -{ - int i; - -/* -------------------------------------------------------------------- */ -/* Trim subtrees, and free subnodes that come back empty. */ -/* -------------------------------------------------------------------- */ - for( i = 0; i < psTreeNode->nSubNodes; i++ ) - { - if( ossim_SHPTreeNodeTrim( psTreeNode->apsSubNode[i] ) ) - { - ossim_SHPDestroyTreeNode( psTreeNode->apsSubNode[i] ); - - psTreeNode->apsSubNode[i] = - psTreeNode->apsSubNode[psTreeNode->nSubNodes-1]; - - psTreeNode->nSubNodes--; - - i--; /* process the new occupant of this subnode entry */ - } - } - -/* -------------------------------------------------------------------- */ -/* We should be trimmed if we have no subnodes, and no shapes. */ -/* -------------------------------------------------------------------- */ - return( psTreeNode->nSubNodes == 0 && psTreeNode->nShapeCount == 0 ); -} - -/************************************************************************/ -/* ossim_SHPTreeTrimExtraNodes() */ -/* */ -/* Trim empty nodes from the tree. Note that we never trim an */ -/* empty root node. */ -/************************************************************************/ - -void ossim_SHPAPI_CALL - ossim_SHPTreeTrimExtraNodes( ossim_SHPTree * hTree ) - -{ - ossim_SHPTreeNodeTrim( hTree->psRoot ); -} - -/************************************************************************/ -/* SwapWord() */ -/* */ -/* Swap a 2, 4 or 8 byte word. */ -/************************************************************************/ - -static void SwapWord( int length, void * wordP ) - -{ - int i; - unsigned char temp; - - for( i=0; i < length/2; i++ ) - { - temp = ((unsigned char *) wordP)[i]; - ((unsigned char *)wordP)[i] = ((unsigned char *) wordP)[length-i-1]; - ((unsigned char *) wordP)[length-i-1] = temp; - } -} - -/************************************************************************/ -/* ossim_SHPSearchDiskTreeNode() */ -/************************************************************************/ - -static int - ossim_SHPSearchDiskTreeNode( FILE *fp, double *padfBoundsMin, double *padfBoundsMax, - int **ppanResultBuffer, int *pnBufferMax, - int *pnResultCount, int bNeedSwap ) - -{ - int i; - int offset; - int numshapes, numsubnodes; - double adfNodeBoundsMin[2], adfNodeBoundsMax[2]; - -/* -------------------------------------------------------------------- */ -/* Read and unswap first part of node info. */ -/* -------------------------------------------------------------------- */ - fread( &offset, 4, 1, fp ); - if ( bNeedSwap ) SwapWord ( 4, &offset ); - - fread( adfNodeBoundsMin, sizeof(double), 2, fp ); - fread( adfNodeBoundsMax, sizeof(double), 2, fp ); - if ( bNeedSwap ) - { - SwapWord( 8, adfNodeBoundsMin + 0 ); - SwapWord( 8, adfNodeBoundsMin + 1 ); - SwapWord( 8, adfNodeBoundsMax + 0 ); - SwapWord( 8, adfNodeBoundsMax + 1 ); - } - - fread( &numshapes, 4, 1, fp ); - if ( bNeedSwap ) SwapWord ( 4, &numshapes ); - -/* -------------------------------------------------------------------- */ -/* If we don't overlap this node at all, we can just fseek() */ -/* pass this node info and all subnodes. */ -/* -------------------------------------------------------------------- */ - if( !ossim_SHPCheckBoundsOverlap( adfNodeBoundsMin, adfNodeBoundsMax, - padfBoundsMin, padfBoundsMax, 2 ) ) - { - offset += numshapes*sizeof(int) + sizeof(int); - fseek(fp, offset, SEEK_CUR); - return TRUE; - } - -/* -------------------------------------------------------------------- */ -/* Add all the shapeids at this node to our list. */ -/* -------------------------------------------------------------------- */ - if(numshapes > 0) - { - if( *pnResultCount + numshapes > *pnBufferMax ) - { - *pnBufferMax = (int) ((*pnResultCount + numshapes + 100) * 1.25); - *ppanResultBuffer = (int *) - SfRealloc( *ppanResultBuffer, *pnBufferMax * sizeof(int) ); - } - - fread( *ppanResultBuffer + *pnResultCount, - sizeof(int), numshapes, fp ); - - if (bNeedSwap ) - { - for( i=0; i<numshapes; i++ ) - SwapWord( 4, *ppanResultBuffer + *pnResultCount + i ); - } - - *pnResultCount += numshapes; - } - -/* -------------------------------------------------------------------- */ -/* Process the subnodes. */ -/* -------------------------------------------------------------------- */ - fread( &numsubnodes, 4, 1, fp ); - if ( bNeedSwap ) SwapWord ( 4, &numsubnodes ); - - for(i=0; i<numsubnodes; i++) - { - if( !ossim_SHPSearchDiskTreeNode( fp, padfBoundsMin, padfBoundsMax, - ppanResultBuffer, pnBufferMax, - pnResultCount, bNeedSwap ) ) - return FALSE; - } - - return TRUE; -} - -/************************************************************************/ -/* ossim_SHPSearchDiskTree() */ -/************************************************************************/ - -int ossim_SHPAPI_CALL1(*) - ossim_SHPSearchDiskTree( FILE *fp, - double *padfBoundsMin, double *padfBoundsMax, - int *pnShapeCount ) - -{ - int i, bNeedSwap, nBufferMax = 0; - unsigned char abyBuf[16]; - int *panResultBuffer = NULL; - - *pnShapeCount = 0; - -/* -------------------------------------------------------------------- */ -/* Establish the byte order on this machine. */ -/* -------------------------------------------------------------------- */ - i = 1; - if( *((unsigned char *) &i) == 1 ) - bBigEndian = FALSE; - else - bBigEndian = TRUE; - -/* -------------------------------------------------------------------- */ -/* Read the header. */ -/* -------------------------------------------------------------------- */ - fseek( fp, 0, SEEK_SET ); - fread( abyBuf, 16, 1, fp ); - - if( memcmp( abyBuf, "SQT", 3 ) != 0 ) - return NULL; - - if( (abyBuf[3] == 2 && bBigEndian) - || (abyBuf[3] == 1 && !bBigEndian) ) - bNeedSwap = FALSE; - else - bNeedSwap = TRUE; - -/* -------------------------------------------------------------------- */ -/* Search through root node and it's decendents. */ -/* -------------------------------------------------------------------- */ - if( !ossim_SHPSearchDiskTreeNode( fp, padfBoundsMin, padfBoundsMax, - &panResultBuffer, &nBufferMax, - pnShapeCount, bNeedSwap ) ) - { - if( panResultBuffer != NULL ) - free( panResultBuffer ); - *pnShapeCount = 0; - return NULL; - } -/* -------------------------------------------------------------------- */ -/* Sort the id array */ -/* -------------------------------------------------------------------- */ - qsort(panResultBuffer, *pnShapeCount, sizeof(int), compare_ints); - - return panResultBuffer; -} - -/************************************************************************/ -/* ossim_SHPGetSubNodeOffset() */ -/* */ -/* Determine how big all the subnodes of this node (and their */ -/* children) will be. This will allow disk based searchers to */ -/* seek past them all efficiently. */ -/************************************************************************/ - -static int ossim_SHPGetSubNodeOffset( ossim_SHPTreeNode *node) -{ - int i; - long offset=0; - - for(i=0; i<node->nSubNodes; i++ ) - { - if(node->apsSubNode[i]) - { - offset += 4*sizeof(double) - + (node->apsSubNode[i]->nShapeCount+3)*sizeof(int); - offset += ossim_SHPGetSubNodeOffset(node->apsSubNode[i]); - } - } - - return(offset); -} - -/************************************************************************/ -/* ossim_SHPWriteTreeNode() */ -/************************************************************************/ - -static void ossim_SHPWriteTreeNode( FILE *fp, ossim_SHPTreeNode *node) -{ - int i,j; - int offset; - unsigned char *pabyRec = NULL; - - offset = ossim_SHPGetSubNodeOffset(node); - - pabyRec = (unsigned char *) - malloc(sizeof(double) * 4 - + (3 * sizeof(int)) + (node->nShapeCount * sizeof(int)) ); - - memcpy( pabyRec, &offset, 4); - - /* minx, miny, maxx, maxy */ - memcpy( pabyRec+ 4, node->adfBoundsMin+0, sizeof(double) ); - memcpy( pabyRec+12, node->adfBoundsMin+1, sizeof(double) ); - memcpy( pabyRec+20, node->adfBoundsMax+0, sizeof(double) ); - memcpy( pabyRec+28, node->adfBoundsMax+1, sizeof(double) ); - - memcpy( pabyRec+36, &node->nShapeCount, 4); - j = node->nShapeCount * sizeof(int); - memcpy( pabyRec+40, node->panShapeIds, j); - memcpy( pabyRec+j+40, &node->nSubNodes, 4); - - fwrite( pabyRec, 44+j, 1, fp ); - free (pabyRec); - - for(i=0; i<node->nSubNodes; i++ ) - { - if(node->apsSubNode[i]) - ossim_SHPWriteTreeNode( fp, node->apsSubNode[i]); - } -} - -/************************************************************************/ -/* ossim_SHPWriteTree() */ -/************************************************************************/ - -int ossim_SHPWriteTree(ossim_SHPTree *tree, const char *filename ) -{ - char signature[4] = "SQT"; - int i; - char abyBuf[32]; - FILE *fp; - -/* -------------------------------------------------------------------- */ -/* Open the output file. */ -/* -------------------------------------------------------------------- */ - fp = fopen(filename, "wb"); - if( fp == NULL ) - { - return FALSE; - } - -/* -------------------------------------------------------------------- */ -/* Establish the byte order on this machine. */ -/* -------------------------------------------------------------------- */ - i = 1; - if( *((unsigned char *) &i) == 1 ) - bBigEndian = FALSE; - else - bBigEndian = TRUE; - -/* -------------------------------------------------------------------- */ -/* Write the header. */ -/* -------------------------------------------------------------------- */ - memcpy( abyBuf+0, signature, 3 ); - - if( bBigEndian ) - abyBuf[3] = 2; /* New MSB */ - else - abyBuf[3] = 1; /* New LSB */ - - abyBuf[4] = 1; /* version */ - abyBuf[5] = 0; /* next 3 reserved */ - abyBuf[6] = 0; - abyBuf[7] = 0; - - fwrite( abyBuf, 8, 1, fp ); - - fwrite( &(tree->nTotalCount), 4, 1, fp ); - - /* write maxdepth */ - - fwrite( &(tree->nMaxDepth), 4, 1, fp ); - -/* -------------------------------------------------------------------- */ -/* Write all the nodes "in order". */ -/* -------------------------------------------------------------------- */ - - ossim_SHPWriteTreeNode( fp, tree->psRoot ); - - fclose( fp ); - - return TRUE; -} -- GitLab