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 __rtkXRadImageIO_h
20 #define __rtkXRadImageIO_h
22 #include <itkImageIOBase.h>
26 #include "clitkCommon.h"
30 /** \class XRadImageIO
31 * \brief Class for reading XRad image file format. XRad is the format of
32 * exported X-ray projection images on the small animal irradiator SMART.
33 * http://www.pxinc.com/products/small-animal-igrt-platform/x-rad-225cx/
39 class XRadImageIO : public itk::ImageIOBase
42 /** Standard class typedefs. */
43 typedef XRadImageIO Self;
44 typedef itk::ImageIOBase Superclass;
45 typedef itk::SmartPointer<Self> Pointer;
47 XRadImageIO(): Superclass() {}
49 /** Method for creation through the object factory. */
52 /** Run-time type information (and related methods). */
53 itkTypeMacro(XRadImageIO, ImageIOBase);
55 /*-------- This part of the interface deals with reading data. ------ */
56 virtual void ReadImageInformation() ITK_OVERRIDE;
58 virtual bool CanReadFile( const char* FileNameToRead ) ITK_OVERRIDE;
60 virtual void Read(void * buffer) ITK_OVERRIDE;
62 /*-------- This part of the interfaces deals with writing data. ----- */
63 virtual void WriteImageInformation(bool keepOfStream);
65 virtual void WriteImageInformation() ITK_OVERRIDE {
66 WriteImageInformation(false);
69 virtual bool CanWriteFile(const char* filename) ITK_OVERRIDE;
71 virtual void Write(const void* buffer) ITK_OVERRIDE;
75 }; // end class XRadImageIO