X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FXGUI%2FXGUI_ObjectsBrowser.h;h=b1a70d487ec1cab3f2d1c6bdc6baf1e8bc89df45;hb=220bd2b37119be1c65abf88a88792445cb9d99f8;hp=d92788abecde6f02730041ba7202c3690b3c1b5b;hpb=86e638f1cea515707ab0d03396661b584985a0c9;p=modules%2Fshaper.git diff --git a/src/XGUI/XGUI_ObjectsBrowser.h b/src/XGUI/XGUI_ObjectsBrowser.h index d92788abe..b1a70d487 100644 --- a/src/XGUI/XGUI_ObjectsBrowser.h +++ b/src/XGUI/XGUI_ObjectsBrowser.h @@ -11,12 +11,78 @@ #include #include +#include class ModuleBase_IDocumentDataModel; -class QLineEdit; class XGUI_DataModel; -//#define ModuleDataModel +/** +* \ingroup GUI +* Implementation of root label in Object Browser +*/ +class XGUI_ActiveDocLbl: public QLabel +{ +Q_OBJECT + public: + /// Constructor + /// \param theText a text + /// \param theParent a parent widget + XGUI_ActiveDocLbl(const QString& theText, QWidget* theParent ); + + /// Sets tree view + /// \param theView a view + void setTreeView(QTreeView* theView); + + /// Returns tree view + QTreeView* treePalette() const { return myTreeView;} + +#if (!defined HAVE_SALOME) && (defined WIN32) + virtual bool event(QEvent* theEvent); +#endif + +public slots: + /// On unselect + void unselect(); + +protected: + /// On mouse release + virtual void mouseReleaseEvent( QMouseEvent* e); + + /// Filter event + bool eventFilter(QObject* theObj, QEvent* theEvent); + +private: + QString myPreSelectionStyle; + QString myNeutralStyle; + QString mySelectionStyle; + + QTreeView* myTreeView; + bool myIsSelected; +}; + + +#if (!defined HAVE_SALOME) && (defined WIN32) +#include +/** +* \ingroup GUI +* Implementation of XGUI_DataTree custom style +*/ +class XGUI_TreeViewStyle : public QWindowsVistaStyle +{ + Q_OBJECT +public: + XGUI_TreeViewStyle() : QWindowsVistaStyle() {} + + void drawPrimitive(PrimitiveElement theElement, const QStyleOption* theOption, + QPainter* thePainter, const QWidget* theWidget = 0) const; + + void setIndex(const QModelIndex& theIndex) { myIndex = theIndex; } + QModelIndex index() const { return myIndex; } + +private: + QModelIndex myIndex; +}; +#endif /** * \ingroup GUI @@ -33,7 +99,7 @@ Q_OBJECT virtual ~XGUI_DataTree(); /// Returns current data model - ModuleBase_IDocumentDataModel* dataModel() const; + XGUI_DataModel* dataModel() const; signals: //! Emited on context menu request @@ -47,6 +113,7 @@ public slots: /// Commit modified data (used for renaming of objects) virtual void commitData(QWidget* theEditor); + /// A slot which is called on mouse double click void onDoubleClick(const QModelIndex&); protected: @@ -56,6 +123,13 @@ public slots: /// Redefinition of virtual method virtual void resizeEvent(QResizeEvent* theEvent); +#if (!defined HAVE_SALOME) && (defined WIN32) + virtual void drawRow(QPainter* thePainter, + const QStyleOptionViewItem& theOptions, + const QModelIndex& theIndex) const; +private: + XGUI_TreeViewStyle* myStyle; +#endif }; /**\class XGUI_ObjectsBrowser @@ -72,17 +146,10 @@ Q_OBJECT virtual ~XGUI_ObjectsBrowser(); //! Returns Model which provides access to data objects -#ifdef ModuleDataModel - ModuleBase_IDocumentDataModel* dataModel() const - { - return myDocModel; - } -#else XGUI_DataModel* dataModel() const { return myDocModel; } -#endif //! Returns list of currently selected objects //! \param theIndexes - output list of corresponded indexes (can be NULL) @@ -105,7 +172,7 @@ Q_OBJECT } /// Returns active doc label object - QLineEdit* activeDocLabel() const { return myActiveDocLbl; } + QLabel* activeDocLabel() const { return myActiveDocLbl; } /// Rebuild data tree void rebuildDataTree(); @@ -113,11 +180,6 @@ Q_OBJECT /// Resets the object browser into initial state void clearContent(); - /// Set Data Model for the Object Browser -#ifdef ModuleDataModel - void setDataModel(ModuleBase_IDocumentDataModel* theModel); -#endif - public slots: //! Called on Edit command request void onEditItem(); @@ -132,10 +194,6 @@ signals: //! Segnal is emitted when user cliks by mouse in header label of object browser void headerMouseDblClicked(const QModelIndex&); - protected: - /// Redefinition of virtual method - virtual bool eventFilter(QObject* obj, QEvent* theEvent); - private slots: /// Show context menu /// \param theEvent a context menu event @@ -149,15 +207,11 @@ signals: void onSelectionChanged(const QItemSelection& theSelected, const QItemSelection& theDeselected); private: - void closeDocNameEditing(bool toSave); + QModelIndexList expandedItems(const QModelIndex& theParent = QModelIndex()) const; //! Internal model -#ifdef ModuleDataModel - ModuleBase_IDocumentDataModel* myDocModel; -#else XGUI_DataModel* myDocModel; -#endif - QLineEdit* myActiveDocLbl; + XGUI_ActiveDocLbl* myActiveDocLbl; XGUI_DataTree* myTreeView; };