comparison Framework/Deprecated/Loaders/OrthancMultiframeVolumeLoader.h @ 1225:16738485e457 broker

deprecating DicomStructureSetLoader, OrthancMultiframeVolumeLoader and OrthancSeriesVolumeProgressiveLoader
author Sebastien Jodogne <s.jodogne@gmail.com>
date Sun, 08 Dec 2019 11:45:09 +0100
parents Framework/Loaders/OrthancMultiframeVolumeLoader.h@34ee7204fde3
children 0ca50d275b9a
comparison
equal deleted inserted replaced
1224:37bc7f115f81 1225:16738485e457
1 /**
2 * Stone of Orthanc
3 * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics
4 * Department, University Hospital of Liege, Belgium
5 * Copyright (C) 2017-2019 Osimis S.A., Belgium
6 *
7 * This program is free software: you can redistribute it and/or
8 * modify it under the terms of the GNU Affero General Public License
9 * as published by the Free Software Foundation, either version 3 of
10 * the License, or (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful, but
13 * WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * Affero General Public License for more details.
16 *
17 * You should have received a copy of the GNU Affero General Public License
18 * along with this program. If not, see <http://www.gnu.org/licenses/>.
19 **/
20
21
22 #pragma once
23
24 #include "LoaderStateMachine.h"
25 #include "../../Volumes/DicomVolumeImage.h"
26
27 #include <boost/shared_ptr.hpp>
28
29 namespace Deprecated
30 {
31 class OrthancMultiframeVolumeLoader :
32 public LoaderStateMachine,
33 public OrthancStone::IObservable
34 {
35 private:
36 class LoadRTDoseGeometry;
37 class LoadGeometry;
38 class LoadTransferSyntax;
39 class LoadUncompressedPixelData;
40
41 boost::shared_ptr<OrthancStone::DicomVolumeImage> volume_;
42 std::string instanceId_;
43 std::string transferSyntaxUid_;
44 bool pixelDataLoaded_;
45
46 const std::string& GetInstanceId() const;
47
48 void ScheduleFrameDownloads();
49
50 void SetTransferSyntax(const std::string& transferSyntax);
51
52 void SetGeometry(const Orthanc::DicomMap& dicom);
53
54 template <typename T>
55 void CopyPixelData(const std::string& pixelData);
56
57 void SetUncompressedPixelData(const std::string& pixelData);
58
59 bool HasGeometry() const;
60 const OrthancStone::VolumeImageGeometry& GetImageGeometry() const;
61
62 public:
63 OrthancMultiframeVolumeLoader(boost::shared_ptr<OrthancStone::DicomVolumeImage> volume,
64 OrthancStone::IOracle& oracle,
65 OrthancStone::IObservable& oracleObservable);
66
67 virtual ~OrthancMultiframeVolumeLoader();
68
69 bool IsPixelDataLoaded() const
70 {
71 return pixelDataLoaded_;
72 }
73
74 void LoadInstance(const std::string& instanceId);
75 };
76 }