CoreWidget.hh 46.4 KB
Newer Older
1
/*===========================================================================*\
Jan Möbius's avatar
Jan Möbius committed
2 3
*                                                                            *
*                              OpenFlipper                                   *
Martin Schultz's avatar
Martin Schultz committed
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
 *           Copyright (c) 2001-2015, RWTH-Aachen University                 *
 *           Department of Computer Graphics and Multimedia                  *
 *                          All rights reserved.                             *
 *                            www.openflipper.org                            *
 *                                                                           *
 *---------------------------------------------------------------------------*
 * This file is part of OpenFlipper.                                         *
 *---------------------------------------------------------------------------*
 *                                                                           *
 * Redistribution and use in source and binary forms, with or without        *
 * modification, are permitted provided that the following conditions        *
 * are met:                                                                  *
 *                                                                           *
 * 1. Redistributions of source code must retain the above copyright notice, *
 *    this list of conditions and the following disclaimer.                  *
 *                                                                           *
 * 2. Redistributions in binary form must reproduce the above copyright      *
 *    notice, this list of conditions and the following disclaimer in the    *
 *    documentation and/or other materials provided with the distribution.   *
 *                                                                           *
 * 3. Neither the name of the copyright holder nor the names of its          *
 *    contributors may be used to endorse or promote products derived from   *
 *    this software without specific prior written permission.               *
 *                                                                           *
 * 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.              *
Jan Möbius's avatar
Jan Möbius committed
39
*                                                                            *
40
\*===========================================================================*/
Jan Möbius's avatar
 
Jan Möbius committed
41

42
/*===========================================================================*\
Jan Möbius's avatar
Jan Möbius committed
43 44
*                                                                            *
*   $Revision$                                                       *
45 46
*   $LastChangedBy$                                                 *
*   $Date$                    *
Jan Möbius's avatar
Jan Möbius committed
47
*                                                                            *
48
\*===========================================================================*/
Jan Möbius's avatar
 
Jan Möbius committed
49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67


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

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

#ifndef COREWIDGET_HH
#define COREWIDGET_HH


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

68 69
#include <set>

Jan Möbius's avatar
 
Jan Möbius committed
70
#include "OpenFlipper/common/Types.hh"
Jan Möbius's avatar
Jan Möbius committed
71
#include <OpenFlipper/common/GlobalOptions.hh>
Jan Möbius's avatar
 
Jan Möbius committed
72 73 74 75 76 77
#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
78
#include <OpenFlipper/widgets/coreWidget/SideArea.hh>
Dirk Wilden's avatar
Dirk Wilden committed
79
#include <OpenFlipper/widgets/coreWidget/ColorStatusBar.hh>
Jan Möbius's avatar
 
Jan Möbius committed
80

81
#include <OpenFlipper/widgets/glWidget/QtBaseViewer.hh>
Jan Möbius's avatar
 
Jan Möbius committed
82 83
#include <OpenFlipper/widgets/glWidget/QtGLGraphicsScene.hh>
#include <OpenFlipper/widgets/glWidget/QtGLGraphicsView.hh>
Jan Möbius's avatar
Jan Möbius committed
84
#include <OpenFlipper/widgets/glWidget/QtMultiViewLayout.hh>
85
#include <OpenFlipper/widgets/glWidget/QtSlideWindow.hh>
Jan Möbius's avatar
 
Jan Möbius committed
86 87 88 89 90 91 92 93

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

94 95 96
#include <QFuture>
#include <QFutureWatcher>

Jan Möbius's avatar
 
Jan Möbius committed
97 98
#include <QDockWidget>

