The expiration time for new job artifacts in CI/CD pipelines is now 30 days (GitLab default). Previously generated artifacts in already completed jobs will not be affected by the change. The latest artifacts for all jobs in the latest successful pipelines will be kept. More information: https://gitlab.lrz.de/help/user/admin_area/settings/continuous_integration.html#default-artifacts-expiration

mainwindow.h 7.72 KB
Newer Older
1
2
// ================================================================================================
// 
schultezub's avatar
schultezub committed
3
// This file is part of the CAMPVis Software Framework.
4
5
// 
// If not explicitly stated otherwise: Copyright (C) 2012, all rights reserved,
schultezub's avatar
schultezub committed
6
//      Christian Schulte zu Berge <christian.szb@in.tum.de>
7
8
9
//      Chair for Computer Aided Medical Procedures
//      Technische Universität München
//      Boltzmannstr. 3, 85748 Garching b. München, Germany
schultezub's avatar
schultezub committed
10
// For a full list of authors and contributors, please refer to the file "AUTHORS.txt".
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
// 
// The licensing of this softare is not yet resolved. Until then, redistribution in source or
// binary forms outside the CAMP chair is not permitted, unless explicitly stated in legal form.
// However, the names of the original authors and the above copyright notice must retain in its
// original state in any case.
// 
// Legal disclaimer provided by the BSD license:
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR
// IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY 
// AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR 
// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 
// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR 
// SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR 
// OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
// POSSIBILITY OF SUCH DAMAGE.
// 
// ================================================================================================

schultezub's avatar
schultezub committed
30
31
#ifndef CAMPVISMAINWINDOW_H__
#define CAMPVISMAINWINDOW_H__
32
33

#include "sigslot/sigslot.h"
schultezub's avatar
schultezub committed
34
#include "application/campvisapplication.h"
35
#include "application/gui/pipelinetreewidget.h"
schultezub's avatar
schultezub committed
36
#include "application/gui/properties/propertycollectionwidget.h"
37
#include "application/gui/logviewerwidget.h"
38
39
#include "application/tools/qtexteditlog.h"
#include "application/ui_mainwindow.h"
40
41

#include <QMainWindow>
42
43
#include <QVBoxLayout>
#include <QHBoxLayout>
44
#include <QPushButton>
45
#include <QMdiArea>
46
#include <QScrollArea>
47
48
#include <vector>

schultezub's avatar
schultezub committed
49
namespace campvis {
50
    class DataContainerInspectorWidget;
51
    class DataContainerInspectorCanvas;
52

schultezub's avatar
schultezub committed
53
    /**
schultezub's avatar
schultezub committed
54
     * Main Window for the CAMPVis application.
55
     * Wraps a nice Qt GUI around the CampVisApplication instance given during creation.
schultezub's avatar
schultezub committed
56
     */
57
    class MainWindow : public QMainWindow, public sigslot::has_slots<> {
58
        Q_OBJECT
59
60

    public:
schultezub's avatar
schultezub committed
61
62
        /**
         * Creates a new TumVis Main window for \a application.
63
         * \param   application     CampVisApplication to create a GUI for.
schultezub's avatar
schultezub committed
64
         */
65
        explicit MainWindow(CampVisApplication* application);
66

schultezub's avatar
schultezub committed
67
68
69
        /**
         * Destructor, make sure to call before destroying the application
         */
70
71
        ~MainWindow();

72
73
74
75
76
77
78
79
80
81
        
        /**
         * Initializes all OpenGL related stuff
         */
        void init();

