OSSIM - Open Source Software Image Map  Version 1.9.0 (20180803)
Public Member Functions | Protected Member Functions | List of all members
ossimQbTileFilesHandler Class Reference

Image handler used for tiled Quickbird imagery. More...

#include <ossimQbTileFilesHandler.h>

Inheritance diagram for ossimQbTileFilesHandler:
ossimTiledImageHandler ossimImageHandler ossimImageSource ossimSource ossimConnectableObject ossimErrorStatusInterface ossimObject ossimListenerManager ossimPropertyInterface ossimReferenced

Public Member Functions

 ossimQbTileFilesHandler ()
 Constructor (default): More...
 
virtual ~ossimQbTileFilesHandler ()
 Destructor: More...
 
virtual bool open ()
 Opens the image file given entry index. More...
 
virtual ossimRefPtr< ossimImageGeometrygetImageGeometry ()
 Fetch the tile-files common RPC data file and create the projection for this image. More...
 
- Public Member Functions inherited from ossimTiledImageHandler
 ossimTiledImageHandler ()
 Constructor (default): More...
 
virtual ~ossimTiledImageHandler ()
 Destructor: More...
 
*virtual void close ()
 Deletes the overview and clears the valid image vertices. More...
 
virtual bool isOpen () const
 Derived classes must implement this method to be concrete. More...
 
virtual ossim_uint32 getNumberOfInputBands () const
 
virtual ossim_uint32 getNumberOfLines (ossim_uint32 resLevel=0) const
 
virtual ossim_uint32 getNumberOfSamples (ossim_uint32 resLevel=0) const
 
virtual bool saveState (ossimKeywordlist &kwl, const char *prefix=0) const
 Method to save the state of an object to a keyword list. More...
 
virtual bool loadState (const ossimKeywordlist &kwl, const char *prefix=0)
 Method to the load (recreate) the state of an object from a keyword list. More...
 
virtual bool isImageTiled () const
 Indicates whether or not the image is tiled internally. More...
 
virtual ossim_uint32 getImageTileWidth () const
 Returns the tile width of the image or 0 if the image is not tiled. More...
 
virtual ossim_uint32 getImageTileHeight () const
 Returns the tile height of the image or 0 if the image is not tiled. More...
 
virtual ossimRefPtr< ossimImageDatagetTile (const ossimIrect &rect, ossim_uint32 resLevel)
 Fills the requested tile by pulling pixels from multiple file tiles as needed. More...
 
virtual ossimScalarType getOutputScalarType () const
 Returns scalar type of first tile (should be the same for all tiles) More...
 
virtual ossimIrect getImageRectangle (ossim_uint32 resLevel=0) const
 Returns overall bounding rect in image space. More...
 
- Public Member Functions inherited from ossimImageHandler
 ossimImageHandler ()
 Constructor (default): More...
 
virtual ~ossimImageHandler ()
 Destructor: Derived classes should implement. More...
 
virtual void initialize ()
 initialize Does nothing in this class. More...
 
virtual bool openOverview ()
 Searches for an overview. More...
 
virtual bool openOverview (const ossimFilename &overview_file)
 Calls closeOverview(), then attempts to open the overview_file. More...
 
virtual void closeOverview ()
 If theOverview is initialized it will be deleted and set to NULL. More...
 
virtual const ossimImageHandlergetOverview () const
 
virtual bool hasOverviews () const
 
virtual ossimFilename createDefaultOverviewFilename () const
 
virtual ossimFilename createDefaultGeometryFilename () const
 
virtual ossimFilename createDefaultMetadataFilename () const
 
virtual ossimFilename createDefaultHistogramFilename () const
 
virtual ossimFilename createDefaultValidVerticesFilename () const
 
virtual bool writeValidImageVertices (const std::vector< ossimIpt > &vertices, const ossimFilename &file=ossimFilename(""))
 Outputs vertices to file and updates the internal vertex array variable "theValidImageVertices". More...
 
virtual bool openValidVertices (const ossimFilename &vertices_file)
 Opens the valid image vertices file and sets theValidImageVerticesFile variable. More...
 
virtual bool openValidVertices ()
 Creates vertices file name based on image, then tries to open. More...
 
virtual bool open (const ossimFilename &imageFile, ossim_uint32 entryIndex)
 Opens the image file. More...
 
virtual bool open (const ossimFilename &imageFile)
 
virtual bool open (std::shared_ptr< ossim::ImageHandlerState > state)
 
virtual bool buildHistogram (int numberOfRLevels=0, ossimHistogramMode mode=OSSIM_HISTO_MODE_NORMAL)
 Build a histogram for image file. More...
 
virtual bool buildAllHistograms (int numberOfRLevels=0, ossimHistogramMode mode=OSSIM_HISTO_MODE_NORMAL)
 Build a histograms for all image entries. More...
 
virtual bool buildOverview (ossimImageHandlerOverviewCompressionType compressionType=OSSIM_OVERVIEW_COMPRESSION_NONE, ossim_uint32 quality=75, ossimFilterResampler::ossimFilterResamplerType resampleType=ossimFilterResampler::ossimFilterResampler_BOX, bool includeFullResFlag=false)
 Will build over file for theImageFile. More...
 
virtual bool buildAllOverviews (ossimImageHandlerOverviewCompressionType compressionType=OSSIM_OVERVIEW_COMPRESSION_NONE, ossim_uint32 quality=75, ossimFilterResampler::ossimFilterResamplerType resampleType=ossimFilterResampler::ossimFilterResampler_BOX, bool includeFullResFlag=false)
 Will build over file for all image entries. More...
 