Jan Möbius's avatar
Jan Möbius committed
99
#include <OpenFlipper/widgets/aboutWidget/aboutWidget.hh>
100
#include <OpenFlipper/widgets/loggerWidget/loggerWidget.hh>
101
#include <OpenFlipper/widgets/optionsWidget/optionsWidget.hh>
102
#include <OpenFlipper/widgets/helpWidget/helpWidget.hh>
103
#include <OpenFlipper/widgets/stereoSettingsWidget/stereoSettingsWidget.hh>
104
#include <OpenFlipper/widgets/postProcessorWidget/postProcessorWidget.hh>
Jan Möbius's avatar
Jan Möbius committed
105
#include <OpenFlipper/widgets/rendererWidget/rendererWidget.hh>
Jan Möbius's avatar
Jan Möbius committed
106
#include <OpenFlipper/widgets/rendererWidget/rendererObjectWidget.hh>
Jan Möbius's avatar
 
Jan Möbius committed
107

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

110 111
#include <ACG/QtWidgets/QtSceneGraphWidget.hh>

Jan Möbius's avatar
Jan Möbius committed
112
#include <ACG/Scenegraph/DrawModes.hh>
113
#include <ACG/Scenegraph/CoordsysNode.hh>
Jan Möbius's avatar
Jan Möbius committed
114

115
#include <OpenFlipper/INIFile/INIFile.hh>
116
#include <OpenFlipper/BasePlugin/PluginFunctions.hh>
Jan Möbius's avatar
Jan Möbius committed
117

Jan Möbius's avatar
Jan Möbius committed
118 119 120 121
/** \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
122 123 124 125 126





Jan Möbius's avatar
 
Jan Möbius committed
127
struct ViewMode{
128

Jan Möbius's avatar
Jan Möbius committed
129 130
  /// Name of the View Mode
  QString name;
131

132 133 134
  /// Icon of the View Mode
  /// TODO Specify size for Icons
  QString icon;
135

Jan Möbius's avatar
Jan Möbius committed
136 137
  /// Is this a user defined custom view mode or a plugin generated one
  bool custom;
138

Jan Möbius's avatar
Jan Möbius committed
139 140
  /// List of Visible Toolboxes in this view mode
  QStringList visibleToolboxes;
141

Jan Möbius's avatar
Jan Möbius committed
142 143
  /// List of Toolbars in this view mode
  QStringList visibleToolbars;
144

Jan Möbius's avatar
Jan Möbius committed
145 146
  /// List of context Menus in this view mode
  QStringList visibleContextMenus;
Jan Möbius's avatar
 
Jan Möbius committed
147 148 149 150 151 152 153 154 155 156 157 158 159
};

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

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

/** Info struct containing information about custom context menus
 */
160 161 162
class MenuInfo {
  public:
    MenuInfo():
Jan Möbius's avatar
Jan Möbius committed
163 164
      action(0),
      type(CONTEXTBACKGROUNDMENU)
165 166 167 168
    {}

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

170 171
    /// Type of objects for which the context Menu should be visible
    DataType        contextType;
Jan Möbius's avatar
 
Jan Möbius committed
172

173
    /// Type of the context Menu ( Context for what type .. Background,Object,Node)
Jan Möbius's avatar
Jan Möbius committed
174
    ContextMenuType type;
Jan Möbius's avatar
 
Jan Möbius committed
175 176
};

Jan Möbius's avatar
Jan Möbius committed
177 178 179 180
/** \brief Struct containing information about pickModes
 *
 * This is an internal DataStructure! Don't use it. It's used to
 * manage the pickmode information internally.
181 182 183 184 185 186 187
*/
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
188
    /// Destructor
189 190 191
    ~PickMode() {};


Jan Möbius's avatar
Jan Möbius committed
192 193 194 195
    /** \brief PickMode visible
     *
     * @param _visible Should this be a visible or a hidden pick mode?
     */
196 197
    void visible(const bool _visible);

Jan Möbius's avatar
Jan Möbius committed
198 199 200 201
    /** \brief PickMode visible
     *
     * Visible or hidden pick mode
     */
202 203
    bool visible() const;

Jan Möbius's avatar
Jan Möbius committed
204 205 206 207
    /** \brief PickMode Name
    *
    * Name of the pick mode
    */
