comparison Framework/Volumes/DicomVolumeImage.h @ 814:aead999345e0

reorganization
author Sebastien Jodogne <s.jodogne@gmail.com>
date Tue, 28 May 2019 21:16:39 +0200
parents
children 32eaf4929b08
comparison
equal deleted inserted replaced
813:bc7ee59420a1 814:aead999345e0
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-2019 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 ORTHANC_STONE_DEFINE_ORIGIN_MESSAGE(__FILE__, __LINE__, GeometryReadyMessage, DicomVolumeImage);
40 ORTHANC_STONE_DEFINE_ORIGIN_MESSAGE(__FILE__, __LINE__, ContentUpdatedMessage, DicomVolumeImage);
41
42 private:
43 uint64_t revision_;
44 std::auto_ptr<VolumeImageGeometry> geometry_;
45 std::auto_ptr<ImageBuffer3D> image_;
46 std::auto_ptr<DicomInstanceParameters> parameters_;
47
48 void CheckHasGeometry() const;
49
50 public:
51 DicomVolumeImage() :
52 revision_(0)
53 {
54 }
55
56 void IncrementRevision()
57 {
58 revision_ ++;
59 }
60
61 void Initialize(const VolumeImageGeometry& geometry,
62 Orthanc::PixelFormat format);
63
64 void SetDicomParameters(const DicomInstanceParameters& parameters);
65
66 uint64_t GetRevision() const
67 {
68 return revision_;
69 }
70
71 bool HasGeometry() const;
72
73 ImageBuffer3D& GetPixelData();
74
75 const ImageBuffer3D& GetPixelData() const;
76
77 const VolumeImageGeometry& GetGeometry() const;
78
79 bool HasDicomParameters() const
80 {
81 return parameters_.get() != NULL;
82 }
83
84 const DicomInstanceParameters& GetDicomParameters() const;
85 };
86 }