mhdimagereader.h 2.96 KB
Newer Older
1
2
// ================================================================================================
// 
schultezub's avatar
schultezub committed
3
// This file is part of the CAMPVis Software Framework.
4
// 
5
// If not explicitly stated otherwise: Copyright (C) 2012-2013, all rights reserved,
schultezub's avatar
schultezub committed
6
//      Christian Schulte zu Berge <christian.szb@in.tum.de>
7
//      Chair for Computer Aided Medical Procedures
8
9
//      Technische Universität München
//      Boltzmannstr. 3, 85748 Garching b. München, Germany
10
// 
schultezub's avatar
schultezub committed
11
// For a full list of authors and contributors, please refer to the file "AUTHORS.txt".
12
// 
13
14
15
16
// Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file 
// except in compliance with the License. You may obtain a copy of the License at
// 
// http://www.apache.org/licenses/LICENSE-2.0
17
// 
18
19
20
21
// Unless required by applicable law or agreed to in writing, software distributed under the 
// License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, 
// either express or implied. See the License for the specific language governing permissions 
// and limitations under the License.
22
23
24
// 
// ================================================================================================

schultezub's avatar
schultezub committed
25
26
27
28
#ifndef MHDIMAGEREADER_H__
#define MHDIMAGEREADER_H__

#include <string>
29
#include "abstractimagereader.h"
schultezub's avatar
schultezub committed
30

31
#include "core/pipeline/abstractprocessor.h"
32
#include "core/properties/datanameproperty.h"
33
#include "core/properties/floatingpointproperty.h"
schultezub's avatar
schultezub committed
34

schultezub's avatar
schultezub committed
35
namespace campvis {
schultezub's avatar
schultezub committed
36
    /**
37
     * Reads a MHD image file into the pipeline.
schultezub's avatar
schultezub committed
38
39
40
     *
     * \note    Full format specification at http://www.itk.org/Wiki/MetaIO/Documentation
     */
41
    class MhdImageReader : public AbstractImageReader {
schultezub's avatar
schultezub committed
42
43
44
45
46
47
48
49
50
51
52
53
    public:
        /**
         * Constructs a new MhdImageReader Processor
         **/
        MhdImageReader();

        /**
         * Destructor
         **/
        virtual ~MhdImageReader();


54
        /**
55
         * Reads the MHD file into an ImageRepresentationDisk representation
56
57
58
         * \param data  DataContainer to work on
         */
        virtual void process(DataContainer& data);
schultezub's avatar
schultezub committed
59

60
61
        /// \see AbstractProcessor::getName()
        virtual const std::string getName() const { return "MhdImageReader"; };
62
63
        /// \see AbstractProcessor::getDescription()
        virtual const std::string getDescription() const { return "Reads an MHD image into the pipeline."; };
64
65
66
        /// \see AbstractProcessor::getAuthor()
        virtual const std::string getAuthor() const { return "Christian Schulte zu Berge <christian.szb@in.tum.de>"; };
        /// \see AbstractProcessor::getProcessorState()
67
        virtual ProcessorState getProcessorState() const { return AbstractProcessor::TESTING; };
schultezub's avatar
schultezub committed
68

69
70
71
        Vec3Property p_imageOffset;         ///< Image Offset in mm
        Vec3Property p_voxelSize;           ///< Voxel Size in mm

schultezub's avatar
schultezub committed
72
73
    protected:

schultezub's avatar
schultezub committed
74
75
76
77
78
        static const std::string loggerCat_;
    };

}

79
#endif // MHDIMAGEREADER_H__