208 209
    std::string name() const;

Jan Möbius's avatar
Jan Möbius committed
210 211 212 213 214 215 216
    /** \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
     */
217
    void tracking(const bool _tracking);
Jan Möbius's avatar
Jan Möbius committed
218 219 220 221 222 223

    /** \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.
    */
224 225
    bool tracking() const;

Jan Möbius's avatar
Jan Möbius committed
226 227 228 229 230
    /** \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.
    */
231 232
    QCursor cursor() const;

233 234 235 236 237 238 239 240 241
    /** \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
242 243 244 245 246 247 248
    /** \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
    */
249
    void toolbar(QToolBar* _toolbar);
Jan Möbius's avatar
Jan Möbius committed
250 251 252 253 254 255

    /** \brief PickMode toolbar
    *
    * Each pickmode can have a toolbar that will be visible at the top of the screen.
    * This toolbar is stored here.
    */
256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279
    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
280 281 282 283 284 285 286 287
/** Core Widget of the Application
 */
class CoreWidget : public QMainWindow
{
  Q_OBJECT

public:

288 289
  friend class Core;

Jan Möbius's avatar
 
Jan Möbius committed
290
  /// constructor
Dirk Wilden's avatar
Dirk Wilden committed
291
  CoreWidget( QVector<ViewMode*>& _viewModes, std::vector<PluginInfo>& _plugins, QList< SlotInfo >& _coreSlots );
Jan Möbius's avatar
 
Jan Möbius committed
292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307

  /// 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
308
    void showPlugins();
Jan Möbius's avatar
 
Jan Möbius committed
309 310 311 312 313 314

  private slots:

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

Dirk Wilden's avatar
Dirk Wilden committed
315 316 317 318 319 320 321 322 323 324 325
   //===========================================================================
  /** @name Logger
  * @{ */
  //===========================================================================

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

   /** @} */

Jan Möbius's avatar
 
Jan Möbius committed
326 327 328 329 330 331 332 333 334 335 336
   //===========================================================================
  /** @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
337 338 339
    // Filter alt key events under windows
    //bool eventFilter(QObject *obj, QEvent *ev);

340 341
  private:
    //event handling
342 343
    bool event( QEvent *event );

344 345
    bool eventFilter(QObject *_obj, QEvent *_event);

Jan Möbius's avatar
 
Jan Möbius committed
346 347
  signals :

348 349 350 351 352 353 354 355 356 357 358 359 360
    /** 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
361

Dirk Wilden's avatar
Dirk Wilden committed
362 363
    ///call a scripting function
    void call( QString _expression , bool& _success  );
Dirk Wilden's avatar
Dirk Wilden committed
364 365

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

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

371 372 373 374 375 376 377 378
    /** \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
     */
379 380
    void coreKeyPressEvent();

Dirk Wilden's avatar
Dirk Wilden committed
381 382 383 384 385
    /// 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
386
    QString    getRPCName(QObject* _plugin );
Dirk Wilden's avatar
Dirk Wilden committed
387 388

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

Dirk Wilden's avatar
Dirk Wilden committed
391 392 393 394 395 396
    ///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
397 398 399
    ///list of scripting slots from core
    QList< SlotInfo >& coreSlots_;

Dirk Wilden's avatar
Dirk Wilden committed
400
  private slots:
401 402 403 404 405
     /** \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
406 407 408 409
    void slotRegisterKey(int _key, Qt::KeyboardModifiers _modifiers, QString _description,
                         bool _multiUse = false);

  public slots:
410 411 412 413
     /** \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
414
    void slotAddKeyMapping(int _key, Qt::KeyboardModifiers _modifiers, QObject* _plugin, int _keyBindingID);
Dirk Wilden's avatar
Dirk Wilden committed
415

416 417 418 419 420
     /** \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
421 422
    void slotRegisterSlotKeyBindings();

423 424 425 426 427 428 429
  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);

Jan Möbius's avatar
Jan Möbius committed
430 431
    void showReducedMenuBar(bool reduced);

Dirk Wilden's avatar
Dirk Wilden committed
432 433 434 435
  private:
    /// Store the state of the shift key
    bool shiftPressed_;

Jan Möbius's avatar
 
Jan Möbius committed
436 437 438 439 440 441 442 443 444
   /** @} */

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

