CoreWidget.hh 43.2 KB
Newer Older
1
/*===========================================================================*\
Jan Möbius's avatar
Jan Möbius committed
2
3
*                                                                            *
*                              OpenFlipper                                   *
Jan Möbius's avatar
Jan Möbius committed
4
*      Copyright (C) 2001-2011 by Computer Graphics Group, RWTH Aachen       *
Jan Möbius's avatar
Jan Möbius committed
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
*                           www.openflipper.org                              *
*                                                                            *
*--------------------------------------------------------------------------- *
*  This file is part of OpenFlipper.                                         *
*                                                                            *
*  OpenFlipper is free software: you can redistribute it and/or modify       *
*  it under the terms of the GNU Lesser General Public License as            *
*  published by the Free Software Foundation, either version 3 of            *
*  the License, or (at your option) any later version with the               *
*  following exceptions:                                                     *
*                                                                            *
*  If other files instantiate templates or use macros                        *
*  or inline functions from this file, or you compile this file and          *
*  link it with other files to produce an executable, this file does         *
*  not by itself cause the resulting executable to be covered by the         *
*  GNU Lesser General Public License. This exception does not however        *
*  invalidate any other reasons why the executable file might be             *
*  covered by the GNU Lesser General Public License.                         *
*                                                                            *
*  OpenFlipper 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 Lesser General Public License for more details.                       *
*                                                                            *
*  You should have received a copy of the GNU LesserGeneral Public           *
*  License along with OpenFlipper. If not,                                   *
*  see <http://www.gnu.org/licenses/>.                                       *
*                                                                            *
33
\*===========================================================================*/
Jan Möbius's avatar
 
Jan Möbius committed
34

35
/*===========================================================================*\
Jan Möbius's avatar
Jan Möbius committed
36
37
*                                                                            *
*   $Revision$                                                       *
38
39
*   $LastChangedBy$                                                 *
*   $Date$                    *
Jan Möbius's avatar
Jan Möbius committed
40
*                                                                            *
41
\*===========================================================================*/
Jan Möbius's avatar
 
Jan Möbius committed
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60


//=============================================================================
//
//  CLASS CoreWidget
//
//=============================================================================

/**
 * \file CoreWidget.hh
 * This File contains the header of the frameworks main widget
*/

#ifndef COREWIDGET_HH
#define COREWIDGET_HH


//== INCLUDES =================================================================

61
62
#include <set>

Jan Möbius's avatar
 
Jan Möbius committed
63
#include "OpenFlipper/common/Types.hh"
Jan Möbius's avatar
Jan Möbius committed
64
#include <OpenFlipper/common/GlobalOptions.hh>
Jan Möbius's avatar
 
Jan Möbius committed
65
66
67
68
69
70
#include <OpenFlipper/BasePlugin/ContextMenuInterface.hh>
#include <OpenFlipper/BasePlugin/LoggingInterface.hh>
#include <OpenFlipper/BasePlugin/MenuInterface.hh>
#include <OpenFlipper/BasePlugin/ViewInterface.hh>
#include <OpenFlipper/BasePlugin/StatusbarInterface.hh>

Jan Möbius's avatar
Dennis:    
Jan Möbius committed
71
#include <OpenFlipper/widgets/coreWidget/SideArea.hh>
Dirk Wilden's avatar
Dirk Wilden committed
72
#include <OpenFlipper/widgets/coreWidget/ColorStatusBar.hh>
Jan Möbius's avatar
 
Jan Möbius committed
73

74
#include <OpenFlipper/widgets/glWidget/QtBaseViewer.hh>
Jan Möbius's avatar
   
Jan Möbius committed
75
76
#include <OpenFlipper/widgets/glWidget/QtGLGraphicsScene.hh>
#include <OpenFlipper/widgets/glWidget/QtGLGraphicsView.hh>
Jan Möbius's avatar
Jan Möbius committed
77
#include <OpenFlipper/widgets/glWidget/QtMultiViewLayout.hh>
78
#include <OpenFlipper/widgets/glWidget/QtSlideWindow.hh>
Jan Möbius's avatar
 
Jan Möbius committed
79
80
81
82
83
84
85
86

// QT INCLUDES
#include <QMainWindow>
#include <QStackedWidget>
#include <QTextEdit>
#include <QToolBar>
#include <QStatusBar>

87
88
89
#include <QFuture>
#include <QFutureWatcher>

Jan Möbius's avatar
 
Jan Möbius committed
90
91
#include <QDockWidget>

Jan Möbius's avatar
Jan Möbius committed
92
#include <OpenFlipper/widgets/aboutWidget/aboutWidget.hh>
93
#include <OpenFlipper/widgets/loggerWidget/loggerWidget.hh>
94
#include <OpenFlipper/widgets/optionsWidget/optionsWidget.hh>
95
#include <OpenFlipper/widgets/helpWidget/helpWidget.hh>
96
#include <OpenFlipper/widgets/stereoSettingsWidget/stereoSettingsWidget.hh>
Jan Möbius's avatar
 
Jan Möbius committed
97

Dirk Wilden's avatar
Dirk Wilden committed
98
#include <OpenFlipper/Core/PluginInfo.hh>
Jan Möbius's avatar
 
Jan Möbius committed
99

100
101
#include <ACG/QtWidgets/QtSceneGraphWidget.hh>

Jan Möbius's avatar
Jan Möbius committed
102
#include <ACG/Scenegraph/DrawModes.hh>
103
#include <ACG/Scenegraph/CoordsysNode.hh>
Jan Möbius's avatar
Jan Möbius committed
104

105
#include <OpenFlipper/INIFile/INIFile.hh>
106
#include <OpenFlipper/BasePlugin/PluginFunctions.hh>
Jan Möbius's avatar
Jan Möbius committed
107

Jan Möbius's avatar
Jan Möbius committed
108
109
110
111
/** \brief ViewMode struct
* This struct contains a ViewMode and its status information such as used widgets,toolbars or context menus
*
*/
Marcel Campen's avatar
Marcel Campen committed
112
113
114
115
116





Jan Möbius's avatar
 
Jan Möbius committed
117
struct ViewMode{
118

Jan Möbius's avatar
Jan Möbius committed
119
120
  /// Name of the View Mode
  QString name;
121

122
123
124
  /// Icon of the View Mode
  /// TODO Specify size for Icons
  QString icon;
125

Jan Möbius's avatar
Jan Möbius committed
126
127
  /// Is this a user defined custom view mode or a plugin generated one
  bool custom;
128

Jan Möbius's avatar
Jan Möbius committed
129
130
  /// List of Visible Toolboxes in this view mode
  QStringList visibleToolboxes;
131

Jan Möbius's avatar
Jan Möbius committed
132
133
  /// List of Toolbars in this view mode
  QStringList visibleToolbars;
134

Jan Möbius's avatar
Jan Möbius committed
135
136
  /// List of context Menus in this view mode
  QStringList visibleContextMenus;
Jan Möbius's avatar
 
Jan Möbius committed
137
138
139
140
141
142
143
144
145
146
147
148
149
};

