Mercurial > hg > orthanc-stone
annotate OrthancStone/Sources/Volumes/DicomVolumeImageReslicer.h @ 1615:f5d4bd7b5593
new class: OsiriXLayerFactory
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Fri, 30 Oct 2020 17:26:44 +0100 |
parents | 8563ea5d8ae4 |
children | 9ac2a65d4172 |
rev | line source |
---|---|
815 | 1 /** |
2 * Stone of Orthanc | |
3 * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics | |
4 * Department, University Hospital of Liege, Belgium | |
1270
2d8ab34c8c91
upgrade to year 2020
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
815
diff
changeset
|
5 * Copyright (C) 2017-2020 Osimis S.A., Belgium |
815 | 6 * |
7 * This program is free software: you can redistribute it and/or | |
1598
8563ea5d8ae4
relicensing some files, cf. osimis bm26 and chu agreement on 2020-05-20
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1596
diff
changeset
|
8 * modify it under the terms of the GNU Lesser General Public License |
815 | 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 | |
1598
8563ea5d8ae4
relicensing some files, cf. osimis bm26 and chu agreement on 2020-05-20
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1596
diff
changeset
|
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
8563ea5d8ae4
relicensing some files, cf. osimis bm26 and chu agreement on 2020-05-20
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1596
diff
changeset
|
15 * Lesser General Public License for more details. |
1596
4fb8fdf03314
removed annoying whitespace
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1571
diff
changeset
|
16 * |
1598
8563ea5d8ae4
relicensing some files, cf. osimis bm26 and chu agreement on 2020-05-20
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1596
diff
changeset
|
17 * You should have received a copy of the GNU Lesser General Public |
8563ea5d8ae4
relicensing some files, cf. osimis bm26 and chu agreement on 2020-05-20
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1596
diff
changeset
|
18 * License along with this program. If not, see |
8563ea5d8ae4
relicensing some files, cf. osimis bm26 and chu agreement on 2020-05-20
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1596
diff
changeset
|
19 * <http://www.gnu.org/licenses/>. |
815 | 20 **/ |
21 | |
22 | |
23 #pragma once | |
24 | |
25 #include "DicomVolumeImage.h" | |
26 #include "IVolumeSlicer.h" | |
27 #include "VolumeReslicer.h" | |
28 | |
29 #include <boost/shared_ptr.hpp> | |
30 | |
31 namespace OrthancStone | |
32 { | |
33 /** | |
34 This class is able to supply an extract slice for an arbitrary cutting | |
35 plane through a volume image | |
36 */ | |
37 class DicomVolumeImageReslicer : public IVolumeSlicer | |
38 { | |
39 private: | |
40 class Slice; | |
41 | |
42 boost::shared_ptr<DicomVolumeImage> volume_; | |
43 VolumeReslicer reslicer_; | |
44 | |
45 public: | |
1571 | 46 explicit DicomVolumeImageReslicer(const boost::shared_ptr<DicomVolumeImage>& volume); |
815 | 47 |
48 ImageInterpolation GetInterpolation() const | |
49 { | |
50 return reslicer_.GetInterpolation(); | |
51 } | |
52 | |
53 void SetInterpolation(ImageInterpolation interpolation) | |
54 { | |
55 reslicer_.SetInterpolation(interpolation); | |
56 } | |
57 | |
58 bool IsFastMode() const | |
59 { | |
60 return reslicer_.IsFastMode(); | |
61 } | |
62 | |
63 void SetFastMode(bool fast) | |
64 { | |
65 reslicer_.EnableFastMode(fast); | |
66 } | |
67 | |
1571 | 68 virtual IExtractedSlice* ExtractSlice(const CoordinateSystem3D& cuttingPlane) ORTHANC_OVERRIDE; |
815 | 69 }; |
70 } |