  public:

445 446
    /// Setup the main menubar
    void setupMenuBar();
447

Dirk Wilden's avatar
Dirk Wilden committed
448 449 450 451 452 453 454 455 456 457
   /** @} */

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

  signals:
    void startVideoCapture(QString _baseName, int _fps, bool _captureViewers);
    void stopVideoCapture();
458 459 460 461

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

Dirk Wilden's avatar
Dirk Wilden committed
462 463
  private slots:
    void startVideoCaptureDialog();
464

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

Jan Möbius's avatar
Jan Möbius committed
467 468 469 470
  //===========================================================================
  /** @name Recent File Menu handling
   * @{ */
  //===========================================================================
471

Dirk Wilden's avatar
Dirk Wilden committed
472 473
  public:

Jan Möbius's avatar
 
Jan Möbius committed
474 475 476 477 478 479 480
  /// 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
481

Jan Möbius's avatar
 
Jan Möbius committed
482 483 484 485
  //===========================================================================
  /** @name GUI Controls
  * @{ */
  //===========================================================================
Jan Möbius's avatar
Jan Möbius committed
486

Jan Möbius's avatar
 
Jan Möbius committed
487
  public :
488 489 490 491 492 493 494 495 496 497 498 499

    /// 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();

500 501 502 503
    QScrollArea* getToolboxScrollArea() { return toolBoxScroll_; }
    QWidget* getToolboxArea() { return toolBoxArea_; }
    SideArea* getToolbox() { return toolBox_; }

504 505
  public slots:

Jan Möbius's avatar
 
Jan Möbius committed
506 507
    /// Set application to Fullscreen and back
    void toggleFullscreen();
Jan Möbius's avatar
Jan Möbius committed
508

509 510 511
    /// Enable or disable fullscreen mode
    void setFullscreen(bool _state );

Jan Möbius's avatar
 
Jan Möbius committed
512 513
    /// Hide or show logging area
    void toggleLogger();
514 515

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

Jan Möbius's avatar
 
Jan Möbius committed
518 519
    /// Hide or show toolbox area
    void toggleToolbox();
520 521 522
    
    /// Show or hide toolbox
    void showToolbox( bool _state );
523

524 525 526
    /// Change visibility of the Status Bar
    void toggleStatusBar();

527 528
    /// Show or hide status bar
    void showStatusBar( bool _state );
Jan Möbius's avatar
Dennis:  
Jan Möbius committed
529

530 531
    /// Show or hide menubar
    void showMenuBar( bool _state );
532

533 534
    /// Hide or show menu bar
    void toggleMenuBar();
Dirk Wilden's avatar
Dirk Wilden committed
535

536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552
    /// 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 );
553

554 555 556
    /// will be emitted if the fullscreen state is changed (_state = true => in fullscreen)
    void fullScreenChanged( bool _state );

Jan Möbius's avatar
Jan Möbius committed
557 558
  private:
    OpenFlipper::Options::LoggerState loggerState_;
Dirk Wilden's avatar
Dirk Wilden committed
559 560
    
    QSize defaultIconSize_;
561

Jan Möbius's avatar
 
Jan Möbius committed
562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578
  /** @} */