virtual bool buildOverview (const ossimFilename &filename, ossimImageHandlerOverviewCompressionType compressionType=OSSIM_OVERVIEW_COMPRESSION_NONE, ossim_uint32 quality=75, ossimFilterResampler::ossimFilterResamplerType resampleType=ossimFilterResampler::ossimFilterResampler_BOX, bool includeFullResFlag=false)
 Will build an over file for filename. More...
 
ossimRefPtr< ossimMultiResLevelHistogramgetImageHistogram () const
 Fetches the current entry image's histogram. More...
 
virtual void setImageGeometry (ossimImageGeometry *geom)
 Sets the image geometry object. More...
 
virtual void saveImageGeometry () const
 Saves the image geometry to a file that will be made based on the image file name. More...
 
virtual void saveImageGeometry (const ossimFilename &geometry_file) const
 Saves the image geometry to a file that will be made based on the image file name. More...
 
virtual ossimIrect getBoundingRect (ossim_uint32 resLevel=0) const
 Returns zero-based bounding rectangle of the image. More...
 
virtual void getDecimationFactor (ossim_uint32 resLevel, ossimDpt &result) const
 
virtual void getDecimationFactors (vector< ossimDpt > &decimations) const
 This returns all decimation for all levels. More...
 
virtual ossim_uint32 getNumberOfDecimationLevels () const
 This returns the total number of decimation levels. More...
 
virtual ossim_uint32 getNumberOfReducedResSets () const
 This method is obsolete. More...
 
virtual void setFilename (const ossimFilename &filename)
 Sets the filename. More...
 
virtual const ossimFilenamegetFilename () const
 Returns the filename. More...
 
virtual bool isValidRLevel (ossim_uint32 resLevel) const
 Determines if the passed in reslution level is valid. More...
 
bool canConnectMyInputTo (ossim_int32 inputIndex, const ossimConnectableObject *object) const
 Connection rule. More...
 
virtual void getValidImageVertices (vector< ossimIpt > &validVertices, ossimVertexOrdering ordering=OSSIM_CLOCKWISE_ORDER, ossim_uint32 resLevel=0) const
 ordering specifies how the vertices should be arranged. More...
 
virtual bool isBandSelector () const
 Indicates whether or not the image handler can control output band selection via the setOutputBandList method. More...
 
virtual bool setOutputBandList (const std::vector< ossim_uint32 > &band_list)
 If the image handler "isBandSeletor()" then the band selection of the output chip can be controlled. More...
 
virtual bool setOutputToInputBandList ()
 If the image handler "isBandSeletor()" then the band selection of the output are set to input or identity. More...
 
virtual bool isIdentityBandList (const std::vector< ossim_uint32 > &bandList) const
 Convenience method to see if band list is identity. More...
 
virtual bool hasMetaData () const
 
virtual ossimRefPtr< ossimNBandLutDataObjectgetLut () const
 
virtual bool hasLut () const
 
virtual void loadMetaData ()
 There is an external file with an omd extension. More...
 
virtual double getMinPixelValue (ossim_uint32 band=0) const
 Retuns the min pixel value. More...
 
virtual double getMaxPixelValue (ossim_uint32 band=0) const
 Returns the max pixel of the band. More...
 
virtual double getNullPixelValue (ossim_uint32 band=0) const
 Each band has a null pixel associated with it. More...
 
virtual void setMinPixelValue (ossim_uint32 band, const ossim_float64 &pix)
 convenience method to set min pixel value. More...
 
virtual void setMaxPixelValue (ossim_uint32 band, const ossim_float64 &pix)
 convenience method to set max pixel value. More...
 
virtual void setNullPixelValue (ossim_uint32 band, const ossim_float64 &pix)
 convenience method to set null pixel value. More...
 
virtual ossim_uint32 getCurrentEntry () const
 
virtual ossim_uint32 getNumberOfEntries () const
 
virtual void getEntryName (ossim_uint32 entryIdx, std::string &name) const
 Get the name of entry as a string. More...
 
virtual void getEntryList (std::vector< ossim_uint32 > &entryList) const
 
virtual void getEntryNames (std::vector< ossimString > &entryNames) const
 
bool useEntryIndex () const
 Convenience method to determine if entry index should be used for support files, e.g. More...
 
ossimFilename getOverviewFile () const
 
virtual bool setCurrentEntry (ossim_uint32 entryIdx)
 
virtual void setProperty (ossimRefPtr< ossimProperty > property)
 
virtual ossimRefPtr< ossimPropertygetProperty (const ossimString &name) const
 
virtual void getPropertyNames (std::vector< ossimString > &propertyNames) const
 
ossimFilename getFilenameWithThisExtension (const ossimString &ext, bool set_e0_prefix=false) const
 Returns the image file with extension set using supplentary directory for dirname if set. More...
 
void getFilenameWithThisExt (const ossimString &ext, ossimFilename &f) const
 Returns the image file with extension set using supplentary directory for dirname if set. More...
 
ossim_uint32 getStartingResLevel () const
 
void setStartingResLevel (ossim_uint32 level)
 
bool getOpenOverviewFlag () const
 
void setOpenOverviewFlag (bool flag)
 Sets theOpenOverviewFlag. More...
 
virtual void setSupplementaryDirectory (const ossimFilename &dir)
 Sets the supplementary directory. More...
 
virtual const ossimFilenamegetSupplementaryDirectory () const
 Returns the supplementary directory. More...
 
const ossimStringgetImageID () const
 Fetches the image ID. More...
 
void setImageID (const ossimString &id)
 Sets the image ID in case it is externally generated. More...
 
ossimPixelType getPixelType () const
 Returns the raster pixel alignment type. More...
 
