Mercurial > hg > orthanc-stl
annotate Sources/Plugin.cpp @ 70:a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Fri, 04 Oct 2024 17:12:49 +0200 |
parents | 054e36474998 |
children | e94f177c3653 |
rev | line source |
---|---|
0
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1 /** |
24 | 2 * SPDX-FileCopyrightText: 2023-2024 Sebastien Jodogne, UCLouvain, Belgium |
0
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
3 * SPDX-License-Identifier: GPL-3.0-or-later |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
4 */ |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
5 |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
6 /** |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
7 * STL plugin for Orthanc |
24 | 8 * Copyright (C) 2023-2024 Sebastien Jodogne, UCLouvain, Belgium |
0
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
9 * |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
10 * This program is free software: you can redistribute it and/or |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
11 * modify it under the terms of the GNU General Public License as |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
12 * published by the Free Software Foundation, either version 3 of the |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
13 * License, or (at your option) any later version. |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
14 * |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
15 * This program is distributed in the hope that it will be useful, but |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
16 * WITHOUT ANY WARRANTY; without even the implied warranty of |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
18 * General Public License for more details. |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
19 * |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
20 * You should have received a copy of the GNU General Public License |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
21 * along with this program. If not, see <http://www.gnu.org/licenses/>. |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
22 **/ |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
23 |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
24 |
46
9b2a2fcc9878
added option to disable Nexus support
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
45
diff
changeset
|
25 #if !defined(ORTHANC_ENABLE_NEXUS) |
9b2a2fcc9878
added option to disable Nexus support
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
45
diff
changeset
|
26 # error Macro ORTHANC_ENABLE_NEXUS must be defined |
9b2a2fcc9878
added option to disable Nexus support
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
45
diff
changeset
|
27 #endif |
9b2a2fcc9878
added option to disable Nexus support
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
45
diff
changeset
|
28 |
62
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
29 #if !defined(ORTHANC_ENABLE_3DHOP) |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
30 # error Macro ORTHANC_ENABLE_3DHOP must be defined |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
31 #endif |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
32 |
35 | 33 #include "StructureSetGeometry.h" |
34 | 34 #include "STLToolbox.h" |
32 | 35 #include "VTKToolbox.h" |
40 | 36 |
37 #include <EmbeddedResources.h> | |
32 | 38 |
0
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
39 #include "../Resources/Orthanc/Plugins/OrthancPluginCppWrapper.h" |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
40 |
4
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
41 #include <DicomParsing/FromDcmtkBridge.h> |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
42 #include <Images/ImageProcessing.h> |
0
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
43 #include <Logging.h> |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
44 #include <SerializationToolbox.h> |
0
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
45 #include <SystemToolbox.h> |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
46 |
33 | 47 #include <vtkNew.h> |
48 | |
36
13698d34e059
preparing to include O3DV
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
35
diff
changeset
|
49 #include <boost/algorithm/string.hpp> |
0
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
50 #include <boost/thread/shared_mutex.hpp> |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
51 |
46
9b2a2fcc9878
added option to disable Nexus support
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
45
diff
changeset
|
52 |
9b2a2fcc9878
added option to disable Nexus support
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
45
diff
changeset
|
53 #if ORTHANC_ENABLE_NEXUS == 1 |
9b2a2fcc9878
added option to disable Nexus support
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
45
diff
changeset
|
54 # include <Cache/MemoryStringCache.h> |
9b2a2fcc9878
added option to disable Nexus support
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
45
diff
changeset
|
55 #endif |
9b2a2fcc9878
added option to disable Nexus support
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
45
diff
changeset
|
56 |
25
5fc3ea6acbd5
fix deprecated calls
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
24
diff
changeset
|
57 #define ORTHANC_PLUGIN_NAME "stl" |
5fc3ea6acbd5
fix deprecated calls
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
24
diff
changeset
|
58 |
6 | 59 |
50
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
60 #if ORTHANC_ENABLE_NEXUS == 1 |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
61 static const char* const ORTHANC_STL_PRIVATE_CREATOR = "OrthancSTL"; |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
62 static const char* const ORTHANC_STL_MANUFACTURER = "ORTHANC^STL"; |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
63 static const uint16_t ORTHANC_STL_PRIVATE_GROUP = 0x4205u; |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
64 static const uint16_t ORTHANC_STL_CREATOR_ELEMENT = 0x0010u; |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
65 static const uint16_t ORTHANC_STL_NEXUS_ELEMENT = 0x1001u; |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
66 static const Orthanc::DicomTag DICOM_TAG_CREATOR_VERSION_UID(0x0008, 0x9123); |
53
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
67 |
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
68 /** |
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
69 * Each version of the STL plugin must provide a different value for |
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
70 * the CreatorVersionUID (0008,9123) tag. A new UID can be generated |
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
71 * by typing: |
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
72 * |
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
73 * $ python -c 'import pydicom; print(pydicom.uid.generate_uid())' |
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
74 * |
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
75 **/ |
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
76 static const char* const ORTHANC_STL_CREATOR_VERSION_UID_MAINLINE = "1.2.826.0.1.3680043.8.498.90514926286349109728701975613711986292"; |
60 | 77 static const char* const ORTHANC_STL_CREATOR_VERSION_UID_1_1 = "1.2.826.0.1.3680043.8.498.13468660186379895313063577332103681503"; |
68 | 78 static const char* const ORTHANC_STL_CREATOR_VERSION_UID_1_2 = "1.2.826.0.1.3680043.8.498.69380801008493335183088431949117714013"; |
53
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
79 |
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
80 static const char* const GetCreatorVersionUid(const std::string& version) |
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
81 { |
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
82 if (version == "mainline") |
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
83 { |
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
84 return ORTHANC_STL_CREATOR_VERSION_UID_MAINLINE; |
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
85 } |
60 | 86 else if (version == "1.1") |
87 { | |
88 return ORTHANC_STL_CREATOR_VERSION_UID_1_1; | |
89 } | |
68 | 90 else if (version == "1.2") |
91 { | |
92 return ORTHANC_STL_CREATOR_VERSION_UID_1_2; | |
93 } | |
53
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
94 else |
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
95 { |
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
96 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError); |
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
97 } |
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
98 } |
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
99 |
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
100 static void FillOrthancExplorerCreatorVersionUid(std::map<std::string, std::string>& dictionary) |
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
101 { |
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
102 dictionary["ORTHANC_STL_CREATOR_VERSION_UID_MAINLINE"] = ORTHANC_STL_CREATOR_VERSION_UID_MAINLINE; |
60 | 103 dictionary["ORTHANC_STL_CREATOR_VERSION_UID_1_1"] = ORTHANC_STL_CREATOR_VERSION_UID_1_1; |
68 | 104 dictionary["ORTHANC_STL_CREATOR_VERSION_UID_1_2"] = ORTHANC_STL_CREATOR_VERSION_UID_1_2; |
53
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
105 } |
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
106 |
50
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
107 #endif |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
108 |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
109 |
0
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
110 // Forward declaration |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
111 void ReadStaticAsset(std::string& target, |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
112 const std::string& path); |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
113 |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
114 |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
115 /** |
38 | 116 * As the static assets are gzipped by the "EmbedStaticAssets.py" |
117 * script, we use a cache to maintain the uncompressed assets in order | |
118 * to avoid multiple gzip decodings. | |
0
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
119 **/ |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
120 class ResourcesCache : public boost::noncopyable |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
121 { |
70
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
122 public: |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
123 class IHandler : public boost::noncopyable |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
124 { |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
125 public: |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
126 virtual ~IHandler() |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
127 { |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
128 } |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
129 |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
130 virtual void Apply(const std::string& resource) = 0; |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
131 }; |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
132 |
0
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
133 private: |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
134 typedef std::map<std::string, std::string*> Content; |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
135 |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
136 boost::shared_mutex mutex_; |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
137 Content content_; |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
138 |
70
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
139 class RestOutputHandler : public IHandler |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
140 { |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
141 private: |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
142 OrthancPluginRestOutput* output_; |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
143 std::string mime_; |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
144 |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
145 public: |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
146 RestOutputHandler(OrthancPluginRestOutput* output, |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
147 const std::string& mime) : |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
148 output_(output), |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
149 mime_(mime) |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
150 { |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
151 } |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
152 |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
153 virtual void Apply(const std::string& resource) ORTHANC_OVERRIDE |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
154 { |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
155 OrthancPluginAnswerBuffer(OrthancPlugins::GetGlobalContext(), output_, |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
156 resource.c_str(), resource.size(), mime_.c_str()); |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
157 } |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
158 }; |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
159 |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
160 class StoreResourceIntoString : public IHandler |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
161 { |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
162 private: |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
163 std::string& target_; |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
164 |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
165 public: |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
166 StoreResourceIntoString(std::string& target) : |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
167 target_(target) |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
168 { |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
169 } |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
170 |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
171 virtual void Apply(const std::string& resource) ORTHANC_OVERRIDE |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
172 { |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
173 target_ = resource; |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
174 } |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
175 }; |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
176 |
0
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
177 public: |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
178 ~ResourcesCache() |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
179 { |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
180 for (Content::iterator it = content_.begin(); it != content_.end(); ++it) |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
181 { |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
182 assert(it->second != NULL); |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
183 delete it->second; |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
184 } |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
185 } |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
186 |
70
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
187 void Apply(IHandler& handler, |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
188 const std::string& path) |
0
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
189 { |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
190 { |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
191 // Check whether the cache already contains the resource |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
192 boost::shared_lock<boost::shared_mutex> lock(mutex_); |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
193 |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
194 Content::const_iterator found = content_.find(path); |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
195 |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
196 if (found != content_.end()) |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
197 { |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
198 assert(found->second != NULL); |
70
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
199 handler.Apply(*found->second); |
0
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
200 return; |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
201 } |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
202 } |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
203 |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
204 // This resource has not been cached yet |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
205 |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
206 std::unique_ptr<std::string> item(new std::string); |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
207 ReadStaticAsset(*item, path); |
70
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
208 handler.Apply(*item); |
0
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
209 |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
210 { |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
211 // Store the resource into the cache |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
212 boost::unique_lock<boost::shared_mutex> lock(mutex_); |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
213 |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
214 if (content_.find(path) == content_.end()) |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
215 { |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
216 content_[path] = item.release(); |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
217 } |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
218 } |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
219 } |
70
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
220 |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
221 void Answer(OrthancPluginRestOutput* output, |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
222 const std::string& path) |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
223 { |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
224 const std::string mime = Orthanc::EnumerationToString(Orthanc::SystemToolbox::AutodetectMimeType(path)); |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
225 |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
226 RestOutputHandler handler(output, mime); |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
227 Apply(handler, path); |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
228 } |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
229 |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
230 void ReadResource(std::string& target, |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
231 const std::string& path) |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
232 { |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
233 StoreResourceIntoString handler(target); |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
234 Apply(handler, path); |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
235 } |
0
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
236 }; |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
237 |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
238 |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
239 static ResourcesCache cache_; |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
240 |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
241 void ServeFile(OrthancPluginRestOutput* output, |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
242 const char* url, |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
243 const OrthancPluginHttpRequest* request) |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
244 { |
3
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
245 if (request->method != OrthancPluginHttpMethod_Get) |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
246 { |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
247 OrthancPluginSendMethodNotAllowed(OrthancPlugins::GetGlobalContext(), output, "GET"); |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
248 return; |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
249 } |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
250 |
45
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
251 const std::string file = request->groups[0]; |
0
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
252 |
62
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
253 if (boost::starts_with(file, "basic-viewer/") || |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
254 boost::starts_with(file, "o3dv/")) |
0
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
255 { |
62
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
256 cache_.Answer(output, file); |
0
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
257 } |
38 | 258 else |
259 { | |
260 Orthanc::EmbeddedResources::FileResourceId resourceId; | |
261 Orthanc::MimeType mimeType; | |
262 | |
263 if (file == "three.html") | |
264 { | |
265 resourceId = Orthanc::EmbeddedResources::THREE_HTML; | |
266 mimeType = Orthanc::MimeType_Html; | |
267 } | |
268 else if (file == "three.js") | |
269 { | |
270 resourceId = Orthanc::EmbeddedResources::THREE_JS; | |
271 mimeType = Orthanc::MimeType_JavaScript; | |
272 } | |
273 else if (file == "o3dv.html") | |
274 { | |
275 resourceId = Orthanc::EmbeddedResources::O3DV_HTML; | |
276 mimeType = Orthanc::MimeType_Html; | |
277 } | |
278 else if (file == "o3dv.js") | |
279 { | |
280 resourceId = Orthanc::EmbeddedResources::O3DV_JS; | |
281 mimeType = Orthanc::MimeType_JavaScript; | |
282 } | |
283 else | |
284 { | |
285 OrthancPluginSendHttpStatusCode(OrthancPlugins::GetGlobalContext(), output, 404); | |
286 return; | |
287 } | |
288 | |
289 std::string s; | |
290 Orthanc::EmbeddedResources::GetFileResource(s, resourceId); | |
291 OrthancPluginAnswerBuffer(OrthancPlugins::GetGlobalContext(), output, s.c_str(), s.size(), Orthanc::EnumerationToString(mimeType)); | |
292 } | |
0
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
293 } |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
294 |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
295 |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
296 |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
297 |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
298 #include <dcmtk/dcmdata/dcfilefo.h> |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
299 #include <dcmtk/dcmdata/dcsequen.h> |
29
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
300 #include <dcmtk/dcmdata/dcuid.h> |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
301 |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
302 |
40 | 303 namespace |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
304 { |
40 | 305 class XorFiller : public Orthanc::ImageProcessing::IPolygonFiller |
306 { | |
307 private: | |
308 Orthanc::ImageAccessor& target_; | |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
309 |
40 | 310 public: |
311 explicit XorFiller(Orthanc::ImageAccessor& target) : | |
312 target_(target) | |
313 { | |
314 } | |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
315 |
40 | 316 virtual void Fill(int y, |
317 int x1, | |
318 int x2) ORTHANC_OVERRIDE | |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
319 { |
40 | 320 assert(x1 <= x2); |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
321 |
40 | 322 if (y >= 0 && |
323 y < static_cast<int>(target_.GetHeight())) | |
324 { | |
325 x1 = std::max(x1, 0); | |
326 x2 = std::min(x2, static_cast<int>(target_.GetWidth()) - 1); | |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
327 |
40 | 328 uint8_t* p = reinterpret_cast<uint8_t*>(target_.GetRow(y)) + x1; |
329 | |
330 for (int i = x1; i <= x2; i++, p++) | |
331 { | |
332 *p = (*p ^ 0xff); | |
333 } | |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
334 } |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
335 } |
40 | 336 }; |
337 } | |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
338 |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
339 |
29
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
340 static Orthanc::ParsedDicomFile* LoadInstance(const std::string& instanceId) |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
341 { |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
342 std::string dicom; |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
343 |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
344 if (!OrthancPlugins::RestApiGetString(dicom, "/instances/" + instanceId + "/file", false)) |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
345 { |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
346 throw Orthanc::OrthancException(Orthanc::ErrorCode_UnknownResource); |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
347 } |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
348 else |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
349 { |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
350 return new Orthanc::ParsedDicomFile(dicom); |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
351 } |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
352 } |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
353 |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
354 |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
355 static void GetReferencedVolumeAxes(Vector3D& axisX, |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
356 Vector3D& axisY, |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
357 const StructureSet& structureSet) |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
358 { |
29
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
359 // This is a rough guess for the X/Y axes |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
360 axisX = Vector3D(1, 0, 0); |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
361 axisY = Vector3D(0, 1, 0); |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
362 |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
363 // Look for one instance from the referenced volume |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
364 const std::string& sopInstanceUid = structureSet.GetPolygon(0).GetReferencedSopInstanceUid(); |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
365 |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
366 Json::Value response; |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
367 if (OrthancPlugins::RestApiPost(response, "/tools/lookup", sopInstanceUid, false)) |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
368 { |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
369 if (response.type() != Json::arrayValue) |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
370 { |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
371 throw Orthanc::OrthancException(Orthanc::ErrorCode_NetworkProtocol); |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
372 } |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
373 |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
374 bool first = true; |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
375 |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
376 for (Json::Value::ArrayIndex i = 0; i < response.size(); i++) |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
377 { |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
378 if (response[i].type() != Json::objectValue) |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
379 { |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
380 throw Orthanc::OrthancException(Orthanc::ErrorCode_NetworkProtocol); |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
381 } |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
382 |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
383 if (Orthanc::SerializationToolbox::ReadString(response[i], "Type") == "Instance") |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
384 { |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
385 if (first) |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
386 { |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
387 const std::string& instanceId = Orthanc::SerializationToolbox::ReadString(response[i], "ID"); |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
388 std::unique_ptr<Orthanc::ParsedDicomFile> reference(LoadInstance(instanceId)); |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
389 |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
390 std::string imageOrientation; |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
391 if (reference->GetTagValue(imageOrientation, Orthanc::DICOM_TAG_IMAGE_ORIENTATION_PATIENT)) |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
392 { |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
393 std::vector<std::string> items; |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
394 Orthanc::Toolbox::TokenizeString(items, imageOrientation, '\\'); |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
395 |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
396 double x1, x2, x3, y1, y2, y3; |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
397 |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
398 if (items.size() == 6 && |
33 | 399 STLToolbox::MyParseDouble(x1, items[0]) && |
400 STLToolbox::MyParseDouble(x2, items[1]) && | |
401 STLToolbox::MyParseDouble(x3, items[2]) && | |
402 STLToolbox::MyParseDouble(y1, items[3]) && | |
403 STLToolbox::MyParseDouble(y2, items[4]) && | |
404 STLToolbox::MyParseDouble(y3, items[5])) | |
29
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
405 { |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
406 axisX = Vector3D(x1, x2, x3); |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
407 axisY = Vector3D(y1, y2, y3); |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
408 } |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
409 } |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
410 } |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
411 else |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
412 { |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
413 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError, |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
414 "Multiple instances with the same SOP Instance UID"); |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
415 } |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
416 } |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
417 } |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
418 } |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
419 } |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
420 |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
421 |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
422 static bool EncodeStructureSetMesh(std::string& stl, |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
423 const StructureSet& structureSet, |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
424 const StructureSetGeometry& geometry, |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
425 const std::set<std::string>& roiNames, |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
426 unsigned int resolution, |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
427 bool smooth) |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
428 { |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
429 if (resolution < 1 || |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
430 structureSet.GetPolygonsCount() < 1) |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
431 { |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
432 throw Orthanc::OrthancException(Orthanc::ErrorCode_ParameterOutOfRange); |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
433 } |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
434 |
33 | 435 if (!STLToolbox::IsNear(1, geometry.GetSlicesNormal().ComputeNorm())) |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
436 { |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
437 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError); |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
438 } |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
439 |
29
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
440 Vector3D axisX, axisY; |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
441 GetReferencedVolumeAxes(axisX, axisY, structureSet); |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
442 |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
443 Vector3D axisZ = Vector3D::CrossProduct(axisX, axisY); |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
444 |
33 | 445 if (!STLToolbox::IsNear(1, axisX.ComputeNorm()) || |
446 !STLToolbox::IsNear(1, axisY.ComputeNorm()) || | |
29
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
447 !Vector3D::AreParallel(axisZ, geometry.GetSlicesNormal())) |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
448 { |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
449 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError); |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
450 } |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
451 |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
452 Extent2D extent; |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
453 for (size_t i = 0; i < structureSet.GetPolygonsCount(); i++) |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
454 { |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
455 structureSet.GetPolygon(i).Add(extent, axisX, axisY); |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
456 } |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
457 |
28
410003c50b17
improved computation of RT-STRUCT geometry
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
25
diff
changeset
|
458 const int depth = geometry.GetSlicesCount(); |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
459 |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
460 vtkNew<vtkImageData> volume; |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
461 volume->SetDimensions(resolution, resolution, depth); |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
462 volume->AllocateScalars(VTK_UNSIGNED_CHAR, 1); |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
463 |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
464 assert(sizeof(unsigned char) == 1); |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
465 memset(volume->GetScalarPointer(), 0, resolution * resolution * depth); |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
466 |
30 | 467 const double pixelSpacingX = extent.GetWidth() / static_cast<double>(resolution); |
468 const double pixelSpacingY = extent.GetHeight() / static_cast<double>(resolution); | |
469 const double pixelSpacingZ = geometry.GetSlicesSpacing(); | |
470 | |
471 bool first = true; | |
472 | |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
473 for (size_t i = 0; i < structureSet.GetPolygonsCount(); i++) |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
474 { |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
475 const StructurePolygon& polygon = structureSet.GetPolygon(i); |
29
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
476 if (roiNames.find(polygon.GetRoiName()) != roiNames.end()) |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
477 { |
29
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
478 // This polygon corresponds to a ROI of interest |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
479 |
29
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
480 size_t z; |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
481 if (geometry.LookupSliceIndex(z, polygon)) |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
482 { |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
483 std::vector<Orthanc::ImageProcessing::ImagePoint> points; |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
484 points.reserve(polygon.GetPointsCount()); |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
485 |
29
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
486 for (size_t j = 0; j < polygon.GetPointsCount(); j++) |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
487 { |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
488 const Vector3D& point = polygon.GetPoint(j); |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
489 double x = (Vector3D::DotProduct(point, axisX) - extent.GetMinX()) / extent.GetWidth() * static_cast<double>(resolution); |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
490 double y = (Vector3D::DotProduct(point, axisY) - extent.GetMinY()) / extent.GetHeight() * static_cast<double>(resolution); |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
491 points.push_back(Orthanc::ImageProcessing::ImagePoint(static_cast<int32_t>(std::floor(x)), |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
492 static_cast<int32_t>(std::floor(y)))); |
30 | 493 |
494 if (first) | |
495 { | |
496 first = false; | |
497 volume->SetOrigin(point.GetX() - x * pixelSpacingX, | |
498 point.GetY() - y * pixelSpacingY, | |
499 point.GetZ() - z * pixelSpacingZ); | |
500 } | |
29
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
501 } |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
502 |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
503 Orthanc::ImageAccessor slice; |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
504 slice.AssignWritable(Orthanc::PixelFormat_Grayscale8, resolution, resolution, resolution /* pitch */, |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
505 reinterpret_cast<uint8_t*>(volume->GetScalarPointer()) + z * resolution * resolution); |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
506 |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
507 XorFiller filler(slice); |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
508 Orthanc::ImageProcessing::FillPolygon(filler, points); |
62abf3c523f9
big endian support, retrieve axes from referenced volume
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
28
diff
changeset
|
509 } |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
510 } |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
511 } |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
512 |
30 | 513 volume->SetSpacing(pixelSpacingX, pixelSpacingY, pixelSpacingZ); |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
514 |
32 | 515 return VTKToolbox::EncodeVolume(stl, volume.Get(), resolution, smooth); |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
516 } |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
517 |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
518 |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
519 void ListStructures(OrthancPluginRestOutput* output, |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
520 const char* url, |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
521 const OrthancPluginHttpRequest* request) |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
522 { |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
523 if (request->method != OrthancPluginHttpMethod_Get) |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
524 { |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
525 OrthancPluginSendMethodNotAllowed(OrthancPlugins::GetGlobalContext(), output, "GET"); |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
526 return; |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
527 } |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
528 |
3
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
529 const std::string instanceId(request->groups[0]); |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
530 |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
531 std::unique_ptr<Orthanc::ParsedDicomFile> dicom(LoadInstance(instanceId)); |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
532 |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
533 std::set<std::string> names; |
33 | 534 StructureSet::ListStructuresNames(names, *dicom); |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
535 |
3
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
536 Json::Value answer = Json::arrayValue; |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
537 |
3
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
538 for (std::set<std::string>::const_iterator it = names.begin(); it != names.end(); ++it) |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
539 { |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
540 answer.append(*it); |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
541 } |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
542 |
3
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
543 std::string s = answer.toStyledString(); |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
544 OrthancPluginAnswerBuffer(OrthancPlugins::GetGlobalContext(), output, s.c_str(), s.size(), Orthanc::MIME_JSON); |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
545 } |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
546 |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
547 |
4
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
548 static void AddDefaultTagValue(Json::Value& target, |
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
549 const Orthanc::DicomTag& tag, |
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
550 const std::string& value) |
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
551 { |
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
552 if (!target.isMember(tag.Format())) |
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
553 { |
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
554 target[tag.Format()] = value; |
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
555 } |
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
556 } |
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
557 |
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
558 |
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
559 static void AddDefaultTagValue(Json::Value& target, |
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
560 const DcmTagKey& tag, |
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
561 const std::string& value) |
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
562 { |
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
563 AddDefaultTagValue(target, Orthanc::DicomTag(tag.getGroup(), tag.getElement()), value); |
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
564 } |
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
565 |
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
566 |
7 | 567 static void CallCreateDicom(Json::Value& answer, |
568 const std::string& stl, | |
569 const Json::Value& body, | |
570 const std::string& parentStudy, | |
571 const std::string& defaultSeriesDescription, | |
572 const std::string& defaultFrameOfReferenceUid, | |
573 const std::string& defaultTitle) | |
574 { | |
575 static const char* const KEY_TAGS = "Tags"; | |
576 | |
577 Json::Value normalized = Json::objectValue; | |
578 | |
579 if (body.isMember(KEY_TAGS)) | |
580 { | |
581 const Json::Value& tags = body[KEY_TAGS]; | |
582 | |
583 if (tags.type() != Json::objectValue) | |
584 { | |
585 throw Orthanc::OrthancException(Orthanc::ErrorCode_BadRequest, "Tags must be provided as a JSON object"); | |
586 } | |
587 | |
588 std::vector<std::string> keys = tags.getMemberNames(); | |
589 for (size_t i = 0; i < keys.size(); i++) | |
590 { | |
591 const Orthanc::DicomTag tag = Orthanc::FromDcmtkBridge::ParseTag(keys[i]); | |
592 normalized[tag.Format()] = tags[keys[i]]; | |
593 } | |
594 } | |
595 | |
596 if (!normalized.isMember(Orthanc::DICOM_TAG_SERIES_DESCRIPTION.Format())) | |
597 { | |
598 normalized[Orthanc::DICOM_TAG_SERIES_DESCRIPTION.Format()] = defaultSeriesDescription; | |
599 } | |
600 | |
601 AddDefaultTagValue(normalized, Orthanc::DICOM_TAG_SERIES_NUMBER, "1"); | |
602 AddDefaultTagValue(normalized, Orthanc::DICOM_TAG_FRAME_OF_REFERENCE_UID, defaultFrameOfReferenceUid); | |
603 AddDefaultTagValue(normalized, Orthanc::DICOM_TAG_INSTANCE_NUMBER, "1"); | |
604 | |
605 AddDefaultTagValue(normalized, DCM_BurnedInAnnotation, "NO"); | |
606 AddDefaultTagValue(normalized, DCM_DeviceSerialNumber, ORTHANC_STL_VERSION); | |
607 AddDefaultTagValue(normalized, DCM_DocumentTitle, defaultTitle); | |
608 AddDefaultTagValue(normalized, DCM_Manufacturer, "Orthanc STL plugin"); | |
609 AddDefaultTagValue(normalized, DCM_ManufacturerModelName, "Orthanc STL plugin"); | |
610 AddDefaultTagValue(normalized, DCM_PositionReferenceIndicator, ""); | |
611 AddDefaultTagValue(normalized, DCM_SoftwareVersions, ORTHANC_STL_VERSION); | |
612 AddDefaultTagValue(normalized, DCM_ConceptNameCodeSequence, ""); | |
613 | |
614 std::string date, time; | |
615 Orthanc::SystemToolbox::GetNowDicom(date, time, true /* use UTC time (not local time) */); | |
616 AddDefaultTagValue(normalized, DCM_AcquisitionDateTime, date + time); | |
617 | |
618 const Orthanc::DicomTag MEASUREMENT_UNITS_CODE_SEQUENCE(DCM_MeasurementUnitsCodeSequence.getGroup(), | |
619 DCM_MeasurementUnitsCodeSequence.getElement()); | |
620 | |
621 if (!normalized.isMember(MEASUREMENT_UNITS_CODE_SEQUENCE.Format())) | |
622 { | |
623 Json::Value item; | |
624 item["CodeValue"] = "mm"; | |
625 item["CodingSchemeDesignator"] = "UCUM"; | |
626 item["CodeMeaning"] = defaultTitle; | |
627 | |
628 normalized[MEASUREMENT_UNITS_CODE_SEQUENCE.Format()].append(item); | |
629 } | |
630 | |
631 std::string content; | |
632 Orthanc::Toolbox::EncodeDataUriScheme(content, Orthanc::MIME_STL, stl); | |
633 | |
634 Json::Value create; | |
635 create["Content"] = content; | |
636 create["Parent"] = parentStudy; | |
637 create["Tags"] = normalized; | |
638 | |
639 if (!OrthancPlugins::RestApiPost(answer, "/tools/create-dicom", create.toStyledString(), false)) | |
640 { | |
641 throw Orthanc::OrthancException(Orthanc::ErrorCode_BadRequest, "Cannot create DICOM from STL"); | |
642 } | |
643 } | |
644 | |
645 | |
646 void EncodeStructureSet(OrthancPluginRestOutput* output, | |
647 const char* url, | |
648 const OrthancPluginHttpRequest* request) | |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
649 { |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
650 static const char* const KEY_INSTANCE = "Instance"; |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
651 static const char* const KEY_RESOLUTION = "Resolution"; |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
652 static const char* const KEY_ROI_NAMES = "RoiNames"; |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
653 static const char* const KEY_SMOOTH = "Smooth"; |
28
410003c50b17
improved computation of RT-STRUCT geometry
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
25
diff
changeset
|
654 static const char* const KEY_STRICT = "Strict"; |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
655 |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
656 if (request->method != OrthancPluginHttpMethod_Post) |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
657 { |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
658 OrthancPluginSendMethodNotAllowed(OrthancPlugins::GetGlobalContext(), output, "POST"); |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
659 return; |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
660 } |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
661 |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
662 Json::Value body; |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
663 if (!Orthanc::Toolbox::ReadJson(body, request->body, request->bodySize)) |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
664 { |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
665 throw Orthanc::OrthancException(Orthanc::ErrorCode_BadRequest); |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
666 } |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
667 |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
668 const std::string instanceId = Orthanc::SerializationToolbox::ReadString(body, KEY_INSTANCE); |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
669 const bool smooth = (body.isMember(KEY_SMOOTH) ? |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
670 Orthanc::SerializationToolbox::ReadBoolean(body, KEY_SMOOTH) : |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
671 true /* smooth by default */); |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
672 const unsigned int resolution = (body.isMember(KEY_RESOLUTION) ? |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
673 Orthanc::SerializationToolbox::ReadUnsignedInteger(body, KEY_RESOLUTION) : |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
674 256 /* default value */); |
28
410003c50b17
improved computation of RT-STRUCT geometry
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
25
diff
changeset
|
675 const bool strict = (body.isMember(KEY_STRICT) ? |
410003c50b17
improved computation of RT-STRUCT geometry
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
25
diff
changeset
|
676 Orthanc::SerializationToolbox::ReadBoolean(body, KEY_STRICT) : |
410003c50b17
improved computation of RT-STRUCT geometry
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
25
diff
changeset
|
677 true /* strict by default */); |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
678 |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
679 std::set<std::string> roiNames; |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
680 Orthanc::SerializationToolbox::ReadSetOfStrings(roiNames, body, KEY_ROI_NAMES); |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
681 |
3
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
682 std::unique_ptr<Orthanc::ParsedDicomFile> dicom(LoadInstance(instanceId)); |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
683 |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
684 StructureSet structureSet(*dicom); |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
685 |
28
410003c50b17
improved computation of RT-STRUCT geometry
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
25
diff
changeset
|
686 StructureSetGeometry geometry(structureSet, strict); |
410003c50b17
improved computation of RT-STRUCT geometry
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
25
diff
changeset
|
687 |
3
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
688 std::string stl; |
28
410003c50b17
improved computation of RT-STRUCT geometry
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
25
diff
changeset
|
689 if (!EncodeStructureSetMesh(stl, structureSet, geometry, roiNames, resolution, smooth)) |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
690 { |
8
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
691 throw Orthanc::OrthancException(Orthanc::ErrorCode_BadFileFormat, "Cannot encode STL from RT-STRUCT"); |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
692 } |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
693 else |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
694 { |
7 | 695 std::string seriesDescription; |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
696 |
7 | 697 if (dicom->GetTagValue(seriesDescription, Orthanc::DICOM_TAG_SERIES_DESCRIPTION)) |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
698 { |
7 | 699 seriesDescription += ": "; |
700 } | |
701 else | |
702 { | |
703 seriesDescription.clear(); | |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
704 } |
4
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
705 |
7 | 706 bool first = true; |
707 for (std::set<std::string>::const_iterator it = roiNames.begin(); it != roiNames.end(); ++it) | |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
708 { |
7 | 709 if (first) |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
710 { |
7 | 711 first = false; |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
712 } |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
713 else |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
714 { |
7 | 715 seriesDescription += ", "; |
3
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
716 } |
2
2bdb9acb7dcf
added STL viewer button at instance level too
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1
diff
changeset
|
717 |
7 | 718 seriesDescription += *it; |
4
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
719 } |
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
720 |
7 | 721 std::string frameOfReferenceUid; |
4
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
722 if (structureSet.HasFrameOfReferenceUid()) |
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
723 { |
7 | 724 frameOfReferenceUid = structureSet.GetFrameOfReferenceUid(); |
4
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
725 } |
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
726 else |
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
727 { |
7 | 728 frameOfReferenceUid = Orthanc::FromDcmtkBridge::GenerateUniqueIdentifier(Orthanc::ResourceType_Instance); |
3
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
729 } |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
730 |
7 | 731 Json::Value answer; |
732 CallCreateDicom(answer, stl, body, structureSet.HashStudy(), seriesDescription, | |
733 frameOfReferenceUid, "STL model generated from DICOM RT-STRUCT"); | |
4
5ee4448a8ff8
generated STL pass dciodvfy
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
734 |
7 | 735 std::string s = answer.toStyledString(); |
736 OrthancPluginAnswerBuffer(OrthancPlugins::GetGlobalContext(), output, s.c_str(), s.size(), Orthanc::MIME_JSON); | |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
737 } |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
738 } |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
739 |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
740 |
3
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
741 void ExtractStl(OrthancPluginRestOutput* output, |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
742 const char* url, |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
743 const OrthancPluginHttpRequest* request) |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
744 { |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
745 if (request->method != OrthancPluginHttpMethod_Get) |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
746 { |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
747 OrthancPluginSendMethodNotAllowed(OrthancPlugins::GetGlobalContext(), output, "GET"); |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
748 return; |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
749 } |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
750 |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
751 const std::string instanceId(request->groups[0]); |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
752 |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
753 std::unique_ptr<Orthanc::ParsedDicomFile> dicom(LoadInstance(instanceId)); |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
754 DcmDataset& dataset = *dicom->GetDcmtkObject().getDataset(); |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
755 |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
756 std::string stl; |
33 | 757 if (STLToolbox::GetStringValue(dataset, DCM_MIMETypeOfEncapsulatedDocument) != Orthanc::MIME_STL || |
758 STLToolbox::GetStringValue(dataset, DCM_SOPClassUID) != UID_EncapsulatedSTLStorage || | |
3
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
759 !dicom->GetTagValue(stl, Orthanc::DICOM_TAG_ENCAPSULATED_DOCUMENT)) |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
760 { |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
761 throw Orthanc::OrthancException(Orthanc::ErrorCode_BadRequest, "DICOM instance not encapsulating a STL model: " + instanceId); |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
762 } |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
763 else |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
764 { |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
765 OrthancPluginAnswerBuffer(OrthancPlugins::GetGlobalContext(), output, |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
766 stl.empty() ? NULL : stl.c_str(), stl.size(), Orthanc::MIME_STL); |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
767 } |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
768 } |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
769 |
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
770 |
6 | 771 |
8
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
772 void EncodeNifti(OrthancPluginRestOutput* output, |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
773 const char* url, |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
774 const OrthancPluginHttpRequest* request) |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
775 { |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
776 static const char* const KEY_NIFTI = "Nifti"; |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
777 static const char* const KEY_RESOLUTION = "Resolution"; |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
778 static const char* const KEY_PARENT_STUDY = "ParentStudy"; |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
779 static const char* const KEY_SMOOTH = "Smooth"; |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
780 |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
781 if (request->method != OrthancPluginHttpMethod_Post) |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
782 { |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
783 OrthancPluginSendMethodNotAllowed(OrthancPlugins::GetGlobalContext(), output, "POST"); |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
784 return; |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
785 } |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
786 |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
787 Json::Value body; |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
788 if (!Orthanc::Toolbox::ReadJson(body, request->body, request->bodySize)) |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
789 { |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
790 throw Orthanc::OrthancException(Orthanc::ErrorCode_BadRequest); |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
791 } |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
792 |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
793 std::string mime, nifti; |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
794 if (!Orthanc::Toolbox::DecodeDataUriScheme(mime, nifti, Orthanc::SerializationToolbox::ReadString(body, KEY_NIFTI))) |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
795 { |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
796 throw Orthanc::OrthancException(Orthanc::ErrorCode_BadRequest, "Missing the \"Nifti\" argument containing the NIfTI file"); |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
797 } |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
798 |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
799 const std::string parentStudy = Orthanc::SerializationToolbox::ReadString(body, KEY_PARENT_STUDY); |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
800 const bool smooth = (body.isMember(KEY_SMOOTH) ? |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
801 Orthanc::SerializationToolbox::ReadBoolean(body, KEY_SMOOTH) : |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
802 true /* smooth by default */); |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
803 const unsigned int resolution = (body.isMember(KEY_RESOLUTION) ? |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
804 Orthanc::SerializationToolbox::ReadUnsignedInteger(body, KEY_RESOLUTION) : |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
805 256 /* default value */); |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
806 |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
807 vtkNew<vtkImageData> volume; |
32 | 808 VTKToolbox::LoadNifti(volume.Get(), nifti); |
8
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
809 |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
810 std::string stl; |
32 | 811 if (!VTKToolbox::EncodeVolume(stl, volume.Get(), resolution, smooth)) |
8
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
812 { |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
813 throw Orthanc::OrthancException(Orthanc::ErrorCode_BadFileFormat, "Cannot encode STL from NIfTI"); |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
814 } |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
815 else |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
816 { |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
817 const std::string title = "STL model generated from NIfTI"; |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
818 |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
819 const std::string frameOfReferenceUid = Orthanc::FromDcmtkBridge::GenerateUniqueIdentifier(Orthanc::ResourceType_Instance); |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
820 |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
821 Json::Value answer; |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
822 CallCreateDicom(answer, stl, body, parentStudy, title, frameOfReferenceUid, title); |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
823 |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
824 std::string s = answer.toStyledString(); |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
825 OrthancPluginAnswerBuffer(OrthancPlugins::GetGlobalContext(), output, s.c_str(), s.size(), Orthanc::MIME_JSON); |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
826 } |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
827 } |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
828 |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
829 |
46
9b2a2fcc9878
added option to disable Nexus support
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
45
diff
changeset
|
830 #if ORTHANC_ENABLE_NEXUS == 1 |
9b2a2fcc9878
added option to disable Nexus support
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
45
diff
changeset
|
831 |
45
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
832 void ServeNexusAssets(OrthancPluginRestOutput* output, |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
833 const char* url, |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
834 const OrthancPluginHttpRequest* request) |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
835 { |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
836 if (request->method != OrthancPluginHttpMethod_Get) |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
837 { |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
838 OrthancPluginSendMethodNotAllowed(OrthancPlugins::GetGlobalContext(), output, "GET"); |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
839 return; |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
840 } |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
841 |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
842 const std::string file = request->groups[0]; |
64
5e11f5880e6d
simplified the embedding of Nexus viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
62
diff
changeset
|
843 cache_.Answer(output, "nexus/" + file); |
45
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
844 } |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
845 |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
846 |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
847 static Orthanc::MemoryStringCache nexusCache_; |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
848 |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
849 void ExtractNexusModel(OrthancPluginRestOutput* output, |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
850 const char* url, |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
851 const OrthancPluginHttpRequest* request) |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
852 { |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
853 OrthancPluginContext* context = OrthancPlugins::GetGlobalContext(); |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
854 |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
855 if (request->method != OrthancPluginHttpMethod_Get) |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
856 { |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
857 OrthancPluginSendMethodNotAllowed(context, output, "GET"); |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
858 return; |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
859 } |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
860 |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
861 const std::string instanceId = request->groups[0]; |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
862 |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
863 std::string range; |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
864 |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
865 for (uint32_t i = 0; i < request->headersCount; i++) |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
866 { |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
867 if (std::string(request->headersKeys[i]) == "range") |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
868 { |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
869 range = request->headersValues[i]; |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
870 } |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
871 } |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
872 |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
873 static const std::string BYTES = "bytes="; |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
874 |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
875 if (!boost::starts_with(range, BYTES)) |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
876 { |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
877 OrthancPluginSendHttpStatusCode(context, output, 416); // Range not satisfiable |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
878 return; |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
879 } |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
880 |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
881 std::vector<std::string> tokens; |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
882 Orthanc::Toolbox::TokenizeString(tokens, range.substr(BYTES.length()), '-'); |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
883 |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
884 uint64_t start, end; |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
885 |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
886 if (tokens.size() != 2 || |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
887 !Orthanc::SerializationToolbox::ParseUnsignedInteger64(start, tokens[0]) || |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
888 !Orthanc::SerializationToolbox::ParseUnsignedInteger64(end, tokens[1]) || |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
889 start < 0 || |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
890 start > end) |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
891 { |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
892 OrthancPluginSendHttpStatusCode(context, output, 416); // Range not satisfiable |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
893 return; |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
894 } |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
895 |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
896 uint64_t modelSize; |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
897 std::string part; |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
898 |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
899 #if 0 |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
900 { |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
901 // Use no cache |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
902 std::string model; |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
903 if (!OrthancPlugins::RestApiGetString(model, "/instances/" + instanceId + "/content/4205-1001", false)) |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
904 { |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
905 OrthancPluginSendHttpStatusCode(context, output, 404); |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
906 return; |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
907 } |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
908 |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
909 modelSize = model.size(); |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
910 |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
911 if (end >= modelSize) |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
912 { |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
913 OrthancPluginSendHttpStatusCode(context, output, 416); // Range not satisfiable |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
914 return; |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
915 } |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
916 |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
917 part = model.substr(start, end - start + 1); |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
918 } |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
919 #else |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
920 { |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
921 Orthanc::MemoryStringCache::Accessor accessor(nexusCache_); |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
922 |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
923 std::string model; |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
924 if (!accessor.Fetch(model, instanceId)) |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
925 { |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
926 if (OrthancPlugins::RestApiGetString(model, "/instances/" + instanceId + "/content/4205-1001", false)) |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
927 { |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
928 accessor.Add(instanceId, model); |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
929 } |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
930 else |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
931 { |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
932 OrthancPluginSendHttpStatusCode(context, output, 404); |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
933 return; |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
934 } |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
935 } |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
936 |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
937 modelSize = model.size(); |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
938 |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
939 if (end >= modelSize) |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
940 { |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
941 OrthancPluginSendHttpStatusCode(context, output, 416); // Range not satisfiable |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
942 return; |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
943 } |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
944 |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
945 part = model.substr(start, end - start + 1); |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
946 } |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
947 #endif |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
948 |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
949 std::string s = ("bytes " + boost::lexical_cast<std::string>(start) + "-" + |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
950 boost::lexical_cast<std::string>(end) + "/" + |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
951 boost::lexical_cast<std::string>(modelSize)); |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
952 OrthancPluginSetHttpHeader(context, output, "Content-Range", s.c_str()); |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
953 |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
954 s = boost::lexical_cast<std::string>(part.size()); |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
955 OrthancPluginSetHttpHeader(context, output, "Content-Length", s.c_str()); |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
956 OrthancPluginSetHttpHeader(context, output, "Content-Type", "application/octet-stream"); |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
957 |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
958 OrthancPluginSendHttpStatus(context, output, 206 /* partial content */, part.c_str(), part.size()); |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
959 } |
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
960 |
50
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
961 |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
962 void DicomizeNexusModel(OrthancPluginRestOutput* output, |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
963 const char* url, |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
964 const OrthancPluginHttpRequest* request) |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
965 { |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
966 static const char* KEY_CONTENT = "Content"; |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
967 static const char* KEY_PARENT = "Parent"; |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
968 static const char* KEY_TAGS = "Tags"; |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
969 static const char* KEY_PRIVATE_CREATOR = "PrivateCreator"; |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
970 |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
971 OrthancPluginContext* context = OrthancPlugins::GetGlobalContext(); |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
972 |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
973 if (request->method != OrthancPluginHttpMethod_Post) |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
974 { |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
975 OrthancPluginSendMethodNotAllowed(context, output, "POST"); |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
976 return; |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
977 } |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
978 |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
979 Json::Value body; |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
980 if (!Orthanc::Toolbox::ReadJson(body, request->body, request->bodySize) || |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
981 body.type() != Json::objectValue || |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
982 !body.isMember(KEY_TAGS) || |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
983 body[KEY_TAGS].type() != Json::objectValue) |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
984 { |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
985 throw Orthanc::OrthancException(Orthanc::ErrorCode_BadRequest); |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
986 } |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
987 |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
988 if (!body.isMember(KEY_CONTENT) || |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
989 body[KEY_CONTENT].type() != Json::stringValue) |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
990 { |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
991 throw Orthanc::OrthancException(Orthanc::ErrorCode_BadRequest, |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
992 "POST body missing string field \"" + std::string(KEY_CONTENT) + "\""); |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
993 } |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
994 |
55
41e3b79e7f4b
added check of Nexus magic header
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
53
diff
changeset
|
995 std::string decoded; |
41e3b79e7f4b
added check of Nexus magic header
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
53
diff
changeset
|
996 Orthanc::Toolbox::DecodeBase64(decoded, body[KEY_CONTENT].asString()); |
41e3b79e7f4b
added check of Nexus magic header
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
53
diff
changeset
|
997 |
41e3b79e7f4b
added check of Nexus magic header
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
53
diff
changeset
|
998 if (decoded.size() < 4 || |
41e3b79e7f4b
added check of Nexus magic header
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
53
diff
changeset
|
999 decoded[0] != 0x20 || |
41e3b79e7f4b
added check of Nexus magic header
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
53
diff
changeset
|
1000 decoded[1] != 0x73 || |
41e3b79e7f4b
added check of Nexus magic header
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
53
diff
changeset
|
1001 decoded[2] != 0x78 || |
41e3b79e7f4b
added check of Nexus magic header
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
53
diff
changeset
|
1002 decoded[3] != 0x4e) |
41e3b79e7f4b
added check of Nexus magic header
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
53
diff
changeset
|
1003 { |
41e3b79e7f4b
added check of Nexus magic header
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
53
diff
changeset
|
1004 throw Orthanc::OrthancException(Orthanc::ErrorCode_BadFileFormat, |
41e3b79e7f4b
added check of Nexus magic header
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
53
diff
changeset
|
1005 "This is not a valid Nexus file, its magic header is incorrect"); |
41e3b79e7f4b
added check of Nexus magic header
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
53
diff
changeset
|
1006 } |
41e3b79e7f4b
added check of Nexus magic header
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
53
diff
changeset
|
1007 |
50
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1008 Json::Value creationBody = Json::objectValue; |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1009 |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1010 creationBody[KEY_TAGS] = body[KEY_TAGS]; |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1011 creationBody[KEY_TAGS][Orthanc::DICOM_TAG_MANUFACTURER.Format()] = ORTHANC_STL_MANUFACTURER; |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1012 creationBody[KEY_TAGS][Orthanc::DICOM_TAG_SOP_CLASS_UID.Format()] = "1.2.840.10008.5.1.4.1.1.66"; |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1013 creationBody[KEY_TAGS][Orthanc::DICOM_TAG_MODALITY.Format()] = "OT"; |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1014 creationBody[KEY_TAGS][DICOM_TAG_CREATOR_VERSION_UID.Format()] = GetCreatorVersionUid(ORTHANC_STL_VERSION); |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1015 creationBody[KEY_TAGS][Orthanc::DicomTag(ORTHANC_STL_PRIVATE_GROUP, ORTHANC_STL_CREATOR_ELEMENT).Format()] = ORTHANC_STL_PRIVATE_CREATOR; |
51 | 1016 creationBody[KEY_TAGS][Orthanc::DicomTag(ORTHANC_STL_PRIVATE_GROUP, ORTHANC_STL_NEXUS_ELEMENT).Format()] = |
1017 "data:application/octet-stream;base64," + body[KEY_CONTENT].asString(); | |
50
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1018 creationBody[KEY_PRIVATE_CREATOR] = ORTHANC_STL_PRIVATE_CREATOR; |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1019 |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1020 if (body.isMember(KEY_PARENT)) |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1021 { |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1022 creationBody[KEY_PARENT] = body[KEY_PARENT]; |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1023 } |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1024 |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1025 std::string bodyString; |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1026 Orthanc::Toolbox::WriteFastJson(bodyString, creationBody); |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1027 |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1028 std::string result; |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1029 if (OrthancPlugins::RestApiPost(result, "/tools/create-dicom", |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1030 bodyString.empty() ? NULL : bodyString.c_str(), |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1031 bodyString.size(), false)) |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1032 { |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1033 OrthancPluginAnswerBuffer(context, output, result.empty() ? NULL : result.c_str(), |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1034 result.size(), "application/json"); |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1035 } |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1036 else |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1037 { |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1038 throw Orthanc::OrthancException(Orthanc::ErrorCode_BadRequest); |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1039 } |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1040 } |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1041 |
46
9b2a2fcc9878
added option to disable Nexus support
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
45
diff
changeset
|
1042 #endif |
9b2a2fcc9878
added option to disable Nexus support
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
45
diff
changeset
|
1043 |
45
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
1044 |
62
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1045 #if ORTHANC_ENABLE_3DHOP == 1 |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1046 |
70
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
1047 // This is the default background style of 3DHOP |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
1048 static std::string canvasStyle3DHOP_ = "background-image: url(skins/backgrounds/light.jpg)"; |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
1049 |
62
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1050 void Serve3DHOPAssets(OrthancPluginRestOutput* output, |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1051 const char* url, |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1052 const OrthancPluginHttpRequest* request) |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1053 { |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1054 if (request->method != OrthancPluginHttpMethod_Get) |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1055 { |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1056 OrthancPluginSendMethodNotAllowed(OrthancPlugins::GetGlobalContext(), output, "GET"); |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1057 return; |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1058 } |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1059 |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1060 const std::string file = request->groups[0]; |
70
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
1061 const std::string resourceId = "3dhop/" + file; |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
1062 |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
1063 if (file == "3DHOP_all_tools.html") |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
1064 { |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
1065 std::string resource; |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
1066 cache_.ReadResource(resource, resourceId); |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
1067 |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
1068 boost::replace_all(resource, "${{CANVAS_STYLE}}", canvasStyle3DHOP_); |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
1069 |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
1070 OrthancPluginAnswerBuffer(OrthancPlugins::GetGlobalContext(), output, resource.c_str(), |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
1071 resource.size(), Orthanc::EnumerationToString(Orthanc::MimeType_Html)); |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
1072 } |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
1073 else |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
1074 { |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
1075 cache_.Answer(output, resourceId); |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
1076 } |
62
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1077 } |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1078 |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1079 #endif |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1080 |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1081 |
0
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1082 extern "C" |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1083 { |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1084 ORTHANC_PLUGINS_API int32_t OrthancPluginInitialize(OrthancPluginContext* context) |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1085 { |
47 | 1086 OrthancPlugins::SetGlobalContext(context, ORTHANC_PLUGIN_NAME); |
0
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1087 |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1088 /* Check the version of the Orthanc core */ |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1089 if (OrthancPluginCheckVersion(OrthancPlugins::GetGlobalContext()) == 0) |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1090 { |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1091 char info[1024]; |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1092 sprintf(info, "Your version of Orthanc (%s) must be above %d.%d.%d to run this plugin", |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1093 OrthancPlugins::GetGlobalContext()->orthancVersion, |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1094 ORTHANC_PLUGINS_MINIMAL_MAJOR_NUMBER, |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1095 ORTHANC_PLUGINS_MINIMAL_MINOR_NUMBER, |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1096 ORTHANC_PLUGINS_MINIMAL_REVISION_NUMBER); |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1097 OrthancPluginLogError(OrthancPlugins::GetGlobalContext(), info); |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1098 return -1; |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1099 } |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1100 |
47 | 1101 #if ORTHANC_FRAMEWORK_VERSION_IS_ABOVE(1, 12, 4) |
1102 Orthanc::Logging::InitializePluginContext(context, ORTHANC_PLUGIN_NAME); | |
1103 #elif ORTHANC_FRAMEWORK_VERSION_IS_ABOVE(1, 7, 2) | |
0
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1104 Orthanc::Logging::InitializePluginContext(context); |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1105 #else |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1106 Orthanc::Logging::Initialize(context); |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1107 #endif |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1108 |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
1109 Orthanc::InitializeFramework("", false); |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
1110 |
52
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1111 const bool hasCreateDicomStl = OrthancPlugins::CheckMinimalOrthancVersion(1, 12, 1); |
0
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1112 |
52
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1113 if (!hasCreateDicomStl) |
0
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1114 { |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1115 LOG(WARNING) << "Your version of Orthanc (" << std::string(context->orthancVersion) |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1116 << ") is insufficient to create DICOM STL, it should be above 1.12.1"; |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1117 } |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1118 |
25
5fc3ea6acbd5
fix deprecated calls
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
24
diff
changeset
|
1119 OrthancPlugins::SetDescription(ORTHANC_PLUGIN_NAME, "STL plugin for Orthanc."); |
0
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1120 |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
1121 OrthancPlugins::RegisterRestCallback<ServeFile>("/stl/app/(.*)", true); |
3
0fb06c6a6c87
added route "/instances/{id}/stl"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
1122 OrthancPlugins::RegisterRestCallback<ExtractStl>("/instances/([0-9a-f-]+)/stl", true); |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
1123 OrthancPlugins::RegisterRestCallback<ListStructures>("/stl/rt-struct/([0-9a-f-]+)", true); |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
1124 |
52
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1125 if (hasCreateDicomStl) |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
1126 { |
8
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
1127 OrthancPlugins::RegisterRestCallback<EncodeStructureSet>("/stl/encode-rtstruct", true); |
d1267c6c33e1
added route /stl/encode-nifti
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
1128 OrthancPlugins::RegisterRestCallback<EncodeNifti>("/stl/encode-nifti", true); |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
1129 } |
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
1130 |
52
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1131 OrthancPlugins::OrthancConfiguration globalConfiguration; |
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1132 OrthancPlugins::OrthancConfiguration configuration; |
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1133 globalConfiguration.GetSection(configuration, "STL"); |
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1134 |
46
9b2a2fcc9878
added option to disable Nexus support
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
45
diff
changeset
|
1135 #if ORTHANC_ENABLE_NEXUS == 1 |
70
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
1136 OrthancPlugins::OrthancConfiguration configuration3DHOP; |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
1137 configuration.GetSection(configuration3DHOP, "3DHOP"); |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
1138 |
52
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1139 const bool enableNexus = configuration.GetBooleanValue("EnableNexus", false); |
50
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1140 |
52
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1141 if (enableNexus) |
50
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1142 { |
52
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1143 LOG(INFO) << "Support for Nexus is enabled"; |
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1144 nexusCache_.SetMaximumSize(512 * 1024 * 1024); // Cache of 512MB for Nexus |
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1145 OrthancPlugins::RegisterRestCallback<ExtractNexusModel>("/instances/([0-9a-f-]+)/nexus", true); |
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1146 OrthancPlugins::RegisterRestCallback<ServeNexusAssets>("/stl/nexus/(.*)", true); |
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1147 |
62
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1148 #if ORTHANC_ENABLE_3DHOP == 1 |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1149 OrthancPlugins::RegisterRestCallback<Serve3DHOPAssets>("/stl/3dhop/(.*)", true); |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1150 |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1151 /** |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1152 * The 3DHOP viewer only supports ".nxs", ".nxz", and ".ply" extensions, |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1153 * as can be seen in the "minimal/js/presenter.js" file. Furthermore, it |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1154 * requires the extension to be part of the URL. |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1155 **/ |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1156 OrthancPlugins::RegisterRestCallback<ExtractNexusModel>("/stl/3dhop-instances/([0-9a-f-]+).nxz", true); |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1157 #endif |
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1158 |
70
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
1159 // New in release 1.3 |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
1160 canvasStyle3DHOP_ = configuration3DHOP.GetStringValue( |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
1161 "CanvasStyle", |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
1162 "background-image: url(skins/backgrounds/light.jpg)"); // This is the default background style of 3DHOP |
a5c1be2ec26a
new configuration option: STL.3DHOP.CanvasStyle
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
68
diff
changeset
|
1163 |
52
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1164 const bool hasCreateNexus_ = OrthancPlugins::CheckMinimalOrthancVersion(1, 9, 4); |
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1165 |
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1166 if (hasCreateNexus_) |
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1167 { |
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1168 OrthancPlugins::RegisterRestCallback<DicomizeNexusModel>("/stl/create-nexus", true); |
50
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1169 |
52
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1170 if (OrthancPluginRegisterPrivateDictionaryTag( |
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1171 context, ORTHANC_STL_PRIVATE_GROUP, ORTHANC_STL_CREATOR_ELEMENT, OrthancPluginValueRepresentation_LO, |
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1172 "PrivateCreator", 1, 1, ORTHANC_STL_PRIVATE_CREATOR) != OrthancPluginErrorCode_Success || |
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1173 OrthancPluginRegisterPrivateDictionaryTag( |
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1174 context, ORTHANC_STL_PRIVATE_GROUP, ORTHANC_STL_NEXUS_ELEMENT, OrthancPluginValueRepresentation_OB, |
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1175 "NexusData", 1, 1, ORTHANC_STL_PRIVATE_CREATOR) != OrthancPluginErrorCode_Success) |
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1176 { |
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1177 LOG(ERROR) << "Cannot register the private DICOM tags for handling Nexus"; |
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1178 } |
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1179 } |
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1180 else |
50
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1181 { |
52
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1182 LOG(WARNING) << "Your version of Orthanc (" << std::string(context->orthancVersion) |
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1183 << ") is insufficient to create DICOM-ize Nexus models, it should be above 1.9.4"; |
50
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1184 } |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1185 } |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1186 else |
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1187 { |
52
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1188 LOG(INFO) << "Support for Nexus is disabled"; |
50
bf4c4e4e7198
added route /stl/create-nexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
48
diff
changeset
|
1189 } |
52
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1190 #else |
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1191 const bool enableNexus = false; |
46
9b2a2fcc9878
added option to disable Nexus support
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
45
diff
changeset
|
1192 #endif |
45
967f947014ac
adding experimental support for nexus models
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
40
diff
changeset
|
1193 |
2
2bdb9acb7dcf
added STL viewer button at instance level too
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1
diff
changeset
|
1194 // Extend the default Orthanc Explorer with custom JavaScript for STL |
2bdb9acb7dcf
added STL viewer button at instance level too
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1
diff
changeset
|
1195 std::string explorer; |
2bdb9acb7dcf
added STL viewer button at instance level too
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1
diff
changeset
|
1196 |
2bdb9acb7dcf
added STL viewer button at instance level too
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1
diff
changeset
|
1197 { |
2bdb9acb7dcf
added STL viewer button at instance level too
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1
diff
changeset
|
1198 Orthanc::EmbeddedResources::GetFileResource(explorer, Orthanc::EmbeddedResources::ORTHANC_EXPLORER); |
2bdb9acb7dcf
added STL viewer button at instance level too
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1
diff
changeset
|
1199 |
2bdb9acb7dcf
added STL viewer button at instance level too
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1
diff
changeset
|
1200 std::map<std::string, std::string> dictionary; |
52
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1201 dictionary["HAS_CREATE_DICOM_STL"] = (hasCreateDicomStl ? "true" : "false"); |
40 | 1202 dictionary["SHOW_NIFTI_BUTTON"] = (configuration.GetBooleanValue("EnableNIfTI", false) ? "true" : "false"); |
52
f9e49dc63817
added configuration option STL.EnableNexus
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
1203 dictionary["IS_NEXUS_ENABLED"] = (enableNexus ? "true" : "false"); |
62
b798387b085c
added 3DHOP viewer version 4.3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
60
diff
changeset
|
1204 dictionary["IS_3DHOP_ENABLED"] = ((ORTHANC_ENABLE_3DHOP == 1) ? "true" : "false"); |
53
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
1205 FillOrthancExplorerCreatorVersionUid(dictionary); |
83b1abee3ece
improved handling of CreatorVersionUID
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
52
diff
changeset
|
1206 |
2
2bdb9acb7dcf
added STL viewer button at instance level too
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1
diff
changeset
|
1207 explorer = Orthanc::Toolbox::SubstituteVariables(explorer, dictionary); |
2bdb9acb7dcf
added STL viewer button at instance level too
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1
diff
changeset
|
1208 |
25
5fc3ea6acbd5
fix deprecated calls
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
24
diff
changeset
|
1209 OrthancPlugins::ExtendOrthancExplorer(ORTHANC_PLUGIN_NAME, explorer); |
2
2bdb9acb7dcf
added STL viewer button at instance level too
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1
diff
changeset
|
1210 } |
2bdb9acb7dcf
added STL viewer button at instance level too
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1
diff
changeset
|
1211 |
0
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1212 return 0; |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1213 } |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1214 |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1215 |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1216 ORTHANC_PLUGINS_API void OrthancPluginFinalize() |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1217 { |
1
0f03a8a0bd6f
encoding of RT-STRUCT as STL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
1218 Orthanc::FinalizeFramework(); |
0
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1219 } |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1220 |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1221 |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1222 ORTHANC_PLUGINS_API const char* OrthancPluginGetName() |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1223 { |
25
5fc3ea6acbd5
fix deprecated calls
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
24
diff
changeset
|
1224 return ORTHANC_PLUGIN_NAME; |
0
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1225 } |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1226 |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1227 |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1228 ORTHANC_PLUGINS_API const char* OrthancPluginGetVersion() |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1229 { |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1230 return ORTHANC_STL_VERSION; |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1231 } |
4e889a8e8be2
initial commit of the viewer plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1232 } |