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
117 lines
4.8 KiB
C++
117 lines
4.8 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 TreeModel_Tools_H
|
|
#define TreeModel_Tools_H
|
|
|
|
#include <Standard.hxx>
|
|
#include <Standard_Macro.hxx>
|
|
|
|
#include <Standard_WarningsDisable.hxx>
|
|
#include <QApplication>
|
|
#include <QByteArray>
|
|
#include <QColor>
|
|
#include <QMap>
|
|
#include <QModelIndex>
|
|
#include <QString>
|
|
#include <QStyle>
|
|
#include <Standard_WarningsRestore.hxx>
|
|
|
|
class QAction;
|
|
class QObject;
|
|
class QTreeView;
|
|
|
|
//! \class TreeModel_Tools
|
|
//! \brief The tool that gives auxiliary methods for qt elements manipulation
|
|
class TreeModel_Tools
|
|
{
|
|
public:
|
|
|
|
//! Converts a Qt string to byte array, string has mask: @ByteArray[...]
|
|
//! \param theValue a converted string
|
|
//! \return the extended filled array
|
|
Standard_EXPORT static QString ToString (const QByteArray& theValue);
|
|
|
|
//! Converts a Qt byte array to Qt string. It has mask: @ByteArray[...]
|
|
//! \param theValue a converted string
|
|
//! \return the extended filled array
|
|
Standard_EXPORT static QByteArray ToByteArray (const QString& theValue);
|
|
|
|
//! Returns header margin, defined in style settings of application
|
|
//! \return integer value
|
|
static int HeaderSectionMargin() { return qApp->style()->pixelMetric (QStyle::PM_HeaderMargin); }
|
|
|
|
//! Saves state of tree view in a container in form: key, value. It saves:
|
|
//! - visibility of columns,
|
|
//! - columns width
|
|
//! \param theTreeView a view instance
|
|
//! \param theItems [out] properties
|
|
//! \param thePrefix peference item prefix
|
|
Standard_EXPORT static void SaveState (QTreeView* theTreeView, QMap<QString, QString>& theItems,
|
|
const QString& thePrefix = QString());
|
|
|
|
//! Restores state of tree view by a container
|
|
//! \param theTreeView a view instance
|
|
//! \param theKey property key
|
|
//! \param theValue property value
|
|
//! \param thePrefix peference item prefix
|
|
//! \return boolean value whether the property is applied to the tree view
|
|
Standard_EXPORT static bool RestoreState (QTreeView* theTreeView, const QString& theKey, const QString& theValue,
|
|
const QString& thePrefix = QString());
|
|
|
|
//! Fills tree view by default sections parameters obtained in view's tree model
|
|
//! \param theTreeView tree view instance
|
|
Standard_EXPORT static void SetDefaultHeaderSections (QTreeView* theTreeView);
|
|
|
|
//! Sets using visibility column in the tree view:
|
|
//! - sets the state in the TreeModel
|
|
//! - set section width, not resizable
|
|
//! \param theTreeView a view instance
|
|
//! \param theActive boolean value if the column should be connected/visible and other
|
|
Standard_EXPORT static void UseVisibilityColumn (QTreeView* theTreeView, const bool theActive = true);
|
|
|
|
//! Returns the text width
|
|
//! \param theText source text
|
|
//! \param theParent parent widget with its own style
|
|
//! \return calculated width value
|
|
Standard_EXPORT static int GetTextWidth (const QString& theText, QObject* theParent);
|
|
|
|
//! Returns string cut by width and '\n'
|
|
//! \param theText processing string
|
|
//! \param theWidth width value, if -1, default value is used
|
|
//! \param theTail symbols added to the end of the cut string
|
|
Standard_EXPORT static QString CutString (const QString& theText, const int theWidth = -1, const QString& theTail = "...");
|
|
|
|
//! Returns light highlight color
|
|
//! \returns Qt color
|
|
Standard_EXPORT static QColor LightHighlightColor();
|
|
|
|
//! Makes the view expanded from the root till the index
|
|
Standard_EXPORT static void SetExpandedTo (QTreeView* theTreeView, const QModelIndex& theIndex);
|
|
|
|
//! Expands items in tree view staring from the index recursive in given number of levels
|
|
//! \param theTreeView an OCAF tree view
|
|
//! \param theParentIndex an index which children should be expanded
|
|
//! \param isExpanded a boolean state if the item should be expanded or collapsed
|
|
//! \param theLevels a number of levels to be expanded, or -1 for all levels
|
|
Standard_EXPORT static void SetExpanded (QTreeView* theTreeView,
|
|
const QModelIndex& theIndex,
|
|
const bool isExpanded,
|
|
int& theLevels);
|
|
|
|
};
|
|
|
|
#endif
|