forked from daviddoria/InteractiveImageGraphCutSegmentation
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathGraphCutSegmentationWidget.h
180 lines (130 loc) · 5.51 KB
/
GraphCutSegmentationWidget.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
/*
Copyright (C) 2011 David Doria, [email protected]
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
/* This is the main GUI class of this project. It is a QMainWindow
* so that we can use a File menu. It contains an instance of our main functional
* class ImageGraphCutBase and our custom scribble interactor style vtkGraphCutInteractorStyle.
* It also contains a CProgressThread so that we can display a progress bar in marquee
* mode during long computations.
*/
#ifndef GraphCutSegmentationWidget_H
#define GraphCutSegmentationWidget_H
#include "ui_GraphCutSegmentationWidget.h"
// Qt
#include <QFutureWatcher>
#include <QProgressDialog>
// Custom
#include "ImageGraphCutSegmentation/ImageGraphCut.h"
// Submodules
#include "ScribbleInteractorStyle/vtkInteractorStyleScribble.h"
#include "ITKVTKCamera/ITKVTKCamera.h"
// VTK
class vtkImageSlice;
class vtkImageSliceMapper;
class vtkImageStack;
class GraphCutSegmentationWidget : public QMainWindow, private Ui::GraphCutSegmentationWidget
{
Q_OBJECT
public:
GraphCutSegmentationWidget(QWidget *parent = 0);
GraphCutSegmentationWidget(const std::string& fileName);
public slots:
/** Menu items*/
// View menu
void on_actionFlipImageVertically_triggered();
void on_actionFlipImageHorizontally_triggered();
// Export menu
void on_actionExportSegmentedImage_triggered();
void on_actionExportSegmentMask_triggered();
void on_actionExportScreenshotLeft_triggered();
// File menu
void on_actionExit_triggered();
void on_actionOpenImage_triggered();
void on_actionLoadForeground_triggered();
void on_actionLoadBackground_triggered();
/** Buttons, radio buttons, and sliders*/
void on_actionSaveForegroundSelection_activated();
void on_actionSaveBackgroundSelection_activated();
void on_actionClearBackgroundSelection_activated();
void on_actionClearForegroundSelection_activated();
void on_actionClearAll_activated();
void on_btnCut_clicked();
void on_radForeground_clicked();
void on_radBackground_clicked();
void on_btnHideStrokesLeft_clicked();
void on_btnShowStrokesLeft_clicked();
void on_btnHideStrokesRight_clicked();
void on_btnShowStrokesRight_clicked();
void sldHistogramBins_valueChanged();
void slot_SegmentationComplete();
/** Setting lambda must be handled specially because we need to multiply the
* percentage set by the slider by the MaxLambda set in the text box
*/
void UpdateLambda();
/** Open the specified file as a greyscale or color image,
* depending on which type the user has specified through the file menu.
*/
void OpenFile(const std::string& fileName);
protected:
void ScribbleEventHandler(vtkObject* caller, long unsigned int eventId, void* callData);
/** A constructor that can be used by all other constructors. */
void SharedConstructor();
/** Compute lambda by multiplying the percentage set by the slider by the MaxLambda set in the text box. */
float ComputeLambda();
/** Our scribble interactor style */
vtkSmartPointer<vtkInteractorStyleScribble> GraphCutStyle;
/** The interactor style for the resulting segmented image. */
vtkSmartPointer<vtkInteractorStyleImage> RightInteractorStyle;
/** The input and output image actors */
vtkSmartPointer<vtkImageSlice> OriginalImageSlice;
vtkSmartPointer<vtkImageSlice> ResultSlice;
vtkSmartPointer<vtkImageSliceMapper> OriginalImageSliceMapper;
vtkSmartPointer<vtkImageSliceMapper> ResultSliceMapper;
/** The renderers */
vtkSmartPointer<vtkRenderer> LeftRenderer;
vtkSmartPointer<vtkRenderer> RightRenderer;
/** Refresh both renderers and render windows */
void Refresh();
/** The main segmentation class. */
typedef itk::VectorImage<float,2> ImageType;
ImageGraphCut<ImageType> GraphCut;
/** Allows the background color to be changed*/
double BackgroundColor[3];
void SetupCameras();
/** We set this when the image is opeend. We sometimes need to know how big the image is.*/
itk::ImageRegion<2> ImageRegion;
QFutureWatcher<void> FutureWatcher;
QProgressDialog* ProgressDialog;
bool AlreadySegmented;
vtkSmartPointer<vtkImageStack> LeftStack;
vtkSmartPointer<vtkImageStack> RightStack;
/** Both panes - This data can be used by both the Left and Right SourceSinkImageSliceMapper */
vtkSmartPointer<vtkImageData> SourceSinkImageData;
vtkSmartPointer<vtkImageSliceMapper> LeftSourceSinkImageSliceMapper;
vtkSmartPointer<vtkImageSlice> LeftSourceSinkImageSlice;
vtkSmartPointer<vtkImageSliceMapper> RightSourceSinkImageSliceMapper;
vtkSmartPointer<vtkImageSlice> RightSourceSinkImageSlice;
void SetupLeftPane();
void SetupRightPane();
/** This function setups up things that are shared by both panes. */
void SetupBothPanes();
typedef std::vector<itk::Index<2> > VectorOfPixels;
VectorOfPixels Sources;
VectorOfPixels Sinks;
VectorOfPixels* SelectedPixelSet;
void UpdateSelections();
void closeEvent(QCloseEvent *);
ITKVTKCamera* LeftCamera = nullptr;
ITKVTKCamera* RightCamera = nullptr;
};
#endif