  //===========================================================================
    /** @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:

Jan Möbius's avatar
Jan Möbius committed
579
      QAction* viewModeButton_;
Jan Möbius's avatar
 
Jan Möbius committed
580 581 582 583 584 585 586 587 588

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

    public slots:

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

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

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

595
      /// Add or change Toolbars for a ViewMode (non-userdefined viewMode)
596 597
      void slotAddViewModeToolbars(QString _mode, QStringList _usedToolbars);

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

Jan Möbius's avatar
Marlin:  
Jan Möbius committed
601 602 603 604 605 606 607 608
      /// 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);
609

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

Jan Möbius's avatar
Jan Möbius committed
613 614
      /// 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
615 616

      /// Slot for Changing visible toolWidgets
617
      void slotChangeView(QString _mode, QStringList _toolboxWidgets, QStringList _toolbars, QStringList _contextmenus, bool _expandAll = false);
618 619
      
      /// Set orientation of tool box (either on the right or the left side of the screen)
620
      void setToolBoxOrientationOnTheRight(bool _toolBoxRight);
621 622 623
      
      /// Hide or show the View Mode controls
      void showViewModeControls(bool _show);
Jan Möbius's avatar
 
Jan Möbius committed
624

Marcel Campen's avatar
Marcel Campen committed
625 626 627
      /// Hide the context menu
      void slotHideContextMenu();

Jan Möbius's avatar
 
Jan Möbius committed
628 629 630 631 632 633 634
    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
635
      /// Show a dialog in which the viewMode can be edited
Jan Möbius's avatar
 
Jan Möbius committed
636
      void slotViewModeDialog();
637

Jan Möbius's avatar
Jan Möbius committed
638 639
      /// Show a dialog in which the viewMode can be changed
      void slotViewChangeDialog();
Jan Möbius's avatar
 
Jan Möbius committed
640

Jan Möbius's avatar
Jan Möbius committed
641 642 643
      /// update the content of the specified examiner
      void slotUpdateExaminer(unsigned _id);

Jan Möbius's avatar
 
Jan Möbius committed
644
    public slots :
645 646
      
      /// Set the view Mode to the given Mode
647
      void setViewMode( QString _mode, bool _expandAll = false );
648 649
      
      /// Move a specific toolbox widget to the top of the side area
650
      void moveToolBoxToTop(QString _name);
651 652
      
      /// Move a specific toolbox widget to the bottom of the side area
653
      void moveToolBoxToBottom(QString _name);
Jan Möbius's avatar
 
Jan Möbius committed
654 655 656 657 658 659 660 661 662 663

   /** @} */



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

664
  private:
Jan Möbius's avatar
 
Jan Möbius committed
665 666

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

Jan Möbius's avatar
 
Jan Möbius committed
669 670
    ///Spliter between toplevel objects and the textedit at the bottom
    QSplitter* splitter_;
Jan Möbius's avatar
Jan Möbius committed
671

672 673 674
    /// Group box containing Task Switcher Controls
    QGroupBox *viewModeControlBox_;
    
Jan Möbius's avatar
 
Jan Möbius committed
675
    /// Textedit at the bottom for log messages
676
    LoggerWidget* logWidget_;
Jan Möbius's avatar
Jan Möbius committed
677

Jan Möbius's avatar
 
Jan Möbius committed
678 679 680 681 682 683
    /// Size of the logging window ( defaults to 240 )
    int originalLoggerSize_;

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

684 685 686
    /// Algorithms Menu
    QMenu* algorithmMenu_;

Jan Möbius's avatar
 
Jan Möbius committed
687 688
    /// Help Menu
    QMenu* helpMenu_;
689 690 691 692 693 694 695
    
    /// Window Menu
    QMenu* windowMenu_;
    
    /// Action for View Mode Widget Conrol in Menu
    QAction* AC_ShowViewModeControls_;
    
Jan Möbius's avatar
 
Jan Möbius committed
696 697 698 699 700 701 702 703 704 705 706 707 708
    /// 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
709
    QtMultiViewLayout* baseLayout_;
Jan Möbius's avatar
 
Jan Möbius committed
710

711 712 713
    /// Class that holds the animated log widget
    QtSlideWindow* slidingLogger_;

Jan Möbius's avatar
Dennis:  
Jan Möbius committed
714 715
    /// Widget for toolBox
    QWidget* toolBoxArea_;
716

Jan Möbius's avatar
Jan Möbius committed
717 718
    /// Button to change viewModes
    QPushButton* vmChangeButton_;
Jan Möbius's avatar
Dennis:  
Jan Möbius committed
719 720 721 722 723 724 725 726 727 728

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

