comparison OrthancStone/Sources/Volumes/DicomVolumeImageMPRSlicer.h @ 1512:244ad1e4e76a

reorganization of folders
author Sebastien Jodogne <s.jodogne@gmail.com>
date Tue, 07 Jul 2020 16:21:02 +0200
parents Framework/Volumes/DicomVolumeImageMPRSlicer.h@2d8ab34c8c91
children 85e117739eca
comparison
equal deleted inserted replaced
1511:9dfeee74c1e6 1512:244ad1e4e76a
1 /**
2 * Stone of Orthanc
3 * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics
4 * Department, University Hospital of Liege, Belgium
5 * Copyright (C) 2017-2020 Osimis S.A., Belgium
6 *
7 * This program is free software: you can redistribute it and/or
8 * modify it under the terms of the GNU Affero General Public License
9 * as published by the Free Software Foundation, either version 3 of
10 * the License, or (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful, but
13 * WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * Affero General Public License for more details.
16 *
17 * You should have received a copy of the GNU Affero General Public License
18 * along with this program. If not, see <http://www.gnu.org/licenses/>.
19 **/
20
21
22 #pragma once
23
24 #include "DicomVolumeImage.h"
25 #include "IVolumeSlicer.h"
26
27 #include <boost/shared_ptr.hpp>
28
29 namespace OrthancStone
30 {
31 /**
32 Implements the IVolumeSlicer on Dicom volume data when the cutting plane
33 that is supplied to the slicer is either axial, sagittal or coronal.
34 Arbitrary planes are *not* supported
35 */
36 class DicomVolumeImageMPRSlicer : public IVolumeSlicer
37 {
38 public:
39 class Slice : public IExtractedSlice
40 {
41 private:
42 const DicomVolumeImage& volume_;
43 uint64_t revision_;
44 bool valid_;
45 VolumeProjection projection_;
46 unsigned int sliceIndex_;
47
48 void CheckValid() const;
49
50 public:
51 /**
52 Represents a slice of a volume image that is parallel to the
53 coordinate system axis.
54 The constructor initializes the type of projection (axial, sagittal or
55 coronal) and the corresponding slice index, from the cutting plane.
56 */
57 Slice(const DicomVolumeImage& volume,
58 const CoordinateSystem3D& cuttingPlane);
59
60 void SetRevision(uint64_t revision)
61 {
62 revision_ = revision;
63 }
64
65 VolumeProjection GetProjection() const;
66
67 unsigned int GetSliceIndex() const;
68
69 virtual bool IsValid()
70 {
71 return valid_;
72 }
73
74 virtual uint64_t GetRevision()
75 {
76 return revision_;
77 }
78
79 virtual ISceneLayer* CreateSceneLayer(const ILayerStyleConfigurator* configurator,
80 const CoordinateSystem3D& cuttingPlane);
81 };
82
83 private:
84 boost::shared_ptr<DicomVolumeImage> volume_;
85
86 public:
87 DicomVolumeImageMPRSlicer(const boost::shared_ptr<DicomVolumeImage>& volume) :
88 volume_(volume)
89 {
90 }
91
92 boost::shared_ptr<const DicomVolumeImage> GetVolume() const
93 {
94 return volume_;
95 }
96
97 virtual ~DicomVolumeImageMPRSlicer();
98
99 virtual IExtractedSlice* ExtractSlice(const CoordinateSystem3D& cuttingPlane) ORTHANC_OVERRIDE;
100 };
101 }