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
105 lines
3.9 KiB
C++
105 lines
3.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_ItemBase_H
|
|
#define DFBrowser_ItemBase_H
|
|
|
|
#include <Standard.hxx>
|
|
#include <TDF_Label.hxx>
|
|
|
|
#include <inspector/TreeModel_ItemBase.hxx>
|
|
|
|
class DFBrowser_ItemBase;
|
|
class DFBrowser_Module;
|
|
typedef QExplicitlySharedDataPointer<DFBrowser_ItemBase> DFBrowser_ItemBasePtr;
|
|
|
|
//! \class DFBrowser_ItemBase
|
|
//! \brief Declaration of the tree model base item.
|
|
//! This item provide method to process a TDF label.
|
|
class DFBrowser_ItemBase : public TreeModel_ItemBase
|
|
{
|
|
public:
|
|
|
|
//! Sets the module to have an access to attribute information
|
|
//! \param theModule a current loaded application module
|
|
void SetModule (DFBrowser_Module* theModule) { myModule = theModule; }
|
|
|
|
//! Resets the cached item values
|
|
Standard_EXPORT virtual void Reset() Standard_OVERRIDE;
|
|
|
|
//! \return true if the current label is not null
|
|
bool HasLabel() const { return !GetLabel().IsNull(); }
|
|
|
|
//! \return the current label
|
|
Standard_EXPORT virtual TDF_Label GetLabel() const;
|
|
|
|
//! \return the current module
|
|
DFBrowser_Module* GetModule() const { return myModule; }
|
|
|
|
//! Changes using of additional information in item. If it does not use additional info,
|
|
//! it will not return extended text in initValue().
|
|
//! \param theValue a new value
|
|
//! \return the previous value
|
|
Standard_EXPORT bool SetUseAdditionalInfo (const bool theValue);
|
|
|
|
//! Returns the data stored under the given role for the current item
|
|
//! \param theIndex the item model index
|
|
//! \param theRole the item model role
|
|
Standard_EXPORT virtual QVariant data (const QModelIndex& theIndex, int theRole) const Standard_OVERRIDE;
|
|
|
|
protected:
|
|
|
|
//! Sets the item label
|
|
//! \param theLabel an object where the child items structure is found
|
|
void setLabel(TDF_Label theLabel) { myLabel = theLabel; }
|
|
|
|
//! Returns if additional information is shown in item for Display and ToolTip values
|
|
//! \return boolean value
|
|
bool useAdditionalInfo() const { return myIsUseAdditionalInfo; }
|
|
|
|
//! Returns sum of label children and attributes
|
|
//! \return rows count
|
|
virtual int initRowCount() const Standard_OVERRIDE;
|
|
|
|
//! Returns label information like text, icon or background(if it contains TDataStd_Name attribute)
|
|
//! \param theItemRole a value role
|
|
//! \return the value
|
|
virtual QVariant initValue (const int theItemRole) const Standard_OVERRIDE;
|
|
|
|
//! Creates a child item in the given position.
|
|
//! \param theRow the child row position
|
|
//! \param theColumn the child column position
|
|
//! \return the created item
|
|
virtual TreeModel_ItemBasePtr createChild (int theRow, int theColumn) Standard_OVERRIDE;
|
|
|
|
//! Initializes the current item. It creates a backup of the specific item information
|
|
virtual void initItem() const {}
|
|
|
|
protected:
|
|
|
|
//! Constructor
|
|
//! \param theParent a parent item
|
|
//! \param theRow the item row position in the parent item
|
|
//! \param theColumn the item column position in the parent item
|
|
DFBrowser_ItemBase (TreeModel_ItemBasePtr theParent, const int theRow, const int theColumn);
|
|
|
|
private:
|
|
|
|
TDF_Label myLabel; //!< a label of the document, which contains child labels and attributes
|
|
DFBrowser_Module* myModule; //!< the current module
|
|
bool myIsUseAdditionalInfo; //!< if true, additional item info is shown in square brackets
|
|
};
|
|
|
|
#endif |