// Created on: 2017-06-16 // Created by: Natalia ERMOLAEVA // Copyright (c) 2017 OPEN CASCADE SAS // // This file is part of Open CASCADE Technology software library. // // This library is free software; you can redistribute it and/or modify it under // the terms of the GNU Lesser General Public License version 2.1 as published // by the Free Software Foundation, with special exception defined in the file // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT // distribution for complete text of the license and disclaimer of any warranty. // // Alternatively, this file may be used under the terms of Open CASCADE // commercial license or contractual agreement. #ifndef View_ToolBar_H #define View_ToolBar_H #include #include #include #include #ifdef _MSC_VER #pragma warning(disable : 4127 4718) // conditional expression is constant, recursive call has no side effects #endif #include #include class QComboBox; class QToolButton; class QWidget; //! \class View_ToolBar //! \brief This is a container of the next view actions: //! - selection of interactive context //! - actions of View_ToolActionType enumeration //! //! It contains container of possible interactive contexts where the presentations may be visualized //! and choice control to select an active context. //! If action is clicked, a signal about is sent. class View_ToolBar : public QObject { Q_OBJECT public: //! Constructor Standard_EXPORT View_ToolBar (QWidget* theParent); //! Destructor virtual ~View_ToolBar() Standard_OVERRIDE {} //! \returns parent widget of actions QWidget* GetControl() const { return myMainWindow; } //! Append context for the given type //! \param theType a context type //! \param theContext a context Standard_EXPORT void SetContext (View_ContextType theType, const Handle(AIS_InteractiveContext)& theContext); //! \returns type of active item of context selector Standard_EXPORT View_ContextType GetCurrentContextType() const; //! \returns an active context of context selector Standard_EXPORT Handle(AIS_InteractiveContext) GetCurrentContext() const; //! \returns whether the action is checked(toggled). Acceptable only if the action is checkable. Standard_EXPORT bool IsActionChecked (const int theActionId) const; signals: //! Signal about click on action of View_ToolActionType enumeration void actionClicked (int theActionId); //! Signal about selection of context void contextChanged(); private slots: //! Processes clicked action and emit signal with action identifier void onActionClicked(); private: QWidget* myMainWindow; //!< tool bar parent widget QComboBox* myViewSelector; //!< container of possible contexts QMap myActionsMap; //!< tool actions QMap myViewContexts; //!< contexts QMap myViewContextNames; //!< names of contexts }; #endif