1 /*=========================================================================
3 * Copyright RTK Consortium
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
9 * http://www.apache.org/licenses/LICENSE-2.0.txt
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
17 *=========================================================================*/
19 #ifndef __rtkHisImageIO_h
20 #define __rtkHisImageIO_h
23 #include <itkImageIOBase.h>
29 * \brief Class for reading His Image file format
31 * The his image file format is used by Perkin Elmer flat panels.
37 class HisImageIO : public itk::ImageIOBase
40 /** Standard class typedefs. */
41 typedef HisImageIO Self;
42 typedef itk::ImageIOBase Superclass;
43 typedef itk::SmartPointer<Self> Pointer;
44 typedef signed short int PixelType;
46 HisImageIO() : Superclass() {
50 /** Method for creation through the object factory. */
53 /** Run-time type information (and related methods). */
54 itkTypeMacro(HisImageIO, itk::ImageIOBase);
56 /*-------- This part of the interface deals with reading data. ------ */
57 virtual void ReadImageInformation();
59 virtual bool CanReadFile( const char* FileNameToRead );
61 virtual void Read(void * buffer);
63 /*-------- This part of the interfaces deals with writing data. ----- */
64 virtual void WriteImageInformation(bool /*keepOfStream*/) {
68 virtual void WriteImageInformation() {
69 WriteImageInformation(false);
72 virtual bool CanWriteFile(const char* filename);
74 virtual void Write(const void* buffer);
79 }; // end class HisImageIO
82 #endif /* end #define __rtkHisImageIO_h */