class StackWidgetInfo {
  public:
    StackWidgetInfo(bool _editable,QString _name,QWidget* _widget);

    bool editable;
    QString name;
    QWidget* widget;
};

/** Info struct containing information about custom context menus
 */
150
151
152
class MenuInfo {
  public:
    MenuInfo():
Jan Möbius's avatar
Jan Möbius committed
153
154
      action(0),
      type(CONTEXTBACKGROUNDMENU)
155
156
157
158
    {}

    /// The context item
    QAction*          action;
Jan Möbius's avatar
 
Jan Möbius committed
159

160
161
    /// Type of objects for which the context Menu should be visible
    DataType        contextType;
Jan Möbius's avatar
 
Jan Möbius committed
162

163
    /// Type of the context Menu ( Context for what type .. Background,Object,Node)
Jan Möbius's avatar
Jan Möbius committed
164
    ContextMenuType type;
Jan Möbius's avatar
 
Jan Möbius committed
165
166
};

Jan Möbius's avatar
Jan Möbius committed
167
168
169
170
/** \brief Struct containing information about pickModes
 *
 * This is an internal DataStructure! Don't use it. It's used to
 * manage the pickmode information internally.
171
172
173
174
175
176
177
*/
class PickMode
{
  public:
    /// Constructor
    PickMode(const std::string& _n, const bool _t, const bool _v, QCursor _c, QToolBar *_tb = 0 );

Jan Möbius's avatar
Jan Möbius committed
178
    /// Destructor
179
180
181
    ~PickMode() {};


Jan Möbius's avatar
Jan Möbius committed
182
183
184
185
    /** \brief PickMode visible
     *
     * @param _visible Should this be a visible or a hidden pick mode?
     */
186
187
    void visible(const bool _visible);

Jan Möbius's avatar
Jan Möbius committed
188
189
190
191
    /** \brief PickMode visible
     *
     * Visible or hidden pick mode
     */
192
193
    bool visible() const;

Jan Möbius's avatar
Jan Möbius committed
194
195
196
197
    /** \brief PickMode Name
    *
    * Name of the pick mode
    */
198
199
    std::string name() const;

Jan Möbius's avatar
Jan Möbius committed
200
201
202
203
204
205
206
    /** \brief PickMode mouse tracking
     *
     * If the pick mode has mouse tracking enabled, it will emit
     * mouse events with every movement and not only on button events.
     *
     * @param _tracking mouse tracking enabled or not
     */
207
    void tracking(const bool _tracking);
Jan Möbius's avatar
Jan Möbius committed
208
209
210
211
212
213

    /** \brief PickMode mouse tracking
    *
    * If the pick mode has mouse tracking enabled, it will emit
    * mouse events with every movement and not only on button events.
    */
214
215
    bool tracking() const;

Jan Möbius's avatar
Jan Möbius committed
216
217
218
219
220
    /** \brief PickMode cursor
    *
    * The cursor associated with this pick mode. You can define a non standard
    * cursor that is visible, if this pick mode is active.
    */
221
222
    QCursor cursor() const;

223
224
225
226
227
228
229
230
231
    /** \brief PickMode cursor
    *
    * The cursor associated with this pick mode. You can define a non standard
    * cursor that is visible, if this pick mode is active.
    *
    * @param _cursor The cursor to be used in this pickmode
    */
    void cursor(const QCursor _cursor);

Jan Möbius's avatar
Jan Möbius committed
232
233
234
235
236
237
238
    /** \brief PickMode toolbar
    *
    * Each pickmode can have a toolbar that will be visible at the top of the screen.
    * This toolbar is stored here.
    *
    * @param _toolbar The used toolbar
    */
239
    void toolbar(QToolBar* _toolbar);
Jan Möbius's avatar
Jan Möbius committed
240
241
242
243
244
245

    /** \brief PickMode toolbar
    *
    * Each pickmode can have a toolbar that will be visible at the top of the screen.
    * This toolbar is stored here.
    */
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
    QToolBar* toolbar() const;

  private:

    /// Name of the pickMode
    std::string  name_;

    /** MouseTracking enabled for this mode?
    */
    bool         tracking_;

    /** Defines if the Mode will be visible in the popup Menu
    */
    bool         visible_;

    /** Cursor used in  this pickMode
    */
    QCursor      cursor_;

    /** Additional toolbar showed in this pickMode
    */
    QToolBar *   toolbar_;
};

Jan Möbius's avatar
 
Jan Möbius committed
270
271
272
273
274
275
276
277
/** Core Widget of the Application
 */
class CoreWidget : public QMainWindow
{
  Q_OBJECT

public:

278
279
  friend class Core;

Jan Möbius's avatar
 
Jan Möbius committed
280
  /// constructor
Dirk Wilden's avatar
Dirk Wilden committed
281
  CoreWidget( QVector<ViewMode*>& _viewModes, std::vector<PluginInfo>& _plugins, QList< SlotInfo >& _coreSlots );
Jan Möbius's avatar
 
Jan Möbius committed
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297

  /// destructor
  ~CoreWidget();

  signals:
    void clearAll();
    void loadMenu();
    void addEmptyObjectMenu();
    void saveMenu();
    void saveToMenu();
    void loadIniMenu();
    void saveIniMenu();
    void recentOpen(QAction*);
    void exit();

    void loadPlugin();
Dirk Wilden's avatar
Dirk Wilden committed
298
    void showPlugins();
Jan Möbius's avatar
 
Jan Möbius committed
299
300
301
302
303
304

  private slots:

    /// Called on applications close
    void closeEvent ( QCloseEvent * event );

Dirk Wilden's avatar
Dirk Wilden committed
305
306
307
308
309
310
311
312
313
314
315
   //===========================================================================
  /** @name Logger
  * @{ */
  //===========================================================================

  signals :
      void log(Logtype _type, QString _message);
      void log(QString _message);

   /** @} */

Jan Möbius's avatar
 
Jan Möbius committed
316
317
318
319
320
321
322
323
324
325
326
   //===========================================================================
  /** @name Keys
  * @{ */
  //===========================================================================

  protected :

