comparison Framework/Volumes/DicomVolumeImage.cpp @ 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 #include "DicomVolumeImage.h"
23
24 #include <Core/OrthancException.h>
25
26 namespace OrthancStone
27 {
28 void DicomVolumeImage::CheckHasGeometry() const
29 {
30 if (!HasGeometry())
31 {
32 throw Orthanc::OrthancException(Orthanc::ErrorCode_BadSequenceOfCalls);
33 }
34 }
35
36
37 void DicomVolumeImage::Initialize(const VolumeImageGeometry& geometry,
38 Orthanc::PixelFormat format)
39 {
40 geometry_.reset(new VolumeImageGeometry(geometry));
41 image_.reset(new ImageBuffer3D(format, geometry_->GetWidth(), geometry_->GetHeight(),
42 geometry_->GetDepth(), false /* don't compute range */));
43
44 revision_ ++;
45 }
46
47
48 void DicomVolumeImage::SetDicomParameters(const DicomInstanceParameters& parameters)
49 {
50 parameters_.reset(parameters.Clone());
51 revision_ ++;
52 }
53
54
55 bool DicomVolumeImage::HasGeometry() const
56 {
57 return (geometry_.get() != NULL &&
58 image_.get() != NULL);
59 }
60
61
62 ImageBuffer3D& DicomVolumeImage::GetPixelData()
63 {
64 CheckHasGeometry();
65 return *image_;
66 }
67
68
69 const ImageBuffer3D& DicomVolumeImage::GetPixelData() const
70 {
71 CheckHasGeometry();
72 return *image_;
73 }
74
75
76 const VolumeImageGeometry& DicomVolumeImage::GetGeometry() const
77 {
78 CheckHasGeometry();
79 return *geometry_;
80 }
81
82
83 const DicomInstanceParameters& DicomVolumeImage::GetDicomParameters() const
84 {
85 if (HasDicomParameters())
86 {
87 return *parameters_;
88 }
89 else
90 {
91 throw Orthanc::OrthancException(Orthanc::ErrorCode_BadSequenceOfCalls);
92 }
93 }
94 }