mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-05 18:16:23 +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
162 lines
7.3 KiB
C++
162 lines
7.3 KiB
C++
// Created on: 2020-01-25
|
|
// Created by: Natalia ERMOLAEVA
|
|
// Copyright (c) 2020 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 ViewControl_TableModelValues_H
|
|
#define ViewControl_TableModelValues_H
|
|
|
|
#include <Standard.hxx>
|
|
|
|
#include <inspector/TreeModel_HeaderSection.hxx>
|
|
#include <inspector/TreeModel_ItemProperties.hxx>
|
|
#include <inspector/ViewControl_EditType.hxx>
|
|
|
|
#include <Standard_WarningsDisable.hxx>
|
|
#include <QAbstractTableModel>
|
|
#include <QColor>
|
|
#include <QList>
|
|
#include <QModelIndexList>
|
|
#include <QVariant>
|
|
#include <Standard_WarningsRestore.hxx>
|
|
|
|
//! \class ViewControl_TableModelValues
|
|
//! \brief This is an interace for ViewControl_TableModel to give real values of the model
|
|
//! It should be filled or redefined.
|
|
class ViewControl_TableModelValues
|
|
{
|
|
public:
|
|
|
|
//! Constructor
|
|
ViewControl_TableModelValues (const Qt::Orientation& theOrientation = Qt::Vertical) { SetOrientation (theOrientation); }
|
|
|
|
//! Destructor
|
|
virtual ~ViewControl_TableModelValues() {}
|
|
|
|
//! Returns item table properties builder
|
|
Handle(TreeModel_ItemProperties) Properties() const { return myProperties; }
|
|
|
|
//! Sets item table properties builder
|
|
void SetProperties (const Handle(TreeModel_ItemProperties)& theProperties) { myProperties = theProperties; }
|
|
|
|
//! Sets direction of the values applying, whether it should be placed by rows or by columns
|
|
//! \param theOrientation if horizontal, the values are applied by rows, otherwise by columns
|
|
void SetOrientation (const Qt::Orientation& theOrientation) { myOrientation = theOrientation; }
|
|
|
|
//! Fills the model header values for orientation.
|
|
//! \param theValues a container of header text values
|
|
//! \param theOrientation an orientation of header
|
|
void SetHeaderValues (const QList<TreeModel_HeaderSection>& theValues, const Qt::Orientation theOrientation)
|
|
{ myHeaderValues.insert (theOrientation, theValues); }
|
|
|
|
//! Returns whether the column is hidden by default
|
|
//! \param theColumnId a column index
|
|
//! \return header section values container
|
|
TreeModel_HeaderSection HeaderItem (const Qt::Orientation theOrientation, const int theColumnId) const
|
|
{ return myHeaderValues.contains(theOrientation) ? myHeaderValues[theOrientation][theColumnId] : TreeModel_HeaderSection(); }
|
|
|
|
//! Stores information about table view header visibility
|
|
//! \param theOrientation an orientation of header
|
|
//! \param theVisibility if true, header is visible
|
|
void SetHeaderVisible (const Qt::Orientation theOrientation, const bool theVisibility)
|
|
{ myVisibleHeader.insert (theOrientation, theVisibility); }
|
|
|
|
//! Stores information about table view header visibility
|
|
//! \param theOrientation an orientation of header
|
|
//! \param theVisibility if true, header is visible
|
|
bool IsHeaderVisible (const Qt::Orientation theOrientation) const
|
|
{ return myVisibleHeader.contains(theOrientation) ? myVisibleHeader[theOrientation] : true; }
|
|
|
|
//! Get default section size if defined
|
|
//! \param theOrientation an orientation of header
|
|
//! \param theVisibility if true, header is visible
|
|
bool DefaultSectionSize (const Qt::Orientation theOrientation, int& theSectionSize)
|
|
{
|
|
theSectionSize = myDefaultSectionSize.contains (theOrientation) ? myDefaultSectionSize[theOrientation] : -1;
|
|
return myDefaultSectionSize.contains (theOrientation);
|
|
}
|
|
|
|
//! Set default section size if defined
|
|
//! \param theOrientation an orientation of header
|
|
//! \param theVisibility if true, header is visible
|
|
void SetDefaultSectionSize (const Qt::Orientation theOrientation, const int& theSectionSize)
|
|
{ myDefaultSectionSize.insert(theOrientation, theSectionSize); }
|
|
|
|
//! Returns number of columns, size of header values
|
|
//! \param theParent an index of the parent item
|
|
//! \return an integer value
|
|
Standard_EXPORT virtual int ColumnCount (const QModelIndex& theParent = QModelIndex()) const;
|
|
|
|
//! Returns number of rows, depending on orientation: myColumnCount or size of values container
|
|
//! \param theParent an index of the parent item
|
|
//! \return an integer value
|
|
Standard_EXPORT virtual int RowCount (const QModelIndex& theParent = QModelIndex()) const;
|
|
|
|
//! Returns content of the model index for the given role, it is obtained from internal container of values
|
|
//! It returns value only for DisplayRole.
|
|
//! \param theRow a model index row
|
|
//! \param theColumn a model index column
|
|
//! \param theRole a view role
|
|
//! \return value intepreted depending on the given role
|
|
Standard_EXPORT virtual QVariant Data (const int theRow, const int theColumn, int theRole = Qt::DisplayRole) const;
|
|
|
|
//! Sets content of the model index for the given role, it is applied to internal container of values
|
|
//! \param theRow a model index row
|
|
//! \param theColumn a model index column
|
|
//! \param theRole a view role
|
|
//! \return true if the value is changed
|
|
Standard_EXPORT virtual bool SetData (const int theRow, const int theColumn, const QVariant& theValue,
|
|
int theRole = Qt::DisplayRole);
|
|
|
|
//! Returns content of the model index for the given role, it is obtainer from internal container of header values
|
|
//! It returns value only for DisplayRole.
|
|
//! \param theSection an index of value in the container
|
|
//! \param theIndex a model index
|
|
//! \param theRole a view role
|
|
//! \return value intepreted depending on the given role
|
|
Standard_EXPORT virtual QVariant HeaderData (int theSection, Qt::Orientation theOrientation, int theRole = Qt::DisplayRole) const;
|
|
|
|
//! Returns flags for the item: ItemIsEnabled | Qt::ItemIsSelectable
|
|
//! \param theIndex a model index
|
|
//! \return flags
|
|
Standard_EXPORT virtual Qt::ItemFlags Flags (const QModelIndex& theIndex) const;
|
|
|
|
//! Returns type of edit control for the model index. By default, it is an empty control
|
|
//! \param theRow a model index row
|
|
//! \param theColumn a model index column
|
|
//! \return edit type
|
|
Standard_EXPORT virtual ViewControl_EditType EditType (const int theRow, const int theColumn) const;
|
|
|
|
//! Returns default color for editable cell
|
|
//! \return color value
|
|
static QColor EditCellColor() { return QColor (Qt::darkBlue); }
|
|
|
|
protected:
|
|
//! Returns true if the header item is italic of the parameter index
|
|
//! \param theRow a model index row
|
|
//! \param theColumn a model index column
|
|
//! \param boolean value
|
|
bool isItalicHeader (const int theRow, const int theColumn) const;
|
|
|
|
protected:
|
|
|
|
Qt::Orientation myOrientation; //!< orientation how the values should fill the current table view
|
|
QMap<Qt::Orientation, QList<TreeModel_HeaderSection> > myHeaderValues; //!< table header values
|
|
QMap<Qt::Orientation, bool> myVisibleHeader; //!< table header visibility
|
|
QMap<Qt::Orientation, int> myDefaultSectionSize; //!< table section default size
|
|
|
|
Handle(TreeModel_ItemProperties) myProperties; //!< item properties
|
|
};
|
|
|
|
#endif
|