virtual bool getRgbBandList (std::vector< ossim_uint32 > &bandList) const
 Convenience method to get the zero based rgb output band list. More...
 
template<class T >
std::shared_ptr< T > getStateAs ()
 
template<class T >
std::shared_ptr< const T > getStateAs () const
 
std::shared_ptr< ossim::ImageHandlerState > getState ()
 
std::shared_ptr< const ossim::ImageHandlerState > getState () const
 
void setState (std::shared_ptr< ossim::ImageHandlerState > state)
 
- Public Member Functions inherited from ossimImageSource
 ossimImageSource (ossimObject *owner=0)
 
 ossimImageSource (ossimObject *owner, ossim_uint32 inputListSize, ossim_uint32 outputListSize, bool inputListIsFixedFlag=true, bool outputListIsFixedFlag=true)
 
virtual ~ossimImageSource ()
 
virtual ossimRefPtr< ossimImageDatagetTile (const ossimIpt &origin, ossim_uint32 resLevel=0)
 
virtual bool getTile (ossimImageData *result, ossim_uint32 resLevel=0)
 Method to get a tile. More...
 
virtual ossimObjectgetObject ()
 For RTTI support. More...
 
virtual const ossimObjectgetObject () const
 For RTTI support. More...
 
virtual void getDecimationFactors (std::vector< ossimDpt > &decimations) const
 Will return an array of all decimations for each resolution level. More...
 
virtual ossim_uint32 getNumberOfOutputBands () const
 Returns the number of bands in a tile returned from this TileSource. More...
 
virtual void getOutputBandList (std::vector< ossim_uint32 > &bandList) const
 Initializes bandList. More...
 
virtual ossim_uint32 getTileWidth () const
 Returns the default processing tile width. More...
 
virtual ossim_uint32 getTileHeight () const
 Returns the default processing tile height. More...
 
virtual void getBoundingRect (ossimIrect &rect, ossim_uint32 resLevel=0) const
 Gets the bounding rectangle of the source. More...
 
virtual void getValidImageVertices (std::vector< ossimIpt > &validVertices, ossimVertexOrdering ordering=OSSIM_CLOCKWISE_ORDER, ossim_uint32 resLevel=0) const
 ordering specifies how the vertices should be arranged. More...
 
virtual void setImageGeometry (const ossimImageGeometry *geom)
 Default implementation sets geometry of the first input to the geometry specified. More...
 
virtual bool isIndexedData () const
 
- Public Member Functions inherited from ossimSource
 ossimSource (ossimObject *owner=0)
 
 ossimSource (ossimObject *owner, ossim_uint32 inputListSize, ossim_uint32 outputListSize, bool inputListIsFixedFlag=true, bool outputListIsFixedFlag=true)
 
virtual ~ossimSource ()
 
virtual bool isSourceEnabled () const
 
virtual void enableSource ()
 
virtual void disableSource ()
 
virtual bool getEnableFlag () const
 
virtual void setEnableFlag (bool flag)
 
virtual bool isInitialized () const
 
virtual void setInitializedFlag (bool flag)
 
virtual std::ostream & print (std::ostream &out) const
 Outputs theErrorStatus as an ossimErrorCode and an ossimString. More...
 
- Public Member Functions inherited from ossimConnectableObject
 ossimConnectableObject (ossimObject *owner=0)
 Base constructor of this object. More...
 
 ossimConnectableObject (ossimObject *owner, ossim_int32 inputListSize, ossim_int32 outputListSize, bool inputListIsFixedFlag=true, bool outputListIsFixedFlag=true)
 
virtual ~ossimConnectableObject ()
 
void setId (const ossimId &id)
 All connectable objects will have id's. More...
 
const ossimIdgetId () const
 Will allow us to get this object's id. More...
 
const ossimObjectgetOwner () const
 Fetches the current owner, most likely a container but not limited to one. More...
 
virtual void changeOwner (ossimObject *owner)
 Permits changing the object's owner. More...
 
virtual void setDescription (const ossimString &description)
 
virtual ossimString getDescription () const
 
virtual bool isConnected (ossimConnectableObjectDirectionType direction=CONNECTABLE_DIRECTION_INPUT) const
 will check the direction specified to see if all slots are full. More...
 
 OSSIM_DEPRECATE_METHOD (virtual ossimConnectableObject *findConnectableObject(const ossimId &id))
 
 OSSIM_DEPRECATE_METHOD (virtual ossimConnectableObject *findObjectOfType(RTTItypeid typeId, ossimConnectableObjectDirectionType directionType, bool recurse=true))
 
 OSSIM_DEPRECATE_METHOD (virtual ossimConnectableObject *findObjectOfType(const ossimString &obj, ossimConnectableObjectDirectionType directionType, bool recurse=true))
 
 OSSIM_DEPRECATE_METHOD (virtual ossimConnectableObject *findInputObjectOfType(const ossimString &className))
 
virtual ossim_int32 findInputIndex (const ossimConnectableObject *object)
 Return a valid index of the input list if the passed in object is found else return -1. More...
 
virtual ossim_int32 findInputIndex (const ossimId &id)
 Return a valid index of the input list if the passed id is found else return -1. More...
 
virtual ossim_int32 findOutputIndex (const ossimConnectableObject *object)
 Return a valid index of the output list if the passed in object is found else return -1. More...
 
virtual ossim_int32 findOutputIndex (const ossimId &id)
 Return a valid index of the output list if the passed in object is found else return -1. More...
 
virtual ossim_int32 getMyInputIndexToConnectTo (ossimConnectableObject *object) const
 Should return the first available index to connect to. More...
 
virtual ossim_int32 getMyOutputIndexToConnectTo (ossimConnectableObject *object) const
 Should return the first available index to connect to. More...
 
