comparison OrthancStone/Sources/Volumes/DicomVolumeImage.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/DicomVolumeImage.h@257f2c9a02ac
children 4fb8fdf03314
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 "../Messages/IMessage.h"
25 #include "../Toolbox/DicomInstanceParameters.h"
26 #include "ImageBuffer3D.h"
27 #include "VolumeImageGeometry.h"
28
29 namespace OrthancStone
30 {
31 /**
32 This class combines a 3D image buffer, a 3D volume geometry and
33 information about the DICOM parameters of the series.
34 (MPR means MultiPlanar Reconstruction)
35 */
36 class DicomVolumeImage : public boost::noncopyable
37 {
38 public:
39 // TODO - Are these messages still useful?
40 ORTHANC_STONE_DEFINE_ORIGIN_MESSAGE(__FILE__, __LINE__, GeometryReadyMessage, DicomVolumeImage);
41 ORTHANC_STONE_DEFINE_ORIGIN_MESSAGE(__FILE__, __LINE__, ContentUpdatedMessage, DicomVolumeImage);
42
43 private:
44 uint64_t revision_;
45 std::unique_ptr<VolumeImageGeometry> geometry_;
46 std::unique_ptr<ImageBuffer3D> image_;
47 std::unique_ptr<DicomInstanceParameters> parameters_;
48
49 void CheckHasGeometry() const;
50
51 public:
52 DicomVolumeImage() :
53 revision_(0)
54 {
55 }
56
57 void IncrementRevision()
58 {
59 revision_ ++;
60 }
61
62 void Initialize(const VolumeImageGeometry& geometry,
63 Orthanc::PixelFormat format,
64 bool computeRange = false);
65
66 // Used by volume slicers
67 void SetDicomParameters(const DicomInstanceParameters& parameters);
68
69 uint64_t GetRevision() const
70 {
71 return revision_;
72 }
73
74 bool HasGeometry() const;
75
76 ImageBuffer3D& GetPixelData();
77
78 const ImageBuffer3D& GetPixelData() const;
79
80 const VolumeImageGeometry& GetGeometry() const;
81
82 bool HasDicomParameters() const
83 {
84 return parameters_.get() != NULL;
85 }
86
87 const DicomInstanceParameters& GetDicomParameters() const;
88 };
89 }