    /// Toolbox
    SideArea* toolBox_;

    /// Toolbox scroll area
    QScrollArea* toolBoxScroll_;

729
    /// Handle to picking toolbar
Jan Möbius's avatar
Jan Möbius committed
730
    typedef std::map<QToolBar*,QGraphicsProxyWidget*> PickToolBarMap;
731
    PickToolBarMap curPickingToolbarItems_;
Jan Möbius's avatar
Dennis:  
Jan Möbius committed
732

733 734 735
    /// Extra toolbar not in scene for picking
    QToolBar* pickToolBarExternal_;

736 737 738
    /// Store all toolbars that once have been registered
    std::set<QToolBar*> registeredToolbars_;

Jan Möbius's avatar
Dennis:  
Jan Möbius committed
739 740 741
    /// Cursor handling
    CursorPainter* cursorPainter_;

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

743 744 745
    // widget showing the scenegraph
    ACG::QtWidgets::QtSceneGraphDialog* sceneGraphDialog_;

Jan Möbius's avatar
 
Jan Möbius committed
746 747 748
  /** @} */

  private slots:
749 750 751 752 753 754

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


755 756 757 758 759
   /** Makes the sender examiner active
    */
   void slotActivateExaminer ();


Jan Möbius's avatar
 
Jan Möbius committed
760 761 762 763 764 765
   /** 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
766 767
   /** Updates the size of the main graphics widget in the scene
     */
768
   void sceneRectChanged(const QRectF &rect);
Jan Möbius's avatar
 
Jan Möbius committed
769

Jan Möbius's avatar
 
Jan Möbius committed
770 771 772 773 774 775
  //===========================================================================
    /** @name Menubar controls
      * @{ */
  //===========================================================================
  private slots :

Jan Möbius's avatar
Jan Möbius committed
776
    void slotAddMenubarAction( QAction* _action , QString _name );
777
    void slotAddMenubarActions( std::vector<QAction*> _actions , QString _name );
Jan Möbius's avatar
Jan Möbius committed
778
    void slotGetMenubarMenu (QString _name, QMenu *& _menu, bool _create);
Jan Möbius's avatar
 
Jan Möbius committed
779 780 781 782 783 784 785 786

  private:

    /// File Menu
    QMenu *fileMenu_;

    /// View Menu
    QMenu *viewMenu_;
787

788 789
    /// Tools Menu
    QMenu *toolsMenu_;
Jan Möbius's avatar
 
Jan Möbius committed
790 791 792 793

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

Jan Möbius's avatar
Jan Möbius committed
794 795 796
    /// All available menus
    QMap<QString, QMenu *> menus_;

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

Jan Möbius's avatar
 
Jan Möbius committed
799 800 801 802
  //===========================================================================
    /** @name ToolBar controls
      * @{ */
  //===========================================================================
Jan Möbius's avatar
Jan Möbius committed
803
  private:
Jan Möbius's avatar
 
Jan Möbius committed
804
    QToolBar* viewerToolbar_;
Dirk Wilden's avatar
Dirk Wilden committed
805 806

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

808 809 810 811 812
    QToolButton* stereoButton_;
    QToolButton* moveButton_;
    QToolButton* pickButton_;
    QToolButton* questionButton_;

813
    QComboBox* viewerLayoutBox_;
814

Jan Möbius's avatar
 
Jan Möbius committed
815 816 817
  /** @} */

