comparison Plugin/SeriesVolumeSorter.h @ 0:02f7a0400a91

initial commit
author Sebastien Jodogne <s.jodogne@gmail.com>
date Wed, 25 Feb 2015 13:45:35 +0100
parents
children
comparison
equal deleted inserted replaced
-1:000000000000 0:02f7a0400a91
1 /**
2 * Orthanc - A Lightweight, RESTful DICOM Store
3 * Copyright (C) 2012-2015 Sebastien Jodogne, Medical Physics
4 * Department, University Hospital of Liege, Belgium
5 *
6 * This program is free software: you can redistribute it and/or
7 * modify it under the terms of the GNU Affero General Public License
8 * as published by the Free Software Foundation, either version 3 of
9 * the License, or (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful, but
12 * WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Affero General Public License for more details.
15 *
16 * You should have received a copy of the GNU Affero General Public License
17 * along with this program. If not, see <http://www.gnu.org/licenses/>.
18 **/
19
20
21 #pragma once
22
23 #include "InstanceInformation.h"
24
25 #include <json/reader.h>
26 #include <boost/noncopyable.hpp>
27
28 namespace OrthancPlugins
29 {
30 class SeriesVolumeSorter : public boost::noncopyable
31 {
32 private:
33 typedef std::pair<std::string, float> InstanceWithPosition;
34 typedef std::pair<std::string, int> InstanceWithIndex;
35
36 static bool ComparePosition(const InstanceWithPosition& a,
37 const InstanceWithPosition& b)
38 {
39 return a.second < b.second;
40 }
41
42 static bool CompareIndex(const InstanceWithIndex& a,
43 const InstanceWithIndex& b)
44 {
45 return a.second < b.second;
46 }
47
48 bool sorted_;
49 bool isVolume_;
50 float normal_[3];
51
52 std::vector<InstanceWithPosition> positions_;
53 std::vector<InstanceWithIndex> indexes_;
54
55 public:
56 SeriesVolumeSorter();
57
58 void Reserve(size_t countInstances);
59
60 void AddInstance(const std::string& instanceId,
61 const InstanceInformation& instance);
62
63 size_t GetSize() const
64 {
65 return indexes_.size();
66 }
67
68 std::string GetInstance(size_t index);
69 };
70 }