mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-03 17:56:21 +03:00
Update empty method guards to new style with regex (see PR). Used clang-format 18.1.8. New actions to validate code formatting is added. Update .clang-format with disabling of include sorting. It is temporary changes, then include will be sorted. Apply formatting for /src and /tools folder. The files with .hxx,.cxx,.lxx,.h,.pxx,.hpp,*.cpp extensions.
121 lines
5.1 KiB
C++
121 lines
5.1 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[out] theItems properties
|
|
//! \param thePrefix preference 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 preference 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
|