  //===========================================================================
Jan Möbius's avatar
Jan Möbius committed
818
    /** @name View Menu
Jan Möbius's avatar
 
Jan Möbius committed
819 820
      * @{ */
  //===========================================================================
821

Jan Möbius's avatar
Jan Möbius committed
822 823 824
  public slots:
    /// Setup and update the global draw menu
    void slotUpdateGlobalDrawMenu();
825

826 827 828
    /// Setup and update the global renderer menu
    void slotUpdateRendererMenu();

829 830
    /// Change viewer layout that was selected in the combo box
    void setViewerLayout(int _idx);
831

832 833
  private slots:
    /// Switches over to the next view mode
834
    void nextViewerLayout();
835

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

839 840
    /// Called before the view Menu is shown
    void slotViewMenuAboutToShow();
841

842 843 844 845 846 847
    /// 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
848 849 850
  private:
    /// This variable holds the global draw menu
    QMenu* globalDrawMenu_;
851

852 853 854
    /// This variable holds the global renderer menu
    QMenu* rendererMenu_;

855 856
    QActionGroup * drawGroup_;

857 858 859
    /// Group for all renderers
    QActionGroup * rendererGroup_;

Jan Möbius's avatar
Jan Möbius committed
860 861
    /// Group for all menu items
    QActionGroup* viewGroup_;
862

863 864
    QAction* perspectiveProjectionAction_;
    QAction* orthogonalProjectionAction_;
865

866
    /// Action to globally set animation
867
    QAction* globalAnimationAction_;
868

869 870
    /// Action to globally set backface culling
    QAction* globalBackfaceCullingAction_;
871

872
    /// Action to globally set two-sided lighting
873 874
    QAction* globalTwosidedLightingAction_;

875
    /// Action to globally set multisampling
876
    QAction* globalMultisamplingAction_;
877 878 879
    
    /// Action to globally set mipmapping
    QAction* globalMipmappingAction_;
880

Jan Möbius's avatar
Jan Möbius committed
881
    ACG::SceneGraph::DrawModes::DrawMode activeDrawModes_;
882

Jan Möbius's avatar
Jan Möbius committed
883
    ACG::SceneGraph::DrawModes::DrawMode availableGlobalDrawModes_;
884

Jan Möbius's avatar
Jan Möbius committed
885 886 887 888 889 890
  /** @} */

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

Jan Möbius's avatar
 
Jan Möbius committed
892
  signals :
893 894 895 896 897 898 899 900 901
    /// 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
902 903 904 905 906

  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
907 908
    /// 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
909

Jan Möbius's avatar
 
Jan Möbius committed
910 911
    /// 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
912 913 914
    