    //! Handle key events
    virtual void keyPressEvent (QKeyEvent* _e);
    virtual void keyReleaseEvent(QKeyEvent* _e);

Jan Möbius's avatar
   
Jan Möbius committed
327
328
329
    // Filter alt key events under windows
    //bool eventFilter(QObject *obj, QEvent *ev);

330
331
  private:
    //event handling
332
333
    bool event( QEvent *event );

334
335
    bool eventFilter(QObject *_obj, QEvent *_event);

Jan Möbius's avatar
 
Jan Möbius committed
336
337
  signals :

338
339
340
341
342
343
344
345
346
347
348
349
350
    /** When this Signal is emitted when a Keyevent Event occures
     *  The signal is connected to all Plugins implementing KeyInterface by the pluginLoader
     */
    void PluginKeyEvent(QKeyEvent* );

    /** When this Signal is emitted when a Keyevent Release occures
     *  The signal is connected to all Plugins implementing KeyInterface by the pluginLoader
     */
    void PluginKeyReleaseEvent(QKeyEvent* );

    /// internal signal to register CoreWidget keys
    void registerKey(int _key, Qt::KeyboardModifiers _modifiers, QString _description,
                     bool _multiUse = false);
Jan Möbius's avatar
 
Jan Möbius committed
351

Dirk Wilden's avatar
Dirk Wilden committed
352
353
    ///call a scripting function
    void call( QString _expression , bool& _success  );
Dirk Wilden's avatar
Dirk Wilden committed
354
355

  private:
Dirk Wilden's avatar
Dirk Wilden committed
356
357
    ///typedefs
    typedef std::multimap<  std::pair< int, Qt::KeyboardModifiers >  ,  std::pair< QObject*, int > > KeyMap;
Dirk Wilden's avatar
Dirk Wilden committed
358

Dirk Wilden's avatar
Dirk Wilden committed
359
360
    typedef std::pair< KeyMap::iterator, KeyMap::iterator > KeyRange;

361
362
363
364
365
366
367
368
    /** \brief Register all events related to the core
     */
    void registerCoreKeys();

    /** \brief handle key events for the core
     *
     * This function is called to handle key events which are registered to the core
     */
369
370
    void coreKeyPressEvent();

Dirk Wilden's avatar
Dirk Wilden committed
371
372
373
374
375
    /// Handle core key events
    void coreKeyPressEvent  (QKeyEvent* _e);
    void coreKeyReleaseEvent(QKeyEvent* _e);

    KeyBinding getKeyBinding(QObject* _plugin, int _keyIndex );
Dirk Wilden's avatar
Dirk Wilden committed
376
    QString    getRPCName(QObject* _plugin );
Dirk Wilden's avatar
Dirk Wilden committed
377
378

    ///vector of keys registered to the core
Dirk Wilden's avatar
Dirk Wilden committed
379
380
    std::vector<KeyBinding> coreKeys_;

Dirk Wilden's avatar
Dirk Wilden committed
381
382
383
384
385
386
    ///mapping of all keys to registered keys and the corresponding plugins
    KeyMap keys_;

    ///mapping of all registered keys and the corresponding plugins to currently assigned keys
    InverseKeyMap invKeys_;

Dirk Wilden's avatar
Dirk Wilden committed
387
388
389
    ///list of scripting slots from core
    QList< SlotInfo >& coreSlots_;

Dirk Wilden's avatar
Dirk Wilden committed
390
  private slots:
391
392
393
394
395
     /** \brief key registration
     *
     * internal slot that registers a keyCombination to the sender() who emitted the registerKey() signal
     * only after registering keyCombinations plugins receive keyEvents to the corresponding keyCombinations via KeyInterface.
     */
Dirk Wilden's avatar
Dirk Wilden committed
396
397
398
399
    void slotRegisterKey(int _key, Qt::KeyboardModifiers _modifiers, QString _description,
                         bool _multiUse = false);

  public slots:
400
401
402
403
     /** \brief add a new key Mapping
     *
     * internal function that stores a new keyCombination assignment for an existing keyBinding
     */
Dirk Wilden's avatar
Dirk Wilden committed
404
    void slotAddKeyMapping(int _key, Qt::KeyboardModifiers _modifiers, QObject* _plugin, int _keyBindingID);
Dirk Wilden's avatar
Dirk Wilden committed
405

406
407
408
409
410
     /** \brief register scripting slots to allow keyBindings
     *
     * internal function that registers all public slots without parameters of each plugin (or core)
     * to the key management system. This allows the assignment of keyBindings for each of these slots.
     */
Dirk Wilden's avatar
Dirk Wilden committed
411
412
    void slotRegisterSlotKeyBindings();

413
414
415
416
417
418
419
  public:
    ///Load key assignments from a given INI file
    void loadKeyBindings(INIFile& _ini);

    ///Store current key assignments to a given INI file
    void saveKeyBindings(INIFile& _ini);

Dirk Wilden's avatar
Dirk Wilden committed
420
421
422
423
  private:
    /// Store the state of the shift key
    bool shiftPressed_;

Jan Möbius's avatar
 
Jan Möbius committed
424
425
426
427
428
429
430
431
432
   /** @} */

  //===========================================================================
  /** @name GUI creation
  * @{ */
  //===========================================================================

  public:

433
434
    /// Setup the main menubar
    void setupMenuBar();
435

Dirk Wilden's avatar
Dirk Wilden committed
436
437
438
439
440
441
442
443
444
445
   /** @} */

  //===========================================================================
  /** @name Video Capturing
  * @{ */
  //===========================================================================

  signals:
    void startVideoCapture(QString _baseName, int _fps, bool _captureViewers);
    void stopVideoCapture();
446
447
448
449

    void resizeViewers(int _width, int _height);
    void resizeApplication(int _width, int _height);

Dirk Wilden's avatar
Dirk Wilden committed
450
451
  private slots:
    void startVideoCaptureDialog();
452

Jan Möbius's avatar
Jan Möbius committed
453
  /** @} */
454

Jan Möbius's avatar
Jan Möbius committed
455
456
457
458
  //===========================================================================
  /** @name Recent File Menu handling
   * @{ */
  //===========================================================================
459

Dirk Wilden's avatar
Dirk Wilden committed
460
461
  public:

Jan Möbius's avatar
 
Jan Möbius committed
462
463
464
465
466
467
468
  /// Add a recent file and update menu
  void addRecent(QString _filename, DataType _type);

  /// Update the recent files menu
  void updateRecent();

  /** @} */
Jan Möbius's avatar
Jan Möbius committed
469

Jan Möbius's avatar
 
Jan Möbius committed
470
471
472
473
  //===========================================================================
  /** @name GUI Controls
  * @{ */
  //===========================================================================
Jan Möbius's avatar
Jan Möbius committed
474

Jan Möbius's avatar
 
Jan Möbius committed
475
  public :
476
477
478
479
480
481
482
483
484
485
486
487
488
489

    /// Show logger in splitter or not
    void showLoggerInSplitView(bool _show);

    /// Set in-scene logger geometry right
    void updateInSceneLoggerGeometry();

