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
122 lines
5.4 KiB
C++
122 lines
5.4 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 DFBrowserPane_AttributePaneModel_H
|
|
#define DFBrowserPane_AttributePaneModel_H
|
|
|
|
#include <Standard.hxx>
|
|
#include <TDocStd_Document.hxx>
|
|
|
|
#include <Standard_WarningsDisable.hxx>
|
|
#include <QAbstractTableModel>
|
|
#include <QList>
|
|
#include <QVariant>
|
|
#include <Standard_WarningsRestore.hxx>
|
|
|
|
//! \class DFBrowserPane_AttributePaneModel
|
|
//! \brief This is an extension of table model to visualize a container of values
|
|
//! It is possible to:
|
|
//! - set orientation to interpretate the values.
|
|
//! - set table view header values.
|
|
//! Items of the view are enabled and selectable.
|
|
class DFBrowserPane_AttributePaneModel : public QAbstractTableModel
|
|
{
|
|
public:
|
|
|
|
//! Constructor
|
|
Standard_EXPORT DFBrowserPane_AttributePaneModel(QObject* theParent = 0);
|
|
|
|
//! Destructor
|
|
virtual ~DFBrowserPane_AttributePaneModel() {}
|
|
|
|
//! 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; }
|
|
|
|
//! Returns table orientation for setting data values
|
|
//! \return thye current orientation
|
|
Qt::Orientation GetOrientation() const { return myOrientation; }
|
|
|
|
//! Sets number of columns
|
|
//! \param theColumnCount a column count
|
|
void SetColumnCount (const int theColumnCount) { myColumnCount = theColumnCount; }
|
|
|
|
//! Fills the model with the values. Store the values in a cache.
|
|
//! \param theValues a container of values
|
|
Standard_EXPORT void Init (const QList<QVariant>& theValues);
|
|
|
|
//! Fills the model header values for orientation.
|
|
//! \param theValues a container of header text values
|
|
//! \param theOrientation an orientation of header
|
|
Standard_EXPORT void SetHeaderValues (const QList<QVariant>& theValues, Qt::Orientation theOrientation);
|
|
|
|
//! Returns header values for orientation.
|
|
//! \param theValues a container of header text values
|
|
//! \param theOrientation an orientation of header
|
|
const QList<QVariant>& HeaderValues (Qt::Orientation theOrientation)
|
|
{ return theOrientation == Qt::Horizontal ? myHorizontalHeaderValues : myVerticalHeaderValues; }
|
|
|
|
//! Returns indices of italic columns
|
|
//! \return indices of columns
|
|
const QList<int>& GetItalicColumns() const { return myItalicColumns; }
|
|
|
|
//! Sets indices of italic columns
|
|
//! \param theValues indices of columns
|
|
void SetItalicColumns (const QList<int>& theValues) { myItalicColumns = theValues; }
|
|
|
|
//! Returns number of columns, 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 columnCount (const QModelIndex& theParent = QModelIndex()) const Standard_OVERRIDE;
|
|
|
|
//! 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 Standard_OVERRIDE;
|
|
|
|
//! 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 theIndex a model index
|
|
//! \param theRole a view role
|
|
//! \return value intepreted depending on the given role
|
|
Standard_EXPORT virtual QVariant data (const QModelIndex& theIndex, int theRole = Qt::DisplayRole) const Standard_OVERRIDE;
|
|
|
|
//! 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 Standard_OVERRIDE;
|
|
|
|
//! Returns flags for the item: ItemIsEnabled | Qt::ItemIsSelectable
|
|
//! \param theIndex a model index
|
|
//! \return flags
|
|
Qt::ItemFlags flags (const QModelIndex& theIndex) const
|
|
{ return theIndex.isValid() ? Qt::ItemIsEnabled | Qt::ItemIsSelectable : Qt::NoItemFlags; }
|
|
|
|
private:
|
|
|
|
Qt::Orientation myOrientation; //!< orientation how the values should fill the current table view
|
|
int myColumnCount; //!< number of table columns
|
|
QMap< int, QList<QVariant> > myValuesMap; //!< container of values, filled in Init(), used in data()
|
|
QList<QVariant> myHorizontalHeaderValues; //!< table horizontal header values
|
|
QList<QVariant> myVerticalHeaderValues; //!< table vertical header values
|
|
QList<int> myItalicColumns; //!< indices of columns that should be visualized in gray and italic
|
|
|
|
};
|
|
|
|
#endif
|