annotate Sources/StructurePolygon.h @ 35:ee3bc8f7df5b

reorganization
author Sebastien Jodogne <s.jodogne@gmail.com>
date Thu, 04 Apr 2024 20:37:08 +0200
parents 2460b376d3f7
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
33
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
1 /**
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
2 * SPDX-FileCopyrightText: 2023-2024 Sebastien Jodogne, UCLouvain, Belgium
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
3 * SPDX-License-Identifier: GPL-3.0-or-later
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
4 */
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
5
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
6 /**
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
7 * STL plugin for Orthanc
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
8 * Copyright (C) 2023-2024 Sebastien Jodogne, UCLouvain, Belgium
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
9 *
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
10 * This program is free software: you can redistribute it and/or
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
11 * modify it under the terms of the GNU General Public License as
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
12 * published by the Free Software Foundation, either version 3 of the
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
13 * License, or (at your option) any later version.
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
14 *
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
15 * This program is distributed in the hope that it will be useful, but
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
16 * WITHOUT ANY WARRANTY; without even the implied warranty of
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
18 * General Public License for more details.
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
19 *
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
20 * You should have received a copy of the GNU General Public License
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
21 * along with this program. If not, see <http://www.gnu.org/licenses/>.
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
22 **/
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
23
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
24
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
25 #pragma once
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
26
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
27 #include "Extent2D.h"
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
28 #include "Vector3D.h"
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
29
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
30 #include <DicomParsing/ParsedDicomFile.h>
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
31
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
32
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
33 class StructurePolygon : public boost::noncopyable
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
34 {
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
35 private:
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
36 std::string roiName_;
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
37 std::string referencedSopInstanceUid_;
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
38 uint8_t red_;
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
39 uint8_t green_;
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
40 uint8_t blue_;
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
41 std::vector<Vector3D> points_;
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
42
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
43 public:
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
44 StructurePolygon(Orthanc::ParsedDicomFile& dicom,
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
45 unsigned long roiIndex,
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
46 unsigned long contourIndex);
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
47
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
48 const std::string& GetRoiName() const
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
49 {
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
50 return roiName_;
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
51 }
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
52
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
53 const std::string& GetReferencedSopInstanceUid() const
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
54 {
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
55 return referencedSopInstanceUid_;
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
56 }
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
57
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
58 size_t GetPointsCount() const
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
59 {
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
60 return points_.size();
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
61 }
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
62
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
63 const Vector3D& GetPoint(size_t i) const;
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
64
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
65 bool IsCoplanar(Vector3D& normal) const;
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
66
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
67 void Add(Extent2D& extent,
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
68 const Vector3D& axisX,
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
69 const Vector3D& axisY) const;
2460b376d3f7 reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
70 };