    /// Use native or gl painted cursor
    void setForceNativeCursor ( bool _state );

    QSize defaultIconSize();

  public slots:

Jan Möbius's avatar
 
Jan Möbius committed
490
491
    /// Set application to Fullscreen and back
    void toggleFullscreen();
Jan Möbius's avatar
Jan Möbius committed
492

493
494
495
    /// Enable or disable fullscreen mode
    void setFullscreen(bool _state );

Jan Möbius's avatar
 
Jan Möbius committed
496
497
    /// Hide or show logging area
    void toggleLogger();
498
499

    /// Change visibility of the logger
Jan Möbius's avatar
Jan Möbius committed
500
    void showLogger(OpenFlipper::Options::LoggerState _state);
Jan Möbius's avatar
Jan Möbius committed
501

Jan Möbius's avatar
 
Jan Möbius committed
502
503
    /// Hide or show toolbox area
    void toggleToolbox();
504
505
506
    
    /// Show or hide toolbox
    void showToolbox( bool _state );
507

508
509
510
    /// Change visibility of the Status Bar
    void toggleStatusBar();

511
512
    /// Show or hide status bar
    void showStatusBar( bool _state );
Jan Möbius's avatar
Dennis:    
Jan Möbius committed
513

514
515
    /// Show or hide menubar
    void showMenuBar( bool _state );
516

517
518
    /// Hide or show menu bar
    void toggleMenuBar();
Dirk Wilden's avatar
Dirk Wilden committed
519

520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
    /// Hide or show current toolbar
    void toggleToolBar();

    /// Show or hide toolbar, emits toolBarToggled( bool _state )
    void showToolBar( bool _state );
  signals:
    /// will be emitted if the visibility of the toolbar is changed
    void toolBarVisChanged( bool _state );

    /// will be emitted if the visibility of the toolbox is changed
    void toolBoxVisChanged( bool _state );

    /// will be emitted if the visibility of the statusbar is changed
    void statusBarVisChanged( bool _state );

    /// will be emitted if the visibility of the menubar is changed
    void menuBarVisChanged( bool _state );
537

Jan Möbius's avatar
Jan Möbius committed
538
539
540
  private:
    OpenFlipper::Options::LoggerState loggerState_;

Dirk Wilden's avatar
Dirk Wilden committed
541
    uint fullscreenState_;
Dirk Wilden's avatar
Dirk Wilden committed
542
543
    
    QSize defaultIconSize_;
544

Jan Möbius's avatar
 
Jan Möbius committed
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
  /** @} */

  //===========================================================================
    /** @name Tool Widgets / View Modes
    * @{ */
  //===========================================================================

    private:
      /// a List of all widgets in the toolbar
      QVector<QWidget*> toolWidgets_;

    public:
      /// List of currently available viewModes
      QVector<ViewMode*>& viewModes_;

    private:

      QPushButton* viewModeButton_;

      /// Submenu holding all ViewMode actions
      QMenu* viewModeMenu_;

    public slots:

      /// init ViewModes that were loaded via ini-file
      void initViewModes(  );

572
      /// Add or change Toolboxes for a ViewMode (non-userdefined viewMode)
Jan Möbius's avatar
Jan Möbius committed
573
      void slotAddViewModeToolboxes(QString _mode, QStringList _usedWidgets);
Jan Möbius's avatar
 
Jan Möbius committed
574

575
      /// Add or change Toolboxes for a ViewMode (_custom == userdefined viewMode)
Jan Möbius's avatar
Jan Möbius committed
576
      void slotAddViewModeToolboxes(QString _mode, bool _custom, QStringList _usedWidgets);
577

578
      /// Add or change Toolbars for a ViewMode (non-userdefined viewMode)
579
580
      void slotAddViewModeToolbars(QString _mode, QStringList _usedToolbars);

581
582
      /// Add or change Toolbars for a ViewMode (_custom == userdefined viewMode)
      void slotAddViewModeToolbars(QString _mode, bool _custom, QStringList _usedToolbars);
583

Jan Möbius's avatar
Marlin:    
Jan Möbius committed
584
585
586
587
588
589
590
591
      /// Add or change Toolbars for a ViewMode (non-userdefined viewMode)
      void slotAddViewModeContextMenus(QString _mode, QStringList _usedToolbars);

      /// Add or change Toolbars for a ViewMode (_custom == userdefined viewMode)
      void slotAddViewModeContextMenus(QString _mode, bool _custom, QStringList _usedToolbars);

      /// Completly configure a view mode ( set toolbars, toolboxes, context menus, ... )
      void slotAddViewModeComplete(QString _mode , bool _custom, QStringList _toolboxes, QStringList _toolbars, QStringList _contextmenus);
592

Jan Möbius's avatar
Jan Möbius committed
593
      /// Sets the Icon for a given View Mode (non-userdefined viewMode)
594
      void slotSetViewModeIcon(QString _mode, QString _iconName);
595

Jan Möbius's avatar
Jan Möbius committed
596
597
      /// Sets the Icon for a given View Mode (_custom == userdefined viewMode)
      void slotSetViewModeIcon(QString _mode, bool _custom, QString _iconName);
Jan Möbius's avatar
 
Jan Möbius committed
598
599

      /// Slot for Changing visible toolWidgets
600
      void slotChangeView(QString _mode, QStringList _toolboxWidgets, QStringList _toolbars, QStringList _contextmenus, bool _expandAll = false);
601
602
      
      /// Set orientation of tool box (either on the right or the left side of the screen)
603
      void setToolBoxOrientationOnTheRight(bool _toolBoxRight);
604
605
606
      
      /// Hide or show the View Mode controls
      void showViewModeControls(bool _show);
Jan Möbius's avatar
 
Jan Möbius committed
607

Marcel Campen's avatar
Marcel Campen committed
608
609
610
      /// Hide the context menu
      void slotHideContextMenu();

Jan Möbius's avatar
 
Jan Möbius committed
611
612
613
614
615
616
617
    private slots:
      /// Remove viewMode
      void slotRemoveViewMode(QString _name);

      /// Slot for setting ViewMode from Menu
      void slotSetViewMode( QAction* action);

Jan Möbius's avatar
Jan Möbius committed
618
      /// Show a dialog in which the viewMode can be edited
Jan Möbius's avatar
 
Jan Möbius committed
619
      void slotViewModeDialog();
620

Jan Möbius's avatar
Jan Möbius committed
621
622
      /// Show a dialog in which the viewMode can be changed
      void slotViewChangeDialog();
Jan Möbius's avatar
 
Jan Möbius committed
623
624

    public slots :
625
626
      
      /// Set the view Mode to the given Mode
627
      void setViewMode( QString _mode, bool _expandAll = false );
628
629
      