virtual bool canConnectMyOutputTo (ossim_int32 myOutputIndex, const ossimConnectableObject *object) const
 default implementation is to allow anyone to connect to us. More...
 
virtual void disconnect (ossimConnectableObject *object=0)
 Will disconnect the object passed in. More...
 
virtual void disconnect (const ossimId &id)
 Will disconnect the object passed in. More...
 
virtual ossimRefPtr< ossimConnectableObjectdisconnectMyInput (ossim_int32 inputIndex, bool disconnectOutputFlag=true, bool createEventFlag=true)
 Will disconnect the object at the given input index and generate a connection event. More...
 
virtual void disconnectMyInput (ossimConnectableObject *input, bool disconnectOutputFlag=true, bool createEventFlag=true)
 Finds the index of the passed in input and calls disconnectMyInput(inputIndex, disconnectOutputFlag, createEventFlag);. More...
 
virtual void disconnectMyInputs (ConnectableObjectList &inputList, bool disconnectOutputFlag=true, bool createEventFlag=true)
 
virtual ossimRefPtr< ossimConnectableObjectdisconnectMyOutput (ossim_int32 outputIndex, bool disconnectInputFlag=true, bool createEventFlag=true)
 Will disconnect the object at the given output index and generate a connection event. More...
 
virtual void disconnectMyOutput (ossimConnectableObject *output, bool disconnectInputFlag=true, bool createEventFlag=true)
 Will disconnect the output object. More...
 
virtual void disconnectMyOutputs (ConnectableObjectList &outputList, bool disconnectOutputFlag=true, bool createEventFlag=true)
 
virtual void disconnectAllInputs ()
 Will disconnect all of the input objects. More...
 
virtual void disconnectAllOutputs ()
 Will disconnect all of the output objects. More...
 
virtual ossim_int32 connectMyInputTo (ossimConnectableObject *inputObject, bool makeOutputConnection=true, bool createEventFlag=true)
 Will try to connect this objects input to the passed in object. More...
 
virtual ossim_int32 connectMyInputTo (ossim_int32 inputIndex, ossimConnectableObject *inputObject, bool makeOutputConnection=true, bool createEventFlag=true)
 Will connect the specified input to the passed in object. More...
 
virtual bool connectMyInputTo (ConnectableObjectList &inputList, bool makeOutputConnection=true, bool createEventFlag=true)
 
virtual ossim_int32 connectMyOutputTo (ossimConnectableObject *outputObject, bool makeInputConnection=true, bool createEventFlag=true)
 Will try to connect this objects output to the passed in object. More...
 
virtual bool connectMyOutputTo (ConnectableObjectList &outputList, bool makeInputConnection=true, bool createEventFlag=true)
 
virtual bool connectInputList (ConnectableObjectList &inputList)
 Will disconnect itself from all inputs and reset to the passed in input list. More...
 
virtual bool connectOutputList (ConnectableObjectList &outputList)
 Will disconnect itself from all outputs and reset to the passed in output list. More...
 
virtual ossim_uint32 getNumberOfInputs () const
 Returns the number of input objects. More...
 
virtual ossim_uint32 getNumberOfOutputs () const
 Return the number of output objects. More...
 
ossimConnectableObjectgetInput (ossim_uint32 index=0)
 returns the object at the specified index. More...
 
const ossimConnectableObjectgetInput (ossim_uint32 index=0) const
 returns the object at the specified index. More...
 
ossimConnectableObjectgetOutput (ossim_uint32 index=0)
 returns the object at the specified index. More...
 
const ossimConnectableObjectgetOutput (ossim_uint32 index=0) const
 returns the object at the specified index. More...
 
virtual void setNumberOfInputs (ossim_int32 numberOfInputs)
 Will set the number of inputs. More...
 
virtual bool getInputListIsFixedFlag () const
 
virtual bool getOutputListIsFixedFlag () const
 
virtual void setNumberOfOutputs (ossim_int32 numberOfInputs)
 Will set the number of outputs. More...
 
const ConnectableObjectListgetInputList () const
 
const ConnectableObjectListgetOutputList () const
 
ConnectableObjectListgetInputList ()
 
ConnectableObjectListgetOutputList ()
 
 OSSIM_DEPRECATE_METHOD (virtual void findAllObjectsOfType(ConnectableObjectList &result, const RTTItypeid &typeInfo, bool recurse=true))
 
 OSSIM_DEPRECATE_METHOD (virtual void findAllObjectsOfType(ConnectableObjectList &result, const ossimString &className, bool recurse=true))
 
virtual void propagateEventToOutputs (ossimEvent &event)
 
virtual void propagateEventToInputs (ossimEvent &event)
 
virtual void setProperty (const ossimString &name, const ossimString &value)
 
virtual ossim_uint32 saveStateOfAllInputs (ossimKeywordlist &kwl, bool saveThisStateFlag=true, ossim_uint32 objectIndex=1, const char *prefix=0) const
 Save the state of all inputs to a keyword list. More...
 
virtual bool fillContainer (ossimConnectableContainer &container)
 Inserts this object and all of its children and inputs into the container provided. More...
 
bool moveInputUp (const ossimId &id)
 Moves the input connection matching id up one in the connection list. More...
 
bool moveInputDown (const ossimId &id)
 Moves the input connection matching id down one in the connection list. More...
 
bool moveInputToTop (const ossimId &id)
 Moves the input connection matching id to the top of the connection list. More...
 
bool moveInputToBottom (const ossimId &id)
 Moves the input connection matching id to the bottom of the connection list. More...
 
virtual void accept (ossimVisitor &visitor)
 We will add a visitor interface for all connectable objects. More...
 