    /// called by slotAddContextItem to add the item to the view mode
    void slotAddContextItemToViewMode( QAction* _entry );
Jan Möbius's avatar
 
Jan Möbius committed
915

916 917 918
    /// Paste the view to the last active examiner
    void slotPasteView( );

919 920 921
    /// Paste the view, the window and toolbox size to the last active examiner
    void slotPasteViewAndWindow( );

922 923 924
    /// Set the supplied serialized view
    void slotSetView( QString view );

925 926 927
    /// Set the supplied serialized view
    void slotSetViewAndWindowGeometry( QString view );

928 929 930
    /// Copy view from the last active examiner
    void slotCopyView( );

931 932
    /// Called when a coordsys drawMode has been changed
    void slotViewerDrawMenu( QAction * _action );
933

934 935 936
    /// Called when a different post processor has been chosen
    void slotPostProcessorMenu( QAction * _action);

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

940 941
    /// Creates a draw Menu for the currently active Viewer
    void slotUpdateViewerDrawMenu();
942

Dirk Wilden's avatar
Dirk Wilden committed
943
    /// Create a snapshot of the last active examiner
944
    void slotExaminerSnapshot();
Dirk Wilden's avatar
Dirk Wilden committed
945

946 947 948
    /// Show / hide wheels
    void slotSwitchWheels(bool _state);

949 950 951
    /// Switch navigation mode
    void slotSwitchNavigation(bool _egomode);

Dirk Wilden's avatar
Dirk Wilden committed
952 953 954
    /// Set the snapShot name for all examiners
    void slotSnapshotName();

Dirk Wilden's avatar
Dirk Wilden committed
955 956 957
    /// Hide coordinate systems in all viewers
    void slotCoordSysVisibility(bool _visible);

Jan Möbius's avatar
 
Jan Möbius committed
958
  private :
Jan Möbius's avatar
Jan Möbius committed
959 960 961 962
    /** Update the contextmenu for the given position inside an examiner widget
     *
     * @param _point      Picking position in coordinates of the viewer
     */
963 964
    void updatePopupMenu(const QPoint& _point);

965 966
    void updatePopupMenuCoordsysNode(QMenu* _menu , const int _part);
    void updatePopupMenuObject(QMenu* _menu , BaseObjectData* _object );
Jan Möbius's avatar
Jan Möbius committed
967
    void updatePopupMenuBackground(QMenu* _menu , const QPoint& _point);
968 969 970
    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
971 972 973 974 975 976 977 978 979 980

  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_;
981

982 983
    /// DrawGroup for per Viewer Draw Modes
    QActionGroup* drawGroupViewer_;
984

985 986
    /// Draw Menu for per Viewer Draw Modes
    QMenu* viewerDrawMenu_;
Jan Möbius's avatar
 
Jan Möbius committed
987

Matthias Möller's avatar
Matthias Möller committed
988 989 990
    /// owns all the checkboxes of viewerDrawMenu_
    QWidget* viewerDrawMenuWidget_;

991 992 993 994
    /// Menu which holds the context menu entries for
    /// the coordsys node if invisible
    QMenu* coordSysMenu_;

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

Dirk Wilden's avatar
Dirk Wilden committed
997 998 999 1000 1001 1002 1003 1004 1005 1006 1007 1008 1009
  //===========================================================================
    /** @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
1010
    void viewerSnapshotDialog();
Dirk Wilden's avatar
Dirk Wilden committed
1011 1012

    /// Create a snapshot of the whole app
Dirk Wilden's avatar
Dirk Wilden committed
1013
    void viewerSnapshot();
Dirk Wilden's avatar
Dirk Wilden committed
1014 1015 1016 1017 1018 1019 1020 1021 1022 1023

    /// 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);

1024 1025 1026
    /// Scriptable snapshot method offering full control
    void viewerSnapshot(QString file_name, bool store_comments,
            bool comments_visible_only, bool comments_targeted_only,
1027
            bool store_material_info, int snapshot_width, int snapshot_height,
1028 1029
            bool snapshot_transparent, bool hide_coord_sys,
            int snapshot_multisampling, bool store_view);
Dirk Wilden's avatar
Dirk Wilden committed
1030 1031 1032

  /** @} */

1033 1034 1035 1036 1037 1038 1039
  //===========================================================================
    /** @name Thread-safe functions using QFuture
    * @{ */
  //===========================================================================

  public:

1040
    void writeImageAsynchronously(QImage* _image, const QString _name);
1041 1042 1043 1044 1045 1046

  private:

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

1047 1048 1049
    // Mutex for operations on map
    QMutex map_mutex_;

1050 1051 1052 1053 1054 1055
  private slots:

    void delete_garbage();

  /** @} */

Jan Möbius's avatar
 
Jan Möbius committed
1056 1057 1058 1059 1060 1061 1062 1063 1064 1065 1066 1067 1068 1069 1070 1071 1072 1073 1074 1075 1076
  //===========================================================================
    /** @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_;

1077
  public :
Jan Möbius's avatar
 
Jan Möbius committed
1078 1079 1080 1081 1082 1083 1084 1085 1086 1087
    /// Container widget for holding multiple views
    QStackedWidget* stackedWidget_;

  /** @} */

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

1088 1089 1090
  private:
    static const QString homePage_;

Jan Möbius's avatar
 
Jan Möbius committed
1091 1092
  public slots:
    /// Display the help Browser
1093
    void showHelpBrowser(const QString &page = homePage_);
Matthias Möller's avatar