      /// Move a specific toolbox widget to the top of the side area
630
      void moveToolBoxToTop(QString _name);
631
632
      
      /// Move a specific toolbox widget to the bottom of the side area
633
      void moveToolBoxToBottom(QString _name);
Jan Möbius's avatar
 
Jan Möbius committed
634
635
636
637
638
639
640
641
642
643

   /** @} */



  //===========================================================================
    /** @name Basic Gui Elements
    * @{ */
  //===========================================================================

644
  private:
Jan Möbius's avatar
 
Jan Möbius committed
645
646

    /// Examiner Widget
Jan Möbius's avatar
   
Jan Möbius committed
647
    std::vector< glViewer* >  examiner_widgets_;
Jan Möbius's avatar
Jan Möbius committed
648

Jan Möbius's avatar
 
Jan Möbius committed
649
650
    ///Spliter between toplevel objects and the textedit at the bottom
    QSplitter* splitter_;
Jan Möbius's avatar
Jan Möbius committed
651

652
653
654
    /// Group box containing Task Switcher Controls
    QGroupBox *viewModeControlBox_;
    
Jan Möbius's avatar
 
Jan Möbius committed
655
    /// Textedit at the bottom for log messages
656
    LoggerWidget* logWidget_;
Jan Möbius's avatar
Jan Möbius committed
657

Jan Möbius's avatar
 
Jan Möbius committed
658
659
660
661
662
663
    /// Size of the logging window ( defaults to 240 )
    int originalLoggerSize_;

    /// QMenu containing the recently opened files
    QMenu* recentFilesMenu_;

664
665
666
    /// Algorithms Menu
    QMenu* algorithmMenu_;

Jan Möbius's avatar
 
Jan Möbius committed
667
668
    /// Help Menu
    QMenu* helpMenu_;
669
670
671
672
673
674
675
    
    /// Window Menu
    QMenu* windowMenu_;
    
    /// Action for View Mode Widget Conrol in Menu
    QAction* AC_ShowViewModeControls_;
    
Jan Möbius's avatar
   
Jan Möbius committed
676
677
678
679
680
681
682
683
684
685
686
687
688
    /// gl widget used as drawing area to paint the graphics scene
    QGLWidget* glWidget_;

    /// graphics scene used to paint gl context and widgets
    QtGLGraphicsScene* glScene_;

    /// graphics view that holds the gl scene
    QtGLGraphicsView* glView_;

    /// center widged
    QGraphicsWidget* centerWidget_;

    /// Base layout that holds gl views
Jan Möbius's avatar
Jan Möbius committed
689
    QtMultiViewLayout* baseLayout_;
Jan Möbius's avatar
   
Jan Möbius committed
690

691
692
693
    /// Class that holds the animated log widget
    QtSlideWindow* slidingLogger_;

Jan Möbius's avatar
Dennis:    
Jan Möbius committed
694
695
    /// Widget for toolBox
    QWidget* toolBoxArea_;
696

Jan Möbius's avatar
Jan Möbius committed
697
698
    /// Button to change viewModes
    QPushButton* vmChangeButton_;
Jan Möbius's avatar
Dennis:    
Jan Möbius committed
699
700
701
702
703
704
705
706
707
708

    /// Spliter between toplevel objects and toolbox
    QSplitter* toolSplitter_;

    /// Toolbox
    SideArea* toolBox_;

    /// Toolbox scroll area
    QScrollArea* toolBoxScroll_;

709
    /// Handle to picking toolbar
Jan Möbius's avatar
Jan Möbius committed
710
    typedef std::map<QToolBar*,QGraphicsProxyWidget*> PickToolBarMap;
711
    PickToolBarMap curPickingToolbarItems_;
Jan Möbius's avatar
Dennis:    
Jan Möbius committed
712

713
714
715
    /// Extra toolbar not in scene for picking
    QToolBar* pickToolBarExternal_;

716
717
718
    /// Store all toolbars that once have been registered
    std::set<QToolBar*> registeredToolbars_;

Jan Möbius's avatar
Dennis:    
Jan Möbius committed
719
720
721
    /// Cursor handling
    CursorPainter* cursorPainter_;

Jan Möbius's avatar
   
Jan Möbius committed
722

723
724
725
    // widget showing the scenegraph
    ACG::QtWidgets::QtSceneGraphDialog* sceneGraphDialog_;

Jan Möbius's avatar
 
Jan Möbius committed
726
727
728
  /** @} */

  private slots:
729
730
731
732
733
734

    /** Creates and shows the Scenegraph Dialog
     */
    void slotShowSceneGraphDialog();


735
736
737
738
739
   /** Makes the sender examiner active
    */
   void slotActivateExaminer ();


Jan Möbius's avatar
 
Jan Möbius committed
740
741
742
743
744
745
   /** Display a log message in the Mainwidget
    * @param _type Type of Message (OUT,WARN,ERR)
    * @param _message The message to be displayed
    */
   void slotLog(Logtype _type, QString _message);

Jan Möbius's avatar
   
Jan Möbius committed
746
747
   /** Updates the size of the main graphics widget in the scene
     */
748
   void sceneRectChanged(const QRectF &rect);
Jan Möbius's avatar
   
Jan Möbius committed
749

Jan Möbius's avatar
 
Jan Möbius committed
750
751
752
753
754
755
  //===========================================================================
    /** @name Menubar controls
      * @{ */
  //===========================================================================
  private slots :

Jan Möbius's avatar
Jan Möbius committed
756
757
    void slotAddMenubarAction( QAction* _action , QString _name );
    void slotGetMenubarMenu (QString _name, QMenu *& _menu, bool _create);
Jan Möbius's avatar
 
Jan Möbius committed
758
759
760
761
762
763
764
765

  private:

    /// File Menu
    QMenu *fileMenu_;

    /// View Menu
    QMenu *viewMenu_;
766

767
768
    /// Tools Menu
    QMenu *toolsMenu_;
Jan Möbius's avatar
 
Jan Möbius committed
769
770
771
772

    /// First entry after all relevant parts of the File Menu
    QAction* fileMenuEnd_;

Jan Möbius's avatar
Jan Möbius committed
773
774
775
    /// All available menus
    QMap<QString, QMenu *> menus_;

Jan Möbius's avatar
 
Jan Möbius committed
776
  /** @} */
Jan Möbius's avatar
Jan Möbius committed
777

Jan Möbius's avatar
 
Jan Möbius committed
778
779
780
781
  //===========================================================================
    /** @name ToolBar controls
      * @{ */
  //===========================================================================
Jan Möbius's avatar
Jan Möbius committed
782
  private:
Jan Möbius's avatar
 
Jan Möbius committed
783
    QToolBar* viewerToolbar_;
Dirk Wilden's avatar
Dirk Wilden committed
784
785

