ITK  4.1.0
Insight Segmentation and Registration Toolkit
itkLSMImageIO.h
Go to the documentation of this file.
00001 /*=========================================================================
00002  *
00003  *  Copyright Insight Software Consortium
00004  *
00005  *  Licensed under the Apache License, Version 2.0 (the "License");
00006  *  you may not use this file except in compliance with the License.
00007  *  You may obtain a copy of the License at
00008  *
00009  *         http://www.apache.org/licenses/LICENSE-2.0.txt
00010  *
00011  *  Unless required by applicable law or agreed to in writing, software
00012  *  distributed under the License is distributed on an "AS IS" BASIS,
00013  *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
00014  *  See the License for the specific language governing permissions and
00015  *  limitations under the License.
00016  *
00017  *=========================================================================*/
00018 /*=========================================================================
00019  *
00020  *  Portions of this file are subject to the VTK Toolkit Version 3 copyright.
00021  *
00022  *  Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
00023  *
00024  *  For complete copyright, license and disclaimer of warranty information
00025  *  please refer to the NOTICE file at the top of the ITK source tree.
00026  *
00027  *=========================================================================*/
00028 #ifndef __itkLSMImageIO_h
00029 #define __itkLSMImageIO_h
00030 
00031 #include "itkTIFFImageIO.h"
00032 #include <fstream>
00033 
00034 namespace itk
00035 {
00046 class ITK_EXPORT LSMImageIO:public TIFFImageIO
00047 {
00048 public:
00050   typedef LSMImageIO           Self;
00051   typedef ImageIOBase          Superclass;
00052   typedef SmartPointer< Self > Pointer;
00053 
00055   itkNewMacro(Self);
00056 
00058   itkTypeMacro(LSMImageIO, Superclass);
00059 
00060   /*-------- This part of the interface deals with reading data. ------ */
00061 
00064   virtual bool CanReadFile(const char *);
00065 
00067   virtual void ReadImageInformation();
00068 
00070   virtual void Read(void *buffer);
00071 
00072   /*-------- This part of the interfaces deals with writing data. ----- */
00073 
00076   virtual bool CanWriteFile(const char *);
00077 
00080   virtual void WriteImageInformation() {}
00081 
00084   virtual void Write(const void *buffer);
00085 
00086 protected:
00087   LSMImageIO();
00088   ~LSMImageIO();
00089   void PrintSelf(std::ostream & os, Indent indent) const;
00090 
00091 private:
00092   LSMImageIO(const Self &);     //purposely not implemented
00093   void operator=(const Self &); //purposely not implemented
00094 
00095   void FillZeissStruct(char *z);
00096 };
00097 } // end namespace itk
00098 
00099 #endif // __itkLSMImageIO_h
00100