mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-04 18:06:22 +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
121 lines
4.9 KiB
C++
121 lines
4.9 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_SearchLineModel_H
|
|
#define DFBrowser_SearchLineModel_H
|
|
|
|
#include <inspector/DFBrowser_SearchItemInfo.hxx>
|
|
#include <inspector/TreeModel_ItemBase.hxx>
|
|
|
|
#include <Standard.hxx>
|
|
#include <TDF_Attribute.hxx>
|
|
#include <TDF_Label.hxx>
|
|
|
|
#include <Standard_WarningsDisable.hxx>
|
|
#include <QAbstractTableModel>
|
|
#include <QMap>
|
|
#include <QStringList>
|
|
#include <QVariant>
|
|
#include <Standard_WarningsRestore.hxx>
|
|
|
|
class QObject;
|
|
class DFBrowser_Module;
|
|
|
|
//! \class DFBrowser_SearchLineModel
|
|
//! Table view model filled by OCAF labels and attributes. It contain information in the next form:
|
|
//! <document index> into <document values container>
|
|
//! <document values container> is key(attribute name or label entry) into item information
|
|
//! The model contains 3 columns:
|
|
//! - 0: information text
|
|
//! - 1: icon size is [80, 80]
|
|
//! - 2: information text that contains united path
|
|
class DFBrowser_SearchLineModel : public QAbstractTableModel
|
|
{
|
|
public:
|
|
|
|
//! Constructor
|
|
Standard_EXPORT DFBrowser_SearchLineModel (QObject* theParent, DFBrowser_Module* theModule);
|
|
|
|
//! Destructor
|
|
virtual ~DFBrowser_SearchLineModel() {}
|
|
|
|
//! Separator as attribute name is divided from the label entry in information text
|
|
static QString SplitSeparator() { return ": "; }
|
|
|
|
//! Returns the current module
|
|
DFBrowser_Module* GetModule() const { return myModule; }
|
|
|
|
//! Fills internal containers by the OCAF values. Updates number of rows value
|
|
//! \param theDocumentValues container of document index to container of entry/attribute name to item information
|
|
//! \param theDocumentInfoValues container of a document index to entry/attribute name
|
|
Standard_EXPORT void SetValues (const QMap<int, QMap<QString, DFBrowser_SearchItemInfo > >& theDocumentValues,
|
|
const QMap<int, QStringList>& theDocumentInfoValues);
|
|
|
|
//! Clears cache of values
|
|
Standard_EXPORT void ClearValues();
|
|
|
|
//! Returns path to attribute or label element of OCAF by the index.
|
|
//! \param theIndex a tree model index
|
|
Standard_EXPORT QStringList GetPath (const QModelIndex& theIndex) const;
|
|
|
|
//! Returns value(attribute name or label entry) of OCAF by the index
|
|
Standard_EXPORT QString GetValue (const QModelIndex& theIndex) const;
|
|
|
|
//! Emits the layoutChanged signal from outside of this class
|
|
Standard_EXPORT void EmitLayoutChanged();
|
|
|
|
//! Creates new model index
|
|
//! \param theRow the index row position
|
|
//! \param theColummn the index column position
|
|
//! \param theParent the parent index
|
|
//! \return the model index
|
|
Standard_EXPORT virtual QModelIndex index (int theRow, int theColumn,
|
|
const QModelIndex& theParent = QModelIndex()) const Standard_OVERRIDE;
|
|
|
|
//! Returns the data stored under the given role for the item referred to by the index.
|
|
//! \param theIndex a model index
|
|
//! \param theRole an enumeration value of role for data obtaining
|
|
Standard_EXPORT virtual QVariant data (const QModelIndex& theIndex,
|
|
int theRole = Qt::DisplayRole) const Standard_OVERRIDE;
|
|
//! Returns the number of rows under the given parent.
|
|
//! \param theParent a parent model index
|
|
//! \return the number of rows
|
|
|
|
virtual int rowCount (const QModelIndex& theParent = QModelIndex()) const Standard_OVERRIDE
|
|
{ (void)theParent; return myRowCount; }
|
|
|
|
//! Returns the number of columns for the children of the given parent.
|
|
//! \param theParent a parent model index
|
|
//! \return the number of columns
|
|
virtual int columnCount (const QModelIndex& theParent = QModelIndex()) const Standard_OVERRIDE
|
|
{ (void)theParent; return 3; }
|
|
|
|
protected:
|
|
|
|
//! Returns document index by a row index in table model
|
|
//! \param theRow a row index of a QModelIndex
|
|
//! \param theRowInDocument an output index, to obtain information from myDocumentInfoValues
|
|
int getDocumentId (const int theRow, int& theRowInDocument) const;
|
|
|
|
private:
|
|
|
|
DFBrowser_Module* myModule; //!< the current module
|
|
//! a document index to container of entry/attribute name to item information
|
|
QMap<int, QMap<QString, DFBrowser_SearchItemInfo> > myAdditionalValues;
|
|
QMap<int, QStringList> myDocumentInfoValues; //!< a document index to entry/attribute name
|
|
int myRowCount; //!< number of rows in the model: summ of row counts in all documents
|
|
};
|
|
#endif
|