    int toolbarCount_;
Jan Möbius's avatar
Jan Möbius committed
786

787
788
789
790
791
    QToolButton* stereoButton_;
    QToolButton* moveButton_;
    QToolButton* pickButton_;
    QToolButton* questionButton_;

792
    QComboBox* viewerLayoutBox_;
793

Jan Möbius's avatar
 
Jan Möbius committed
794
795
796
  /** @} */

  //===========================================================================
Jan Möbius's avatar
Jan Möbius committed
797
    /** @name View Menu
Jan Möbius's avatar
 
Jan Möbius committed
798
799
      * @{ */
  //===========================================================================
800

Jan Möbius's avatar
Jan Möbius committed
801
802
803
  public slots:
    /// Setup and update the global draw menu
    void slotUpdateGlobalDrawMenu();
804

805
806
807
808
809
    /// Setup and update the global renderer menu
    void slotUpdateRendererMenu();

    /// Setup and update the global postprocessor menu
    void slotUpdatePostProcessorMenu();
810

811
812
    /// Change viewer layout that was selected in the combo box
    void setViewerLayout(int _idx);
813

814
815
  private slots:
    /// Switches over to the next view mode
816
    void nextViewerLayout();
817

Jan Möbius's avatar
Jan Möbius committed
818
819
    /// Called when the global drawMode is selected
    void slotGlobalDrawMenu(QAction * _action);
820

821
822
    /// Called before the view Menu is shown
    void slotViewMenuAboutToShow();
823

824
825
826
827
828
829
    /// Called when the global renderer is selected
    void slotGlobalRendererMenu(QAction * _action);

    /// Called when the global postprocessor is selected
    void slotGlobalPostProcessorMenu(QAction * _action);

Jan Möbius's avatar
Jan Möbius committed
830
831
832
  private:
    /// This variable holds the global draw menu
    QMenu* globalDrawMenu_;
833

834
835
836
837
838
839
    /// This variable holds the global renderer menu
    QMenu* rendererMenu_;

    /// This variable holds the global postprocessor menu
    QMenu* postprocessorMenu_;

840
841
    QActionGroup * drawGroup_;

842
843
844
845
846
847
    /// Group for all renderers
    QActionGroup * rendererGroup_;

    /// Group for all postprocessors
    QActionGroup *  postProcessorGroup_;

Jan Möbius's avatar
Jan Möbius committed
848
849
    /// Group for all menu items
    QActionGroup* viewGroup_;
850

851
852
    QAction* perspectiveProjectionAction_;
    QAction* orthogonalProjectionAction_;
853

854
    /// Action to globally set animation
855
    QAction* globalAnimationAction_;
856

857
858
    /// Action to globally set backface culling
    QAction* globalBackfaceCullingAction_;
859

860
    /// Action to globally set two-sided lighting
861
862
    QAction* globalTwosidedLightingAction_;

863
    /// Action to globally set multisampling
864
    QAction* globalMultisamplingAction_;
865
866
867
    
    /// Action to globally set mipmapping
    QAction* globalMipmappingAction_;
868

Jan Möbius's avatar
Jan Möbius committed
869
    ACG::SceneGraph::DrawModes::DrawMode activeDrawModes_;
870

Jan Möbius's avatar
Jan Möbius committed
871
    ACG::SceneGraph::DrawModes::DrawMode availableGlobalDrawModes_;
872

Jan Möbius's avatar
Jan Möbius committed
873
874
875
876
877
878
  /** @} */

  //===========================================================================
    /** @name Context Menu
     * @{ */
  //===========================================================================
879

Jan Möbius's avatar
 
Jan Möbius committed
880
  signals :
881
882
883
884
885
886
887
888
889
    /// tells the plugins to update their context menu when an object is picked
    void updateContextMenu(int);

    /// tells the plugins to update their context menu when a node is picked
    void updateContextMenuNode(int);

    /// tells the plugins to update their context menu when the background is picked
    void updateContextMenuBackground();

Jan Möbius's avatar
 
Jan Möbius committed
890
891
892
893
894

  private slots:
    /// This slot is called by the examiner widgets gl area when a context menu is requested
    void slotCustomContextMenu( const QPoint& _point );

Jan Möbius's avatar
   
Jan Möbius committed
895
896
    /// called by plugins to add a new context menu item
    void slotAddContextItem(QAction* _entry, ContextMenuType _type);
Jan Möbius's avatar
 
Jan Möbius committed
897

Jan Möbius's avatar
   
Jan Möbius committed
898
899
    /// called by plugins to add a real context menu item depending on DataType
    void slotAddContextItem( QAction* _entry , DataType _dataType ,ContextMenuType type_);
Jan Möbius's avatar
Marlin:    
Jan Möbius committed
900
901
902
    
    /// called by slotAddContextItem to add the item to the view mode
    void slotAddContextItemToViewMode( QAction* _entry );
Jan Möbius's avatar
 
Jan Möbius committed
903

904
905
906
    /// Paste the view to the last active examiner
    void slotPasteView( );

907
908
909
    /// Paste the view, the window and toolbox size to the last active examiner
    void slotPasteViewAndWindow( );

910
911
912
    /// Copy view from the last active examiner
    void slotCopyView( );

913
914
    /// Called when a coordsys drawMode has been changed
    void slotViewerDrawMenu( QAction * _action );
915

916
917
918
    /// Called when a different post processor has been chosen
    void slotPostProcessorMenu( QAction * _action);

Jan Möbius's avatar
Jan Möbius committed
919
920
921
    /// Called when a different renderer has been chosen
    void slotRenderMenu( QAction * _action);

922
923
    /// Creates a draw Menu for the currently active Viewer
    void slotUpdateViewerDrawMenu();
924

Dirk Wilden's avatar
Dirk Wilden committed
925
    /// Create a snapshot of the last active examiner
926
    void slotExaminerSnapshot();
Dirk Wilden's avatar
Dirk Wilden committed
927

928
929
930
    /// Show / hide wheels
    void slotSwitchWheels(bool _state);

931
932
933
    /// Switch navigation mode
    void slotSwitchNavigation(bool _egomode);

Dirk Wilden's avatar
Dirk Wilden committed
934
935
936
    /// Set the snapShot name for all examiners
    void slotSnapshotName();

Dirk Wilden's avatar
Dirk Wilden committed
937
938
939
    /// Hide coordinate systems in all viewers
    void slotCoordSysVisibility(bool _visible);

Jan Möbius's avatar
 
Jan Möbius committed
940
  private :
Jan Möbius's avatar
Jan Möbius committed
941
942
943
944
    /** Update the contextmenu for the given position inside an examiner widget
     *
     * @param _point      Picking position in coordinates of the viewer
     */
945
946
    void updatePopupMenu(const QPoint& _point);

947
948
    void updatePopupMenuCoordsysNode(QMenu* _menu , const int _part);
    void updatePopupMenuObject(QMenu* _menu , BaseObjectData* _object );
Jan Möbius's avatar
Jan Möbius committed
949
    void updatePopupMenuBackground(QMenu* _menu , const QPoint& _point);
950
951
952
    void updatePopupMenuNode(QMenu* _menu , ACG::SceneGraph::BaseNode* _node);