        /**
         * Deinitializes all OpenGL related stuff
         */
        void deinit();
82

83
84
85
86
        /**
         * Size hint for the default window size
         * \return QSize(800, 450)
         */
87
88
        QSize sizeHint() const;

89
90
        /**
         * Adds a widget of a visualization pipeline to the main window.
91
92
         * \param   name       the name of the visualization pipeline
         * \param   canvas     the pipeline's canvas
93
         */
94
        void addVisualizationPipelineWidget(const std::string& name, QWidget* canvas);
95

96
97
98
99
100
101
102
103
    protected:
        /**
         * Listens to resize events on _pipelinePropertiesWidget and resizes _pipelinePropertiesScrollArea accordingly
         * \param   watched    the object that caused the event
         * \param   event      the event to be filtered
         */
        bool eventFilter(QObject* watched, QEvent* event);

104
    signals:
105
        /// Qt signal for updating the PipelineWidget.
106
107
        void updatePipelineWidget(const std::vector<DataContainer*>&, const std::vector<AbstractPipeline*>&);

108
        /// Qt signal for updating the PropertyCollectionWidget
109
        void updatePropCollectionWidget(HasPropertyCollection*, DataContainer*);
110

111
112
113
114
115
116
    private slots:
        /**
         * Slot to be called by the PipelineWidget when the selected item changes.
         * \param   index   Index of the selected item
         */
        void onPipelineWidgetItemClicked(const QModelIndex& index);
117

118
119
120
121
122
123
124
125
126
127
        /**
         * Slot to be called when _btnExecute was clicked.
         */
        void onBtnExecuteClicked();

        /**
         * Slot to be called when _btnShowDataContainerInspector was clicked.
         */
        void onBtnShowDataContainerInspectorClicked();

128
    private:
129
130
131
132
133
134
135
136
137
138
139
140

        /**
         * Slot to be called by the application when its collection of pipelines has changed.
         */
        void onPipelinesChanged();

        /**
         * Slot to be called by the application when its collection of DataContainers has changed.
         */
        void onDataContainersChanged();


schultezub's avatar
schultezub committed
141
142
143
        /**
         * Setup Qt GUI stuff
         */
144
145
        void setup();

146
147
148
149
150
151
152
153
154
155
156
157
        /**
         * Adds a widget to the top docking area of the main window.
         * This method creates a new dock with the specified name,
         * sets its widget to the given widget, and docks it in top
         * docking area of the main window. If there are already
         * other docks there, they're tabified with the new dock.
         * \param   name       the name that will be given to the created dock
         * \param   widget     the widget to add to the top docking area of the main window
         * \return  the dock created to store the provided widget
         */
        QDockWidget* dockPrimaryWidget(const std::string& name, QWidget* widget);

158
159
        Ui::MainWindow ui;                                  ///< Interface definition of the MainWindow

160
        CampVisApplication* _application;                    ///< Pointer to the application hosting the whole stuff
161

162
        QMdiArea* _mdiArea;                                 ///< MDI area (the window's central widget)
163
        PipelineTreeWidget* _pipelineWidget;                ///< Widget for browsing the active pipelines
164
165
        QWidget* _pipelinePropertiesWidget;                 ///< Widget showing the selected pipeline's properties
        QScrollArea* _pipelinePropertiesScrollArea;         ///< Scroll area for _pipelinePropertiesWidget
166
        PropertyCollectionWidget* _propCollectionWidget;    ///< Widget for brosing the PropertyCollection of the selected pipeline/processor
167
        DataContainerInspectorWidget* _dcInspectorWidget;   ///< Widget for inspecting the DataContainer of the selected pipeline.
168
        QDockWidget* _dcInspectorDock;                      ///< Dock storing the above DataContainerInspectorWidget instance.
169
170
171
172
173
174

        QPushButton* _btnExecute;                           ///< Button to execute the selected pipeline/processor
        QPushButton* _btnShowDataContainerInspector;        ///< Button to show the DataContainerInspector for the selected pipeline

        AbstractPipeline* _selectedPipeline;                ///< currently selected pipeline
        AbstractProcessor* _selectedProcessor;              ///< currently selected processor
175
176
        LogViewerWidget* _logViewer;                        ///< Widget displaying log messages
        std::vector<QDockWidget*> _primaryDocks;            ///< Docks located in top docking area of the main window
177
178
179
    };
}

schultezub's avatar
schultezub committed
180
#endif // CAMPVISMAINWINDOW_H__