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.52 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

schultezub's avatar
schultezub committed
83
84
85
        /**
         * Slot to be called by the application when its collection of pipelines has changed.
         */
86
87
        void onPipelinesChanged();

88
89
90
91
        /**
         * Size hint for the default window size
         * \return QSize(800, 450)
         */
92
93
        QSize sizeHint() const;

94
95
        /**
         * Adds a widget of a visualization pipeline to the main window.
96
97
         * \param   name       the name of the visualization pipeline
         * \param   canvas     the pipeline's canvas
98
         */
99
        void addVisualizationPipelineWidget(const std::string& name, QWidget* canvas);
100

101
102
103
104
105
106
107
108
    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);

109
    signals:
110
        /// Qt signal for updating the PipelineWidget.
111
        void updatePipelineWidget(const std::vector<AbstractPipeline*>&);
112
        /// Qt signal for updating the PropertyCollectionWidget
113
        void updatePropCollectionWidget(HasPropertyCollection*, DataContainer*);
114

115
116
117
118
119
120
    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);
121

122
123
124
125
126
127
128
129
130
131
        /**
         * Slot to be called when _btnExecute was clicked.
         */
        void onBtnExecuteClicked();

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

132
    private:
schultezub's avatar
schultezub committed
133
134
135
        /**
         * Setup Qt GUI stuff
         */
136
137
        void setup();

138
139
140
141
142
143
144
145
146
147
148
149
        /**
         * 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);

150
151
        Ui::MainWindow ui;                                  ///< Interface definition of the MainWindow

152
        CampVisApplication* _application;                    ///< Pointer to the application hosting the whole stuff
153

154
        QMdiArea* _mdiArea;                                 ///< MDI area (the window's central widget)
155
        PipelineTreeWidget* _pipelineWidget;                ///< Widget for browsing the active pipelines
156
157
        QWidget* _pipelinePropertiesWidget;                 ///< Widget showing the selected pipeline's properties
        QScrollArea* _pipelinePropertiesScrollArea;         ///< Scroll area for _pipelinePropertiesWidget
158
        PropertyCollectionWidget* _propCollectionWidget;    ///< Widget for brosing the PropertyCollection of the selected pipeline/processor
159
        DataContainerInspectorWidget* _dcInspectorWidget;   ///< Widget for inspecting the DataContainer of the selected pipeline.
160
        QDockWidget* _dcInspectorDock;                      ///< Dock storing the above DataContainerInspectorWidget instance.
161
162
163
164
165
166

        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
167
168
        LogViewerWidget* _logViewer;                        ///< Widget displaying log messages
        std::vector<QDockWidget*> _primaryDocks;            ///< Docks located in top docking area of the main window
169
170
171
    };
}

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