- Public Member Functions inherited from ossimObject
 ossimObject ()
 
virtual ~ossimObject ()
 
virtual ossimObjectdup () const
 
virtual ossimString getShortName () const
 
virtual ossimString getLongName () const
 
virtual ossimString getClassName () const
 
virtual RTTItypeid getType () const
 
virtual bool canCastTo (ossimObject *obj) const
 
virtual bool canCastTo (const RTTItypeid &id) const
 
virtual bool canCastTo (const ossimString &parentClassName) const
 
virtual bool isEqualTo (const ossimObject &obj, ossimCompareType compareType=OSSIM_COMPARE_FULL) const
 
- Public Member Functions inherited from ossimReferenced
 ossimReferenced ()
 
 ossimReferenced (const ossimReferenced &)
 
ossimReferencedoperator= (const ossimReferenced &)
 
void ref () const
 increment the reference count by one, indicating that this object has another pointer which is referencing it. More...
 
void unref () const
 decrement the reference count by one, indicating that a pointer to this object is referencing it. More...
 
void unref_nodelete () const
 decrement the reference count by one, indicating that a pointer to this object is referencing it. More...
 
int referenceCount () const
 
- Public Member Functions inherited from ossimListenerManager
 ossimListenerManager ()
 
virtual ~ossimListenerManager ()
 
virtual void fireEvent (ossimEvent &event)
 
virtual bool addListener (ossimListener *listener)
 
virtual bool removeListener (ossimListener *listener)
 
virtual bool findListener (ossimListener *listener)
 
- Public Member Functions inherited from ossimPropertyInterface
 ossimPropertyInterface ()
 
virtual ~ossimPropertyInterface ()
 
virtual ossimString getPropertyValueAsString (const ossimString &name) const
 
void getPropertyList (std::vector< ossimRefPtr< ossimProperty > > &propertyList) const
 
void setProperties (std::vector< ossimRefPtr< ossimProperty > > &propertyList)
 
- Public Member Functions inherited from ossimErrorStatusInterface
 ossimErrorStatusInterface ()
 
virtual ~ossimErrorStatusInterface ()
 
virtual ossimErrorCode getErrorStatus () const
 
virtual ossimString getErrorStatusString () const
 
virtual void setErrorStatus (ossimErrorCode error_status) const
 
virtual void setErrorStatus () const
 
virtual void clearErrorStatus () const
 
bool hasError () const
 

Protected Member Functions

bool computeImageRects ()
 Initializes tile image rects by considering adjacent row/col offsets. More...
 
- Protected Member Functions inherited from ossimTiledImageHandler
void allocate ()
 Initialize tile buffer to match image datatype. More...
 
- Protected Member Functions inherited from ossimImageHandler
virtual ossimRefPtr< ossimImageGeometrygetExternalImageGeometry () const
 Returns the image geometry object associated with this tile source or NULL if non defined. More...
 
virtual ossimRefPtr< ossimImageGeometrygetInternalImageGeometry () const
 
virtual bool getOverviewTile (ossim_uint32 resLevel, ossimImageData *result)
 Method to get an overview tile. More...
 
bool initVertices (const char *file)
 Opens file and attempts to initialize the valid image vertices. More...
 
virtual void completeOpen ()
 Will complete the opening process. More...
 
void initImageParameters (ossimImageGeometry *geom) const
 Convenience method to set things needed in the image geometry from the image handler. More...
 
virtual void establishDecimationFactors ()
 Virtual method determines the decimation factors at each resolution level. More...
 
virtual bool setOutputBandList (const std::vector< ossim_uint32 > &inBandList, std::vector< ossim_uint32 > &outBandList)
 Convenience method to set output band list. More...
 
void getFilenameWithNoExtension (ossimFilename &f) const
 Get filename with no extension, using supplentary directory for dirname if set. More...
 
- Protected Member Functions inherited from ossimImageSource
 ossimImageSource (const ossimImageSource &rhs)
 
const ossimImageSourceoperator= (const ossimImageSource &)
 
- Protected Member Functions inherited from ossimSource
 ossimSource (const ossimSource &rhs)
 
const ossimSourceoperator= (const ossimSource &rhs)
 
- Protected Member Functions inherited from ossimConnectableObject
ossimConnectableObjectfindObjectOfType (ConnectableObjectList *connectableList, ossimVisitor &visitor)
 
- Protected Member Functions inherited from ossimReferenced
virtual ~ossimReferenced ()
 
- Protected Member Functions inherited from ossimListenerManager
 ossimListenerManager (const ossimListenerManager &rhs)
 

Additional Inherited Members

- Public Types inherited from ossimImageHandler
enum  ossimImageHandlerOverviewCompressionType {
  OSSIM_OVERVIEW_COMPRESSION_NONE = 0, OSSIM_OVERVIEW_COMPRESSION_JPEG, OSSIM_OVERVIEW_COMPRESSION_LZW, OSSIM_OVERVIEW_COMPRESSION_DEFLATE,
  OSSIM_OVERVIEW_COMPRESSION_PACKBITS
}
 
- Public Types inherited from ossimConnectableObject
enum  ossimConnectableObjectDirectionType { CONNECTABLE_DIRECTION_NONE = 0, CONNECTABLE_DIRECTION_INPUT = 1, CONNECTABLE_DIRECTION_OUTPUT = 2 }
 
typedef std::vector< ossimRefPtr< ossimConnectableObject > > ConnectableObjectList
 
- Protected Attributes inherited from ossimTiledImageHandler
vector< ossimTileFilem_tileFiles
 
ossimRefPtr< ossimImageDatam_tile
 
