mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-03 17:56:21 +03:00
- Convert package creation. It is used to prepare some auxiliary presentations/methods to prepare variables for inspector based on occt classes. - ViewControl package improvement: Classes for property view, table, table model are implemented to visualize view of properties. This view is filled by selection in tree if the selected object has implemented DumpJson functionality. - TreeModel package improvements: Method InitColumn is implemented in TreeModel_TreeModel to fill default columns in base model. The default columns are: Name, Visibility, Rows. Additional columns should be added in successors. Container of root items is moved into the base class - View package imrovements: Store preferences: display mode, fit all checked state and type of external context View_DisplayPreview is added to process preview for selected in tree view objects hide actions Clear, Multi, Single by default (as selection in tree view or Visibility state of item define which presentations should be displayed or erased) - ShapeView plugin improvements: Property View content based on DumpJson (columns in tree view for properties are removed), Properties for TopoDS_Shape are displayed Explode shape action in tree view to see content of shape by selected shape type. Type of displayed shapes is only preview, it is not used in export action. Export shape into BREP. The previous implementation about BREP files in some directory and default view is removed. - VInspector plugin imrovements: Property View content based on DumpJson (columns in tree view for properties are removed), Properties for AIS_InteractiveContext and AIS_InteractiveObject are displayed obsolete classes to provide properties are removed. - DFBrowser plugin improvements: Property View content based on DumpJson is not used yet. But there is the USE_DUMPJSON macro. It's switch off by default. If switch ON, it creates a Property View filled with DumpJson. It's a way of DFBrowser moving on this property view. Init uses static variable CDF_Session::CurrentSession()->CurrentApplication to fill plugin if application in plugin is not set but OCAF application exists - OCC_VERSION_HEX variable used for previous OCCT versions support (before 6.9.0 or 7.2.0) is removed
132 lines
5.1 KiB
C++
132 lines
5.1 KiB
C++
// 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 DFBrowser_TreeLevelLine_H
|
|
#define DFBrowser_TreeLevelLine_H
|
|
|
|
#include <inspector/TreeModel_ItemBase.hxx>
|
|
|
|
#include <Standard.hxx>
|
|
|
|
#include <Standard_WarningsDisable.hxx>
|
|
#include <QItemSelection>
|
|
#include <QObject>
|
|
#include <QMap>
|
|
#include <QModelIndex>
|
|
#include <Standard_WarningsRestore.hxx>
|
|
|
|
class DFBrowser_SearchLine;
|
|
|
|
class QAbstractItemModel;
|
|
class QToolButton;
|
|
class QTableView;
|
|
class QWidget;
|
|
|
|
//! \class DFBrowser_TreeLevelLine
|
|
//! This is a control to visualize the current selected item of OCAF tree view.
|
|
//! It contains history of previous selected items.
|
|
//! The structure of this control is the next:
|
|
//! <back button> <forward button> <selected item line> <update button> <search line>
|
|
//! - <back button> allows moving to previously selected item (if it exists)
|
|
//! - <forward button> allows moving to next selected item (if it exists)
|
|
//! - <selected item line> path to currently selected item in OCAF tree view. Click on any level will
|
|
//! select the clicked item in tree view.
|
|
//! - <update button> will update content of OCAF tree model
|
|
//! - <search line> allows type label entry or attribute name and see in search view the available elements
|
|
class DFBrowser_TreeLevelLine : public QObject
|
|
{
|
|
Q_OBJECT
|
|
public:
|
|
|
|
//! Constructor
|
|
Standard_EXPORT DFBrowser_TreeLevelLine (QWidget* theParent);
|
|
|
|
//! Destructor
|
|
virtual ~DFBrowser_TreeLevelLine() {}
|
|
|
|
//! Clears history of selected items
|
|
Standard_EXPORT void ClearHistory();
|
|
|
|
//! Returns parent control
|
|
QWidget* GetControl() const { return myMainWindow; }
|
|
|
|
//! Returns current search line
|
|
DFBrowser_SearchLine* GetSearchLine() const { return mySearchLine; };
|
|
|
|
signals:
|
|
|
|
//! Signal about selection of an item in tree level line
|
|
//! \param theIndex a tree view model index of selected item
|
|
void indexSelected (const QModelIndex& theIndex);
|
|
|
|
//! Signal about necessity to update OCAF tree model
|
|
void updateClicked();
|
|
|
|
public slots:
|
|
|
|
//! Listens tree view selection model. Update tree level line by selected item. Stores
|
|
//! \param theSelected a list of selected items
|
|
//! \param theDeselected a list of deselected items
|
|
Standard_EXPORT void OnTreeViewSelectionChanged (const QItemSelection& theSelected,
|
|
const QItemSelection& theDeselected);
|
|
|
|
private slots:
|
|
|
|
//! Listens table view selection model. Gets selected tree view model index and emit indexSelected signal.
|
|
//! \param theSelected a list of selected items
|
|
//! \param theDeselected a list of deselected items
|
|
void onTableSelectionChanged (const QItemSelection& theSelected, const QItemSelection& theDeselected);
|
|
|
|
//! Listens actions and do the following:
|
|
//! - <backward>: moves history to the previous selection item, emits indexSelected signal
|
|
//! - <forward>: moves history to the next selection item, emits indexSelected signal
|
|
//! - <update>: emits updateClicked signal to update OCAF tree model
|
|
void onActionClicked();
|
|
|
|
private:
|
|
|
|
//! Returns the previous index of history selection
|
|
QModelIndex getBackwardIndex();
|
|
|
|
//! Returns the next index of history selection
|
|
QModelIndex getForwardIndex();
|
|
|
|
//! Appends new history index, set it active, remove the first history index if the cache is out of range
|
|
//! \param theIndex a selected OCAF tree model index
|
|
void setForwardIndex (const QModelIndex& theIndex);
|
|
|
|
//! Updates enable state of backward/forward actions depending on the current item index
|
|
void updateActionsState();
|
|
|
|
//! Sets the current index and update actions state
|
|
//! \param theIndexId an item index, should be in range of history of indices
|
|
void setCurrentHistoryIndex (const int theIndexId);
|
|
|
|
private:
|
|
|
|
bool mySelectionProcessingBlocked; //!< if true, table view selection is started but has not been finished yet
|
|
QList<QModelIndex> myHistoryIndices; //!< cached selected OCAF tree model indices
|
|
int myCurrentHistoryIndex; //!< an index of the current history selected index from myHistoryIndices
|
|
|
|
QWidget* myMainWindow; //!< parent widget for controls
|
|
QToolButton* myBackwardButton; //!< backward button, to select previous selected item
|
|
QToolButton* myForwardButton; //!< forward button, to select next selected item
|
|
QToolButton* myUpdateButton; //!< update button, like F5, to update OCAF tree model content
|
|
QTableView* myTableView; //!< container of path values to selected item, a path value is a label entry
|
|
|
|
DFBrowser_SearchLine* mySearchLine; //!< line of search
|
|
};
|
|
#endif
|