    bool addContextMenus( QMenu* _menu , ContextMenuType _type, int _id = -1);
Jan Möbius's avatar
 
Jan Möbius committed
953
954
955
956
957
958
959
960
961
962

  private :
    /// context Menu for the gl area
    QMenu*  contextMenu_;

    /// Context Menu containing all selection elements
    QMenu*  contextSelectionMenu_;

    /// All real context menu entries
    std::vector< MenuInfo > contextMenus_;
963

964
965
    /// DrawGroup for per Viewer Draw Modes
    QActionGroup* drawGroupViewer_;
966

967
968
    /// Draw Menu for per Viewer Draw Modes
    QMenu* viewerDrawMenu_;
Jan Möbius's avatar
 
Jan Möbius committed
969

970
971
972
973
    /// Menu which holds the context menu entries for
    /// the coordsys node if invisible
    QMenu* coordSysMenu_;

Jan Möbius's avatar
 
Jan Möbius committed
974
975
  /** @} */

Dirk Wilden's avatar
Dirk Wilden committed
976
977
978
979
980
981
982
983
984
985
986
987
988
  //===========================================================================
    /** @name Snapshots
     * @{ */
  //===========================================================================

  private:

    QString snapshotName_;
    int     snapshotCounter_;

  public slots:

    /// Create a snapshot of the whole app with fileDialog
Dirk Wilden's avatar
Dirk Wilden committed
989
    void viewerSnapshotDialog();
Dirk Wilden's avatar
Dirk Wilden committed
990
991

    /// Create a snapshot of the whole app
Dirk Wilden's avatar
Dirk Wilden committed
992
    void viewerSnapshot();
Dirk Wilden's avatar
Dirk Wilden committed
993
994
995
996
997
998
999
1000
1001
1002
1003
1004
1005

    /// Create a snapshot of the whole app with fileDialog
    void applicationSnapshotDialog();

    /// Create a snapshot of the whole app
    void applicationSnapshot();

    /// Set the snapshot name
    void applicationSnapshotName(QString _name);


  /** @} */

1006
1007
1008
1009
1010
1011
1012
  //===========================================================================
    /** @name Thread-safe functions using QFuture
    * @{ */
  //===========================================================================

  public:

1013
    void writeImageAsynchronously(QImage* _image, const QString _name);
1014
1015
1016
1017
1018
1019

  private:

    // Store pointers to QFuture and QFutureWatcher
    std::map<QFutureWatcher<void>*,QFuture<void>*> watcher_garbage_;

1020
1021
1022
    // Mutex for operations on map
    QMutex map_mutex_;

1023
1024
1025
1026
1027
1028
  private slots:

    void delete_garbage();

  /** @} */

Jan Möbius's avatar
 
Jan Möbius committed
1029
1030
1031
1032
1033
1034
1035
1036
1037
1038
1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
  //===========================================================================
    /** @name StackWidget controls
    * @{ */
  //===========================================================================

  private slots:
    void slotGetStackWidget( QString _name, QWidget*& _widget );
    void slotAddStackWidget( QString _name, QWidget* _widget );
    void slotUpdateStackWidget( QString _name, QWidget* _widget );

    void slotViewMenuAction( QAction * _action);

    void slotUpdateStackMenu();


  private :
    /// QMenu containing the recently opened files
    QMenu* stackMenu_;

    std::vector< StackWidgetInfo > stackWidgetList_;

1050
  public :
Jan Möbius's avatar
 
Jan Möbius committed
1051
1052
1053
1054
1055
1056
1057
1058
1059
1060
    /// Container widget for holding multiple views
    QStackedWidget* stackedWidget_;

  /** @} */

  //===========================================================================
  /** @name Help System
  * @{ */
  //===========================================================================

1061
1062
1063
  private:
    static const QString homePage_;

Jan Möbius's avatar
 
Jan Möbius committed
1064
1065
  public slots:
    /// Display the help Browser
1066
    void showHelpBrowser(const QString &page = homePage_);
1067
1068
1069

  signals:
   void changeHelpSite(QUrl);
Jan Möbius's avatar
 
Jan Möbius committed
1070
1071
1072

  private:
    /// Pointer to the help Browser
1073
    HelpWidget* helpWidget_;
Jan Möbius's avatar
 
Jan Möbius committed
1074
1075

  /** @} */
1076

1077
1078
1079
1080
1081
1082
1083
1084
1085
1086
  //===========================================================================
  /** @name Stereo View Mode
  * @{ */
  //===========================================================================

  public slots:
      /// Creates custom context menu for stereo viewer settings
    void stereoButtonContextMenu(const QPoint& _pos);

    /// Is called if the user has changed stereo settings
1087
1088
1089
    /// Note: The parameter just makes sure, we can connect
    /// all necessary signals to this slot. It has no use for now.
    void slotApplyStereoSettings(int _tmpParam = 0);
1090
1091
1092
1093
1094
1095
1096
1097


  private:
    /// Widget to change stereo settings
    StereoSettingsWidget* stereoSettingsWidget_;

  /** @} */

Jan Möbius's avatar
Jan Möbius committed
1098
1099
1100
1101
1102
1103
1104
1105
1106
1107
1108
1109
1110
1111
1112
  //===========================================================================
  /** @name About System
  * @{ */
  //===========================================================================

  public slots:
    /// Display the about widget
    void showAboutWidget();

  private:
    /// Pointer to the about widget
    AboutWidget* aboutWidget_;

  /** @} */

1113
1114
1115
1116
1117
1118
1119
1120
1121
1122
1123
  //===========================================================================
  /** @name Options System
  * @{ */
  //===========================================================================

  public slots:
    /// Display the Options Browser
    void showOptionsWidget();

  signals:
    void applyOptions();
Dirk Wilden's avatar
Dirk Wilden committed
1124
    void saveOptions();
Jan Möbius's avatar
Jan Möbius committed
1125

1126
1127
1128
1129
1130
  private:

    /// Pointer to the OptionsWidget
    OptionsWidget* optionsWidget_;

Jan Möbius's avatar
Jan Möbius committed
1131
1132
  /** @} */

Jan Möbius's avatar
 
Jan Möbius committed
1133
1134
1135
1136
  //===========================================================================
  /** @name ToolBar controls
  * @{ */
  //===========================================================================
Jan Möbius's avatar
Jan Möbius committed
1137
  private slots:
Jan Möbius's avatar
 
Jan Möbius committed
1138
1139
    /// Called by Plugins to add a Toolbar
    void slotAddToolbar(QToolBar* _toolbar);
Jan Möbius's avatar
Jan Möbius committed
1140

Jan Möbius's avatar
 
Jan Möbius committed
1141
1142
1143
    /// Called by Plugins to remove a Toolbar
    void slotRemoveToolbar(QToolBar* _toolbar);

Jan Möbius's avatar
Jan Möbius committed
1144
1145
1146
    /// Called by Plugins to get access to specific Toolbars by name
    void getToolBar( QString _name, QToolBar*& _toolbar);

Jan Möbius's avatar
 
Jan Möbius committed
1147
1148
  private :
    QToolBar* mainToolbar_;
Jan Möbius's avatar
Jan Möbius committed
1149

Jan Möbius's avatar
Jan Möbius committed
1150
1151
    std::vector< QToolBar* > toolbars_;

Jan Möbius's avatar
Jan Möbius committed
1152
1153
  /** @} */

Jan Möbius's avatar
 
Jan Möbius committed
1154
1155
1156
1157
1158
1159
  //===========================================================================
  /** @name StatusBar controls
   * @{ */
  //===========================================================================
  public slots:
    void statusMessage(QString _message, int _timeout = 0);
Jan Möbius's avatar
Jan Möbius committed
1160

Jan Möbius's avatar
 
Jan Möbius committed
1161
    void clearStatusMessage();
Jan Möbius's avatar
Jan Möbius committed
1162

Jan Möbius's avatar
 
Jan Möbius committed
1163
    void setStatus( ApplicationStatus::applicationStatus _status);
Jan Möbius's avatar
Jan Möbius committed
1164

Dirk Wilden's avatar
Dirk Wilden committed
1165
1166
    void addWidgetToStatusbar(QWidget* _widget);
    
Jan Möbius's avatar
 
Jan Möbius committed
1167
1168
  private:
    void setupStatusBar();
Jan Möbius's avatar
Jan Möbius committed
1169

Jan Möbius's avatar
 
Jan Möbius committed
1170
  private :
Dirk Wilden's avatar
Dirk Wilden committed
1171
    ColorStatusBar* statusBar_;
Jan Möbius's avatar
Jan Möbius committed
1172

Jan Möbius's avatar
 
Jan Möbius committed
1173
    QLabel* statusIcon_;
Jan Möbius's avatar
Jan Möbius committed
1174
1175
1176

  /** @} */

Jan Möbius's avatar
 
Jan Möbius committed
1177
1178
1179
1180
  //===========================================================================
  /** @name Drag and Drop
   * @{ */
  //===========================================================================
1181
1182
1183
1184
  
  signals:
    void dragOpenFile(QString _filename);
  
Jan Möbius's avatar
 
Jan Möbius committed
1185
1186
  private slots:
    void startDrag( QMouseEvent* _event );
Jan Möbius's avatar
Jan Möbius committed
1187

Jan Möbius's avatar
 
Jan Möbius committed
1188
    void dragEnterEvent(QDragEnterEvent* _event);
Jan Möbius's avatar
Jan Möbius committed
1189

Jan Möbius's avatar
 
Jan Möbius committed
1190
    void dropEvent( QDropEvent* _event );
1191
    
Jan Möbius's avatar
Jan Möbius committed
1192
1193
  /** @} */

Jan Möbius's avatar
 
Jan Möbius committed
1194
1195
  private :

Dirk Wilden's avatar
Dirk Wilden committed
1196
  std::vector<PluginInfo>& plugins_;
1197
1198
1199
1200
1201
1202
1203
1204
1205
1206
1207
1208


  //===========================================================================
  /** @name Viewer Controls
   * @{ */
  //===========================================================================

  private slots:

    /// Enable or disable Stereo
    void slotToggleStereoMode();

Jan Möbius's avatar
Jan Möbius committed
1209
1210
    /// Set Background Color for all viewers at once.
    void slotSetGlobalBackgroundColor();
1211

Jan Möbius's avatar
Jan Möbius committed
1212
    /// Set Background Color for one viewer.
1213
    void slotSetContextBackgroundColor();
1214
1215
1216



1217
1218
    /// Set the active viewer to home position
    void slotContextHomeView();
1219

1220
1221
    /// Set the viewer to home position
    void slotGlobalHomeView();
1222
1223
1224



1225
1226
    /// Set the active viewers home position
    void slotContextSetHomeView();
1227
1228

    /// Set the home position for all viewers
1229
    void slotGlobalSetHomeView();
1230
1231
1232



1233
1234
1235
1236
1237
    /// Change view on active viewer to view complete scene
    void slotContextViewAll();

    /// Change view on all viewers to view complete scene
    void slotGlobalViewAll();
1238
1239


1240
    /// Toggle projection mode of the active viewer.
1241
    void slotContextSwitchProjection();
1242
1243
1244
1245
1246
1247
    
    /// Toggle coordsys projection mode of the active viewer.
    ACG::SceneGraph::CoordsysNode::ProjectionMode getCoordsysProjection();
    
    /// Toggle coordsys projection mode of the active viewer.
    void slotContextSwitchCoordsysProjection();
1248

1249
    /// Toggle projection mode of all viewers to perspective projection
1250
1251
    void slotGlobalPerspectiveProjection();

1252
    /// Toggle projection mode of all viewers to orthographic projection
1253
    void slotGlobalOrthographicProjection();
1254
1255


1256
    /// Change the viewing direction from context-menu
1257
    void slotSetViewingDirection(QAction* _action);
1258
1259
1260
    
    /// Lock rotation in current examiner widget
    void slotLockRotation(bool _lock);
1261

1262
1263
1264
1265
1266
1267
    
    
    /// If animation is disabled in all viewers, enable it in all viewers. Otherwise disable it.
    void slotGlobalToggleAnimation();
    
    /// Set the animation mode for all viewers
1268
1269
    void slotGlobalChangeAnimation(bool _animation);

1270
    /// Set the animation mode for active viewer
1271
    void slotLocalChangeAnimation(bool _animation);
1272
1273


1274
1275
1276
    
    /// If backface culling is disabled in all viewers, enable it in all viewers. Otherwise disable it.
    void slotGlobalToggleBackFaceCulling();
1277

1278
    /// Set backface culling for all viewers
1279
    void slotGlobalChangeBackFaceCulling(bool _backFaceCulling);
1280

1281
    /// Set backface culling for active viewer
1282
    void slotLocalChangeBackFaceCulling(bool _backFaceCulling);