ossimRefPtr< ossimImageDatam_blankTile
 
ossimIrect m_fullImgRect
 
ossim_uint32 m_startOvrResLevel
 
- Protected Attributes inherited from ossimImageHandler
ossimFilename theImageFile
 
ossimFilename theOverviewFile
 
ossimFilename theSupplementaryDirectory
 
ossimRefPtr< ossimImageHandlertheOverview
 
vector< ossimIpttheValidImageVertices
 
ossimImageMetaData theMetaData
 
ossimRefPtr< ossimImageGeometrytheGeometry
 
ossimRefPtr< ossimNBandLutDataObjecttheLut
 
std::vector< ossimDpttheDecimationFactors
 
ossimString theImageID
 
ossim_uint32 theStartingResLevel
 theStartingResLevel If set to something other than zero(default) this is indicative that the reader is an overview. More...
 
bool theOpenOverviewFlag
 If true opening of overviews will be attempted. More...
 
ossimPixelType thePixelType
 
std::shared_ptr< ossim::ImageHandlerState > m_state
 
- Protected Attributes inherited from ossimSource
bool theEnableFlag
 
bool theInitializedFlag
 
- Protected Attributes inherited from ossimConnectableObject
ossimId theId
 
ossimString theDescription
 
ossimObjecttheOwner
 
bool theInputListIsFixedFlag
 Indicates whether the theInputObjectList is fixed. More...
 
bool theOutputListIsFixedFlag
 Indicates whether the theOutputObjectList is fixed. More...
 
ConnectableObjectList theInputObjectList
 Holds a list of input objects. More...
 
ConnectableObjectList theOutputObjectList
 Holds a list of output objects. More...
 
- Protected Attributes inherited from ossimListenerManager
std::list< ossimListener * > theListenerList
 
bool theEnabledFlag
 
std::list< ossimListener * > theDelayedAdd
 
std::list< ossimListener * > theDelayedRemove
 
bool theFireEventFlag
 
- Protected Attributes inherited from ossimErrorStatusInterface
ossimErrorCode theErrorStatus
 

Detailed Description

Image handler used for tiled Quickbird imagery.

Definition at line 20 of file ossimQbTileFilesHandler.h.

Constructor & Destructor Documentation

◆ ossimQbTileFilesHandler()

ossimQbTileFilesHandler::ossimQbTileFilesHandler ( )

Constructor (default):

Definition at line 44 of file ossimQbTileFilesHandler.cpp.

45 {
46 }

◆ ~ossimQbTileFilesHandler()

ossimQbTileFilesHandler::~ossimQbTileFilesHandler ( )
virtual

Destructor:

Definition at line 51 of file ossimQbTileFilesHandler.cpp.

52 {
53 }

Member Function Documentation

◆ computeImageRects()

bool ossimQbTileFilesHandler::computeImageRects ( )
protected

Initializes tile image rects by considering adjacent row/col offsets.

Called when TIL doesn't contain the info. Returns true if successful.

Definition at line 249 of file ossimQbTileFilesHandler.cpp.

References ossimQuickbirdMetaData::getImageSize(), ossimTiledImageHandler::m_fullImgRect, ossimTiledImageHandler::m_tileFiles, ossimQuickbirdMetaData::open(), ossimIrect::set_lr(), ossimIrect::set_ulx(), ossimIrect::set_uly(), ossimImageHandler::theImageFile, ossimIpt::x, and ossimIpt::y.

250 {
251  try
252  {
254  if (!oqmd.open(theImageFile))
255  throw 1;
256 
257  ossimIpt image_size (oqmd.getImageSize());
258  if (image_size.hasNans())
259  throw 2;
260 
261  ossimIpt full_image_lr (image_size.x-1, image_size.y-1);
264  m_fullImgRect.set_lr(full_image_lr);
265 
266  // Now consider the subrects for each tile. It is assumed that all tiles (except right
267  // and bottom) will be of uniform size. The TIL file should have at least provided the row
268  // and column offsets for each tile into the full image. This is equivalent to the UL corner.
269  // It is presumed that the TIL failed to provide the LR corner since this method was called.
270  int dx=0, dy=0, i=0;
271  int num_tiles = (int) m_tileFiles.size();
272  while (((dx == 0) || (dy == 0)) && (i < num_tiles-1))
273  {
274  if (dx == 0)
275  dx = m_tileFiles[i+1].subImageRects[0].ul().x - m_tileFiles[i].subImageRects[0].ul().x;
276  if (dy == 0)
277  dy = m_tileFiles[i+1].subImageRects[0].ul().y - m_tileFiles[i].subImageRects[0].ul().y;
278  ++i;
279  }
280 
281  // We should have the nominal tile size now. Check this is so:
282  if ((dx == 0) || (dy == 0))
283  {
284  // Prior scheme failed for establishing the tile dimensions. Final resort is to open the first
285  // available tile file and query its dimensions:
286  if (num_tiles == 0)
287  throw 3;
288  if (m_tileFiles[0].imageHandler.valid())
289  {
290  // we have an open handler, so just query it:
291  dy = m_tileFiles[0].imageHandler->getNumberOfLines();
292  dx = m_tileFiles[0].imageHandler->getNumberOfSamples();
293  }
294  else
295  {
296  // Struck out, just assume the tile is square:
297  if ((dx == 0) && (dy == 0))
298  throw 4;
299  if (dy == 0)
300  dy = dx;
301  else
302  dx = dy;
303  }
304  }
305 
306  // Loop over all tiles to properly assign their image rectangles:
307  for (i=0; i<num_tiles; i++)
308  {
309  ossimIpt ul (m_tileFiles[i].subImageRects[0].ul());
310  ossimIpt lr (ul.x + dx - 1, ul.y + dy - 1);
311 
312  // Check to make sure we don't exceed extents of full image:
313  if (lr.x > full_image_lr.x)
314  lr.x = full_image_lr.x;
315  if (lr.y > full_image_lr.y)
316  lr.y = full_image_lr.y;
317 
318  m_tileFiles[i].subImageRects[0].set_lr(lr);
319  }
320  }
321 
322  catch (...)
323  {
324  // Could not establish the rectangles:
325  return false;
326  }
327 
328  return true;
329 }
void set_uly(ossim_int32 y)
Definition: ossimIrect.h:666
ossimFilename theImageFile
void set_lr(const ossimIpt &pt)
Definition: ossimIrect.h:623
bool open(const ossimFilename &imageFile)
Open method that takes the image file, derives the metadata, header and rpc files, then calls parse methods parseMetaData, parseHdrData, and parseRpcData.
const ossimIpt & getImageSize() const
vector< ossimTileFile > m_tileFiles
void set_ulx(ossim_int32 x)
Definition: ossimIrect.h:657

