comparison OrthancStone/Sources/Loaders/SeriesOrderedFrames.h @ 1512:244ad1e4e76a

reorganization of folders
author Sebastien Jodogne <s.jodogne@gmail.com>
date Tue, 07 Jul 2020 16:21:02 +0200
parents Framework/Loaders/SeriesOrderedFrames.h@0ca50d275b9a
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 "LoadedDicomResources.h"
25
26 #include "../Toolbox/DicomInstanceParameters.h"
27
28 namespace OrthancStone
29 {
30 class SeriesOrderedFrames : public boost::noncopyable
31 {
32 private:
33 class Instance;
34 class Frame;
35 class InstanceWithIndexInSeries;
36
37 std::vector<Instance*> instances_;
38 std::vector<Frame*> orderedFrames_;
39 bool isVolume_;
40 bool isRegular_;
41 double spacingBetweenSlices_;
42
43 void Clear();
44
45 bool Sort3DVolume();
46
47 void SortIndexInSeries();
48
49 const Frame& GetFrame(size_t seriesIndex) const;
50
51 public:
52 SeriesOrderedFrames(LoadedDicomResources& instances);
53
54 ~SeriesOrderedFrames()
55 {
56 Clear();
57 }
58
59 size_t GetFramesCount() const
60 {
61 return orderedFrames_.size();
62 }
63
64 unsigned int GetFrameIndex(size_t seriesIndex) const;
65
66 const Orthanc::DicomMap& GetInstance(size_t seriesIndex) const;
67
68 const DicomInstanceParameters& GetInstanceParameters(size_t seriesIndex) const;
69
70 // Are all frames parallel and aligned?
71 bool Is3DVolume() const
72 {
73 return isVolume_;
74 }
75
76 // Are all frames parallel, aligned and evenly spaced?
77 bool IsRegular3DVolume() const
78 {
79 return isRegular_;
80 }
81
82 // Only available on regular 3D volumes
83 double GetSpacingBetweenSlices() const;
84 };
85 }