00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020 #ifndef DX_IO_SITUS_IO_PLUGIN_OST_HH
00021 #define DX_IO_SITUS_IO_PLUGIN_OST_HH
00022
00023 #include "map_io_handler.hh"
00024
00025 namespace ost { namespace io {
00026
00027 class DLLEXPORT_OST_IO Situs: public ImageFormatBase
00028 {
00029 public:
00030
00031 Situs(bool normalize_on_save = false);
00032
00033 bool GetNormalizeOnSave() const;
00034 void SetNormalizeOnSave(bool normalize_on_save);
00035 static String FORMAT_STRING;
00036 static String FORMAT_NAME_STRING;
00037 static String FORMAT_ALIGNMENT_STRING;
00038
00039 private:
00040
00041 bool normalize_on_save_;
00042 };
00043
00044 class DLLEXPORT_OST_IO MapIOSitusHandler: public MapIOHandler
00045 {
00046 public:
00051 virtual void Import(img::MapHandle& sh, const boost::filesystem::path& loc,const ImageFormatBase& formatstruct);
00052 virtual void Import(img::MapHandle& sh, std::istream& loc,const ImageFormatBase& formatstruct);
00053 virtual void Export(const img::MapHandle& sh, const boost::filesystem::path& loc, const ImageFormatBase& formatstruct) const;
00054 virtual void Export(const img::MapHandle& sh, std::ostream& loc,const ImageFormatBase& formatstruct) const;
00055 static bool MatchContent(unsigned char* header);
00056 static bool MatchType(const ImageFormatBase& type);
00057 static bool MatchSuffix(const String& loc);
00058 static bool ProvidesImport() { return true; }
00059 static bool ProvidesExport() { return true; }
00060 static String GetFormatName() { return "Situs"; };
00061 static String GetFormatDescription() { return "Format used by the Situs software package"; };
00062 };
00063
00064 typedef MapIOHandlerFactory<MapIOSitusHandler> MapIOSitusHandlerFactory;
00065
00066 }}
00067
00068 #endif