◆ getImageGeometry()

ossimRefPtr< ossimImageGeometry > ossimQbTileFilesHandler::getImageGeometry ( )
virtual

Fetch the tile-files common RPC data file and create the projection for this image.

Reimplemented from ossimImageHandler.

Definition at line 186 of file ossimQbTileFilesHandler.cpp.

References ossimFilename::exists(), ossimRefPtr< T >::get(), ossimErrorStatusInterface::getErrorStatus(), ossimImageHandler::getExternalImageGeometry(), ossimQuickbirdMetaData::getMapProjectionKwl(), ossimImageHandler::initImageParameters(), ossimProjectionFactoryRegistry::instance(), ossimTiledImageHandler::m_fullImgRect, ossimFilename::setExtension(), ossimImageGeometry::setProjection(), ossimImageGeometry::setTransform(), ossimImageHandler::theGeometry, ossimImageHandler::theImageFile, true, ossimIrect::ul(), ossimRefPtr< T >::valid(), ossimIpt::x, and ossimIpt::y.

187 {
188  if ( !theGeometry )
189  {
190  // Try external geom first:
192 
193  if ( !theGeometry )
194  {
196 
197  // The dataset is expected to have an RPC model associated with it:
199  if (!model->getErrorStatus())
200  {
201  theGeometry->setProjection(model.get());
202  }
203  else
204  {
205  // Check for map projected data:
206  ossimFilename imd_file = theImageFile;
207  imd_file.setExtension("IMD");
208  if ( imd_file.exists() == false )
209  {
210  imd_file.setExtension("imd");
211  }
212 
213  if ( imd_file.exists() )
214  {
216  ossimKeywordlist kwl;
217  if ( md.getMapProjectionKwl( imd_file, kwl ) == true )
218  {
220  createProjection( kwl, 0 );
221  if ( proj.valid() == true )
222  {
223  theGeometry->setProjection( proj.get() );
224  }
225  }
226  }
227  }
228 
229  if ( (m_fullImgRect.ul().x != 0) || (m_fullImgRect.ul().y != 0) )
230  {
231  // Set sub image offset.
234  theGeometry->setTransform( xfrm.get() );
235  }
236  }
237 
238  // Set image things the geometry object should know about.
240  }
241 
242  return theGeometry;
243 }
ossimRefPtr< ossimImageGeometry > theGeometry
void setProjection(ossimProjection *projection)
Sets the projection to be used for local-to-world coordinate transformation.
ossimFilename theImageFile
Represents serializable keyword/value map.
bool valid() const
Definition: ossimRefPtr.h:75
const ossimIpt & ul() const
Definition: ossimIrect.h:274
bool getMapProjectionKwl(const ossimFilename &imd_file, ossimKeywordlist &kwl)
bool exists() const
void initImageParameters(ossimImageGeometry *geom) const
Convenience method to set things needed in the image geometry from the image handler.
Container class that holds both 2D transform and 3D projection information for an image Only one inst...
static ossimProjectionFactoryRegistry * instance()
virtual ossimRefPtr< ossimImageGeometry > getExternalImageGeometry() const
Returns the image geometry object associated with this tile source or NULL if non defined...
virtual ossimErrorCode getErrorStatus() const
ossim_int32 y
Definition: ossimIpt.h:142
void setTransform(ossim2dTo2dTransform *transform)
Sets the transform to be used for local-to-full-image coordinate transformation.
ossim_int32 x
Definition: ossimIpt.h:141
ossimFilename & setExtension(const ossimString &e)
Sets the extension of a file name.

◆ open()

bool ossimQbTileFilesHandler::open ( )
virtual

Opens the image file given entry index.

Returns
Returns true on success, false on error.
Note
This method relies on the data member ossimImageData::theImageFile being set.

This class does not support multiple entries.

Parameters
imageFileFile to open.
entryIndex
Returns
false if entry index other than 0 specified.

Implements ossimTiledImageHandler.

Definition at line 61 of file ossimQbTileFilesHandler.cpp.

