annotate Sources/StructureSet.h @ 59:21335e91225e nexus

closing nexus
author Sebastien Jodogne <s.jodogne@gmail.com>
date Tue, 21 May 2024 16:03:07 +0200
parents ee3bc8f7df5b
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
35
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
1 /**
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
2 * SPDX-FileCopyrightText: 2023-2024 Sebastien Jodogne, UCLouvain, Belgium
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
3 * SPDX-License-Identifier: GPL-3.0-or-later
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
4 */
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
5
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
6 /**
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
7 * STL plugin for Orthanc
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
8 * Copyright (C) 2023-2024 Sebastien Jodogne, UCLouvain, Belgium
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
9 *
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
10 * This program is free software: you can redistribute it and/or
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
11 * modify it under the terms of the GNU General Public License as
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
12 * published by the Free Software Foundation, either version 3 of the
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
13 * License, or (at your option) any later version.
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
14 *
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
15 * This program is distributed in the hope that it will be useful, but
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
16 * WITHOUT ANY WARRANTY; without even the implied warranty of
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
18 * General Public License for more details.
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
19 *
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
20 * You should have received a copy of the GNU General Public License
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
21 * along with this program. If not, see <http://www.gnu.org/licenses/>.
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
22 **/
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
23
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
24
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
25 #pragma once
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
26
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
27 #include "StructurePolygon.h"
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
28
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
29 class StructureSet : public boost::noncopyable
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
30 {
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
31 private:
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
32 std::vector<StructurePolygon*> polygons_;
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
33 std::string patientId_;
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
34 std::string studyInstanceUid_;
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
35 std::string seriesInstanceUid_;
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
36 std::string sopInstanceUid_;
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
37 bool hasFrameOfReferenceUid_;
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
38 std::string frameOfReferenceUid_;
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
39
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
40 public:
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
41 explicit StructureSet(Orthanc::ParsedDicomFile& dicom);
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
42
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
43 ~StructureSet();
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
44
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
45 const std::string& GetPatientId() const
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
46 {
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
47 return patientId_;
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
48 }
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
49
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
50 const std::string& GetStudyInstanceUid() const
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
51 {
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
52 return studyInstanceUid_;
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
53 }
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
54
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
55 const std::string& GetSeriesInstanceUid() const
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
56 {
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
57 return seriesInstanceUid_;
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
58 }
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
59
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
60 const std::string& GetSopInstanceUid() const
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
61 {
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
62 return sopInstanceUid_;
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
63 }
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
64
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
65 std::string HashStudy() const;
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
66
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
67 size_t GetPolygonsCount() const
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
68 {
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
69 return polygons_.size();
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
70 }
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
71
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
72 const StructurePolygon& GetPolygon(size_t i) const;
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
73
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
74 bool HasFrameOfReferenceUid() const
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
75 {
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
76 return hasFrameOfReferenceUid_;
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
77 }
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
78
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
79 const std::string& GetFrameOfReferenceUid() const;
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
80
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
81 // This static method is faster than constructing the full "StructureSet" object
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
82 static void ListStructuresNames(std::set<std::string>& target,
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
83 Orthanc::ParsedDicomFile& source);
ee3bc8f7df5b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
84 };