00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020 #ifndef OST_IO_MAP_IO_NANOSCOPE_HANDLER_HH
00021 #define OST_IO_MAP_IO_NANOSCOPE_HANDLER_HH
00022
00023 #include "map_io_handler.hh"
00024
00025 namespace ost { namespace io {
00026
00027 class DLLEXPORT_OST_IO Nanoscope: public ImageFormatBase
00028 {
00029 public:
00030 Nanoscope(int subimage = -1);
00031
00032 static String FORMAT_STRING;
00033 static String FORMAT_NAME_STRING;
00034 static String FORMAT_DESCRIPTION_STRING;
00035
00036 int GetSubimage () const;
00037 void SetSubimage (int subimage);
00038
00039 private:
00040
00041 int subimage_;
00042
00043 };
00044
00045
00046
00047 class MapIONanoscopeHandler: public MapIOHandler {
00048 public:
00049
00050 public:
00054 virtual void Import(img::MapHandle& sh, const boost::filesystem::path& loc,const ImageFormatBase& formatstruct );
00055 virtual void Import(img::MapHandle& sh, std::istream& loc, const ImageFormatBase& formatstruct);
00056 virtual void Export(const img::MapHandle& sh, const boost::filesystem::path& loc, const ImageFormatBase& formatstruct) const;
00057 virtual void Export(const img::MapHandle& sh, std::ostream& loc,const ImageFormatBase& formatstruct) const;
00058 static bool MatchContent(unsigned char* header);
00059 static bool MatchType(const ImageFormatBase& type);
00060 static bool MatchSuffix(const String& loc);
00061 static bool ProvidesImport() { return true; }
00062 static bool ProvidesExport() { return true; }
00063 static String GetFormatName() { return String("Nanoscope"); }
00064 static String GetFormatDescription() { return String("Format used by software from Veeco"); }
00065 };
00066
00067 typedef MapIOHandlerFactory<MapIONanoscopeHandler> MapIONanoscopeHandlerFactory;
00068
00069 }}
00070
00071 #endif