62 {
63  static const char* MODULE = "ossimQbTileFilesHandler::open() -- ";
64  if (traceDebug())
65  {
67  <<MODULE << "Entering...\nimage: " << theImageFile << "\n";
68  }
69 
70  // Test for extension: image.til
72  if ( ext == "ovr" )
73  {
74  return false; // Don't try to open overviews.
75  }
76 
77  ossimRegExp regExp("^[t|T][i|I][l|L]");
78  if ( regExp.find( ext.c_str() ) )
79  {
80  if (!theImageFile.exists())
81  {
82  return false;
83  }
84  }
85 
86  // Use ossimQuickbirdTile object for parsing the TIL file and fetching the data structure
87  // containing tile-file info:
88  if (traceDebug())
89  ossimNotify(ossimNotifyLevel_INFO)<<MODULE<<"OPENING ossimQuickbirdTile..."<<std::endl;
90 
92  bool success = qbt.open(theImageFile);
93  if (!success)
94  return false;
95 
96  // Populate our own data structure given the QBT map:
97  ossimFilename image_dir (theImageFile.path());
98  const ossimQuickbirdTile::TileMap& qbtTileMap = qbt.getMap();
99 
101  ossimIrect subImageRect;
102  ossimQuickbirdTile::TileMap::const_iterator qbt_iter = qbtTileMap.begin();
104  while (qbt_iter != qbtTileMap.end())
105  {
106  ossimQuickbirdTileInfo info ((*qbt_iter).second);
107  ossimTileFile tilefile;
108  tilefile.tileFilename = (*qbt_iter).second.theFilename;
109  tilefile.tileFilename.setPath(image_dir);
110  if (traceDebug())
111  {
112  ossimNotify(ossimNotifyLevel_INFO)<<MODULE<<"Using factory to open <"
113  <<tilefile.tileFilename<<">"<<std::endl;
114  }
115 
116  // Now open up the handlers for this tile-file:
117  tilefile.imageHandler = factory->open(tilefile.tileFilename);
118  if (tilefile.imageHandler.valid())
119  {
120  // Valid handler, populate remaining items of interest and push it on our list...
121  // Fetch image coordinates in full-view:
122  subImageRect.set_ulx((*qbt_iter).second.theUlXOffset);
123  subImageRect.set_uly((*qbt_iter).second.theUlYOffset);
124  subImageRect.set_lrx((*qbt_iter).second.theLrXOffset);
125  subImageRect.set_lry((*qbt_iter).second.theLrYOffset);
126  tilefile.subImageRects.push_back(subImageRect);
127 
128  // Update bounding image rectangle:
129  m_fullImgRect = m_fullImgRect.combine(subImageRect);
130  m_tileFiles.push_back(tilefile);
131  if (traceDebug())
132  {
133  ossimNotify(ossimNotifyLevel_INFO)<<MODULE<<"Pushed <"<<tilefile.tileFilename<<"> on"
134  "to tile-files list."<<std::endl;
135  }
136  }
137  else
138  {
139  ossimNotify(ossimNotifyLevel_WARN)<<MODULE<<"TIL file listed <"
140  <<tilefile.tileFilename<<"> as one of the tiles, but the file could not be opened. "
141  <<"This is being ignored but may cause a problem downstream."<<std::endl;
142  }
143 
144  ++qbt_iter;
145  }
146 
147  // Need to check the full-image rect for validity. May need to explore the .IMD file if this
148  // was not properly initialized:
149  if (m_fullImgRect.hasNans())
150  {
151  if (!computeImageRects())
152  {
153  if (traceDebug())
154  {
155  ossimNotify(ossimNotifyLevel_INFO)<<MODULE<<"Could not establish image rectangles."
156  <<std::endl;
157  }
158  return false;
159  }
160  }
161 
162  if (traceDebug())
163  ossimNotify(ossimNotifyLevel_INFO)<<MODULE<<"Finished loading tiles."<<std::endl;
164 
165  bool open_good = false;
166  if ((m_tileFiles.size() != 0) && m_tileFiles[0].imageHandler.valid())
167  {
168  completeOpen();
169  open_good = true;
170 
171  if (traceDebug())
172  ossimNotify(ossimNotifyLevel_INFO)<<MODULE<<"Open successful."<<std::endl;
173  }
174 
175  if (traceDebug())
176  {
177  ossimNotify(ossimNotifyLevel_INFO)<<MODULE<<"Returning with <"
178  <<ossimString::toString(open_good)<<">"<<std::endl;
179  }
180  return open_good;
181 }
void set_uly(ossim_int32 y)
Definition: ossimIrect.h:666
ossimFilename theImageFile
virtual ossimImageHandler * open(const ossimFilename &fileName, bool trySuffixFirst=true, bool openOverview=true) const
open that takes a filename.
bool open(const ossimFilename tileFile)
static ossimString toString(bool aValue)
Numeric to string methods.
const std::map< std::string, ossimQuickbirdTileInfo > & getMap() const
ossimImageHandlerRegistry supports the new state cache.
bool exists() const
static ossimString downcase(const ossimString &aString)
Definition: ossimString.cpp:48
std::map< std::string, ossimQuickbirdTileInfo > TileMap
void set_lrx(ossim_int32 x)
Definition: ossimIrect.h:693
virtual void completeOpen()
Will complete the opening process.
void set_lry(ossim_int32 y)
Definition: ossimIrect.h:702
void makeNan()
Definition: ossimIrect.h:329
const char * c_str() const
Returns a pointer to a null-terminated array of characters representing the string&#39;s contents...
Definition: ossimString.h:396
bool hasNans() const
Definition: ossimIrect.h:337
vector< ossimTileFile > m_tileFiles
ossimString ext() const
static ossimImageHandlerRegistry * instance()
ossimIrect combine(const ossimIrect &rect) const
Definition: ossimIrect.cpp:543
ossimFilename path() const
bool computeImageRects()
Initializes tile image rects by considering adjacent row/col offsets.
OSSIMDLLEXPORT std::ostream & ossimNotify(ossimNotifyLevel level=ossimNotifyLevel_WARN)
void set_ulx(ossim_int32 x)
Definition: ossimIrect.h:657

The documentation for this class was generated from the following files: