-// Created on: 2020-01-25
+// Created on: 2017-06-16
// Created by: Natalia ERMOLAEVA
-// Copyright (c) 2020 OPEN CASCADE SAS
+// Copyright (c) 2017 OPEN CASCADE SAS
//
// This file is part of Open CASCADE Technology software library.
//
#include <AIS_Plane.hxx>
#include <AIS_Shape.hxx>
-#include <BRep_Builder.hxx>
-#include <BRepBuilderAPI_MakeEdge.hxx>
-#include <BRepBuilderAPI_MakeVertex.hxx>
-#include <BRepPreviewAPI_MakeBox.hxx>
-#include <BRepTools.hxx>
#include <gp_XY.hxx>
#include <Geom_Plane.hxx>
#include <Prs3d_PlaneAspect.hxx>
-#include <Standard_Dump.hxx>
#include <TColgp_Array1OfPnt.hxx>
+#include <Standard_Dump.hxx>
+#include <BRepTools.hxx>
+#include <BRep_Builder.hxx>
#include <TopoDS_Compound.hxx>
+#include <BRepPrimAPI_MakeBox.hxx>
+#include <BRepBuilderAPI_MakeEdge.hxx>
+#include <BRepBuilderAPI_MakeVertex.hxx>
// =======================================================================
// function : ReadShape
}
//=======================================================================
-//function : ConvertStreamToPresentations
+//function : CreateShape
//purpose :
//=======================================================================
void Convert_Tools::ConvertStreamToPresentations (const Standard_SStream& theSStream,
//=======================================================================
Standard_Boolean Convert_Tools::CreateBoxShape (const gp_Pnt& thePntMin, const gp_Pnt& thePntMax, TopoDS_Shape& theShape)
{
- BRepPreviewAPI_MakeBox aMakeBox;
- aMakeBox.Init (thePntMin, thePntMax);
- theShape = aMakeBox.Shape();
+ Standard_Boolean aThinOnX = fabs (thePntMin.X() - thePntMax.X()) < Precision::Confusion();
+ Standard_Boolean aThinOnY = fabs (thePntMin.Y() - thePntMax.Y()) < Precision::Confusion();
+ Standard_Boolean aThinOnZ = fabs (thePntMin.Z() - thePntMax.Z()) < Precision::Confusion();
- return Standard_True;
+ if (((int)aThinOnX + (int)aThinOnY + (int)aThinOnZ) > 1) // thin box in several directions is a point
+ {
+ BRep_Builder aBuilder;
+ TopoDS_Compound aCompound;
+ aBuilder.MakeCompound (aCompound);
+ aBuilder.Add (aCompound, BRepBuilderAPI_MakeVertex (thePntMin));
+ theShape = aCompound;
+ return Standard_True;
+ }
+
+ if (aThinOnX || aThinOnY || aThinOnZ)
+ {
+ gp_Pnt aPnt1, aPnt2, aPnt3, aPnt4 ;
+ if (aThinOnX)
+ {
+ aPnt1 = gp_Pnt(thePntMin.X(), thePntMin.Y(), thePntMin.Z());
+ aPnt2 = gp_Pnt(thePntMin.X(), thePntMax.Y(), thePntMin.Z());
+ aPnt3 = gp_Pnt(thePntMin.X(), thePntMax.Y(), thePntMax.Z());
+ aPnt4 = gp_Pnt(thePntMin.X(), thePntMin.Y(), thePntMax.Z());
+ }
+ else if (aThinOnY)
+ {
+ aPnt1 = gp_Pnt(thePntMin.X(), thePntMin.Y(), thePntMin.Z());
+ aPnt2 = gp_Pnt(thePntMax.X(), thePntMin.Y(), thePntMin.Z());
+ aPnt3 = gp_Pnt(thePntMax.X(), thePntMin.Y(), thePntMax.Z());
+ aPnt4 = gp_Pnt(thePntMin.X(), thePntMin.Y(), thePntMax.Z());
+ }
+ else if (aThinOnZ)
+ {
+ aPnt1 = gp_Pnt(thePntMin.X(), thePntMin.Y(), thePntMin.Z());
+ aPnt2 = gp_Pnt(thePntMax.X(), thePntMin.Y(), thePntMin.Z());
+ aPnt3 = gp_Pnt(thePntMax.X(), thePntMax.Y(), thePntMin.Z());
+ aPnt4 = gp_Pnt(thePntMin.X(), thePntMax.Y(), thePntMin.Z());
+ }
+ BRep_Builder aBuilder;
+ TopoDS_Compound aCompound;
+ aBuilder.MakeCompound (aCompound);
+ aBuilder.Add (aCompound, BRepBuilderAPI_MakeEdge (aPnt1, aPnt2));
+ aBuilder.Add (aCompound, BRepBuilderAPI_MakeEdge (aPnt2, aPnt3));
+ aBuilder.Add (aCompound, BRepBuilderAPI_MakeEdge (aPnt3, aPnt4));
+ aBuilder.Add (aCompound, BRepBuilderAPI_MakeEdge (aPnt4, aPnt1));
+
+ theShape = aCompound;
+ return Standard_True;
+ }
+ else
+ {
+ BRepPrimAPI_MakeBox aBoxBuilder (thePntMin, thePntMax);
+ theShape = aBoxBuilder.Shape();
+ return Standard_True;
+ }
}
//=======================================================================
{
Handle(AIS_Plane) aPlanePrs = new AIS_Plane (thePlane);
+ // TODO - default fields to be defined in another place
aPlanePrs->Attributes()->SetPlaneAspect (new Prs3d_PlaneAspect());
Handle (Prs3d_PlaneAspect) aPlaneAspect = aPlanePrs->Attributes()->PlaneAspect();
aPlaneAspect->SetPlaneLength (100, 100);
return;
Handle(AIS_Shape) aSourcePrs = new AIS_Shape (aBoxShape);
+ // TODO - default fields to be defined in another place
aSourcePrs->SetColor (Quantity_NOC_WHITE);
aSourcePrs->SetTransparency (0.5);
thePresentations.Append (aSourcePrs);
Handle(AIS_Shape) aTransformedPrs = new AIS_Shape (aBoxShape);
+ // TODO - default fields to be defined in another place
aTransformedPrs->SetColor (Quantity_NOC_TOMATO);
aTransformedPrs->SetTransparency (0.5);
aTransformedPrs->SetLocalTransformation (theTrsf);
-// Created on: 2020-01-25
+// Created on: 2017-06-16
// Created by: Natalia ERMOLAEVA
-// Copyright (c) 2020 OPEN CASCADE SAS
+// Copyright (c) 2017 OPEN CASCADE SAS
//
// This file is part of Open CASCADE Technology software library.
//
class Geom_Transformation;
//! \class Convert_Tools
-//! \brief The tool that gives auxiliary methods for qt elements manipulation.
+//! \brief The tool that gives auxiliary methods for qt elements manipulation
class Convert_Tools
{
public:
//! \param thePntMin minimum point on the bounding box
//! \param thePntMax maximum point on the bounding box
//! \return created shape
- Standard_EXPORT static Standard_Boolean CreateBoxShape (const gp_Pnt& thePntMin,
- const gp_Pnt& thePntMax,
- TopoDS_Shape& theShape);
+ Standard_EXPORT static Standard_Boolean CreateBoxShape (const gp_Pnt& thePntMin, const gp_Pnt& thePntMax, TopoDS_Shape& theShape);
//! Creates presentation AIS_Plane
//! \param thePlane source plane
<!DOCTYPE RCC><RCC version="1.0">
<qresource>
+ <file>icons/attribute.png</file>
+ <file>icons/attribute_40x40.png</file>
+ <file>icons/export_shape.png</file>
+ <file>icons/folder_export.png</file>
<file>icons/item_type_folder.png</file>
<file>icons/item_type_folder_40x40.png</file>
<file>icons/level_change.png</file>
+ <file>icons/named_shape.png</file>
+ <file>icons/named_shape_40x40.png</file>
<file>icons/search.png</file>
<file>icons/search_cancel.png</file>
<file>icons/treeline_backward.png</file>
// =======================================================================
void DFBrowser_TreeModel::InitColumns()
{
- SetHeaderItem (0, TreeModel_HeaderSection ("Name"));
+ setHeaderItem (0, TreeModel_HeaderSection ("Name"));
}
// =======================================================================
+++ /dev/null
-<!DOCTYPE RCC><RCC version="1.0">
- <qresource>
- <file>icons/attribute.png</file>
- <file>icons/attribute_40x40.png</file>
- <file>icons/export_shape.png</file>
- <file>icons/folder_export.png</file>
- <file>icons/label.png</file>
- <file>icons/label_folder_16x16.png</file>
- <file>icons/label_folder_40x40.png</file>
- <file>icons/named_shape.png</file>
- <file>icons/named_shape_40x40.png</file>
- </qresource>
-</RCC>
// =======================================================================
void DFBrowserPane_TDataStdTreeNodeModel::InitColumns()
{
- SetHeaderItem (0, TreeModel_HeaderSection ("Name"));
+ setHeaderItem (0, TreeModel_HeaderSection ("Name"));
}
// =======================================================================
-DFBrowserPane.qrc
DFBrowserPane_AttributePane.cxx
DFBrowserPane_AttributePane.hxx
DFBrowserPane_AttributePaneAPI.hxx
--- /dev/null
+MessageModel.qrc
+MessageModel_Actions.cxx
+MessageModel_Actions.hxx
+MessageModel_ActionType.hxx
+MessageModel_ItemAlert.cxx
+MessageModel_ItemAlert.hxx
+MessageModel_ItemBase.cxx
+MessageModel_ItemBase.hxx
+MessageModel_ItemReport.cxx
+MessageModel_ItemReport.hxx
+MessageModel_ItemRoot.cxx
+MessageModel_ItemRoot.hxx
+MessageModel_Tools.cxx
+MessageModel_Tools.hxx
+MessageModel_TreeModel.cxx
+MessageModel_TreeModel.hxx
--- /dev/null
+<!DOCTYPE RCC><RCC version="1.0">
+ <qresource>
+ <file>icons/item_shape.png</file>
+ <file>icons/item_streamValues.png</file>
+ </qresource>
+</RCC>
--- /dev/null
+// 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 MessageModel_ActionType_H
+#define MessageModel_ActionType_H
+
+//! Kind of action type for tree view context menu item
+enum MessageModel_ActionType
+{
+ MessageModel_ActionType_Activate, //!< set Message_Report active
+ MessageModel_ActionType_Deactivate, //!< set Message_Report not active
+ MessageModel_ActionType_Clear, //!< clear Message_Report alerts
+ MessageModel_ActionType_ExportToShapeView, //!< export TopoDS_Shape of selected item into TKShapeView plugin
+ MessageModel_ActionType_TestMetric, //!< test alerts
+ MessageModel_ActionType_TestProperties, //!< test alerts
+ MessageModel_ActionType_TestMessenger, //!< test message view on messenger printer to report
+ MessageModel_ActionType_TestReportTree, //!< test message view on hierarchical report
+ MessageModel_ActionType_TestReportTree2 //!< test message view on hierarchical report
+};
+
+#endif
--- /dev/null
+// 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.
+
+
+#include <inspector/MessageModel_Actions.hxx>
+
+#include <inspector/MessageModel_ItemReport.hxx>
+#include <inspector/MessageModel_ItemRoot.hxx>
+#include <inspector/MessageModel_ItemAlert.hxx>
+#include <inspector/MessageModel_Tools.hxx>
+#include <inspector/MessageModel_TreeModel.hxx>
+#include <inspector/TInspectorAPI_PluginParameters.hxx>
+#include <inspector/ViewControl_Tools.hxx>
+
+#include <Message.hxx>
+#include <Message_AlertExtended.hxx>
+#include <Message_Messenger.hxx>
+#include <Message_PrinterToReport.hxx>
+
+#include <BRepBuilderAPI_MakeEdge.hxx>
+#include <OSD_Chronometer.hxx>
+#include <Quantity_Color.hxx>
+#include <Quantity_ColorRGBA.hxx>
+#include <TCollection_AsciiString.hxx>
+#include <TopoDS_AlertAttribute.hxx>
+
+#include <Standard_WarningsDisable.hxx>
+#include <QAction>
+#include <QFileDialog>
+#include <QItemSelectionModel>
+#include <QMenu>
+#include <QMessageBox>
+#include <QWidget>
+#include <Standard_WarningsRestore.hxx>
+
+// =======================================================================
+// function : Constructor
+// purpose :
+// =======================================================================
+MessageModel_Actions::MessageModel_Actions (QWidget* theParent,
+ MessageModel_TreeModel* theTreeModel, QItemSelectionModel* theModel)
+: QObject (theParent), myTreeModel (theTreeModel), mySelectionModel (theModel)
+{
+ myActions.insert (MessageModel_ActionType_Activate,
+ ViewControl_Tools::CreateAction ("Activate", SLOT (OnActivateReport()), parent(), this));
+ myActions.insert (MessageModel_ActionType_Deactivate,
+ ViewControl_Tools::CreateAction ("Deactivate", SLOT (OnDeactivateReport()), parent(), this));
+ myActions.insert (MessageModel_ActionType_Clear,
+ ViewControl_Tools::CreateAction ("Clear", SLOT (OnClearReport()), parent(), this));
+ myActions.insert (MessageModel_ActionType_ExportToShapeView,
+ ViewControl_Tools::CreateAction (tr ("Export to ShapeView"), SLOT (OnExportToShapeView()), parent(), this));
+}
+
+// =======================================================================
+// function : GetAction
+// purpose :
+// =======================================================================
+QAction* MessageModel_Actions::GetAction (const MessageModel_ActionType& theType)
+{
+ if (myActions.contains (theType))
+ return myActions[theType];
+
+ return 0;
+}
+
+// =======================================================================
+// function : AddMenuActions
+// purpose :
+// =======================================================================
+void MessageModel_Actions::AddMenuActions (const QModelIndexList& theSelectedIndices, QMenu* theMenu)
+{
+ MessageModel_ItemRootPtr aRootItem;
+ MessageModel_ItemReportPtr aReportItem;
+ MessageModel_ItemAlertPtr anAlertItem;
+ for (QModelIndexList::const_iterator aSelIt = theSelectedIndices.begin(); aSelIt != theSelectedIndices.end(); aSelIt++)
+ {
+ QModelIndex anIndex = *aSelIt;
+ if (anIndex.column() != 0)
+ continue;
+
+ TreeModel_ItemBasePtr anItemBase = TreeModel_ModelBase::GetItemByIndex (anIndex);
+ if (!anItemBase)
+ continue;
+
+ aRootItem = itemDynamicCast<MessageModel_ItemRoot> (anItemBase);
+ if (aRootItem)
+ break;
+
+ aReportItem = itemDynamicCast<MessageModel_ItemReport> (anItemBase);
+ if (aReportItem)
+ break;
+
+ anAlertItem = itemDynamicCast<MessageModel_ItemAlert> (anItemBase);
+ if (anAlertItem)
+ break;
+ }
+
+ if (aReportItem && !aReportItem->GetReport().IsNull())
+ {
+ theMenu->addAction (myActions[MessageModel_ActionType_Deactivate]);
+ theMenu->addAction (myActions[MessageModel_ActionType_Activate]);
+ theMenu->addAction (myActions[MessageModel_ActionType_Clear]);
+ }
+ else if (anAlertItem)
+ {
+ theMenu->addAction (myActions[MessageModel_ActionType_ExportToShapeView]);
+ }
+
+ theMenu->addSeparator();
+}
+
+// =======================================================================
+// function : getSelectedReport
+// purpose :
+// =======================================================================
+Handle(Message_Report) MessageModel_Actions::getSelectedReport (QModelIndex& theReportIndex) const
+{
+ MessageModel_ItemReportPtr aReportItem;
+ QModelIndexList aSelectedIndices = mySelectionModel->selectedIndexes();
+ for (QModelIndexList::const_iterator aSelIt = aSelectedIndices.begin(); aSelIt != aSelectedIndices.end(); aSelIt++)
+ {
+ QModelIndex anIndex = *aSelIt;
+ if (anIndex.column() != 0)
+ continue;
+
+ TreeModel_ItemBasePtr anItemBase = TreeModel_ModelBase::GetItemByIndex (anIndex);
+ if (!anItemBase)
+ continue;
+
+ aReportItem = itemDynamicCast<MessageModel_ItemReport> (anItemBase);
+ theReportIndex = anIndex;
+ if (aReportItem)
+ break;
+ }
+ if (!aReportItem)
+ return NULL;
+
+ return aReportItem->GetReport();
+}
+
+// =======================================================================
+// function : OnActivateReport
+// purpose :
+// =======================================================================
+static Handle(Message_PrinterToReport) MyPrinterToReport;
+static Message_SequenceOfPrinters MyDeactivatedPrinters;
+
+void MessageModel_Actions::OnActivateReport()
+{
+ if (MyPrinterToReport.IsNull())
+ MyPrinterToReport = new Message_PrinterToReport();
+
+ if (MyPrinterToReport->Report()->IsActiveInMessenger())
+ return;
+
+ MyDeactivatedPrinters = Message::DefaultMessenger()->Printers();
+ Message::DefaultMessenger()->ChangePrinters().Clear();
+
+ Message::DefaultMessenger()->AddPrinter (MyPrinterToReport);
+ Message::DefaultMessenger()->SetTraceLevel (1);
+ Message::DefaultReport()->UpdateActiveInMessenger();
+
+ myTreeModel->UpdateTreeModel();
+}
+
+// =======================================================================
+// function : OnDeactivateReport
+// purpose :
+// =======================================================================
+void MessageModel_Actions::OnDeactivateReport()
+{
+ if (MyPrinterToReport.IsNull() || !MyPrinterToReport->Report()->IsActiveInMessenger())
+ return;
+
+ Message::DefaultMessenger()->RemovePrinter (MyPrinterToReport);
+ Message::DefaultMessenger()->ChangePrinters().Assign (MyDeactivatedPrinters);
+
+ myTreeModel->UpdateTreeModel();
+}
+
+// =======================================================================
+// function : OnClearReport
+// purpose :
+// =======================================================================
+void MessageModel_Actions::OnClearReport()
+{
+ QModelIndex aReportIndex;
+ Handle(Message_Report) aReport = getSelectedReport (aReportIndex);
+ if (aReport.IsNull())
+ return;
+
+ aReport->Clear();
+ myTreeModel->UpdateTreeModel();
+}
+
+// =======================================================================
+// function : OnExportToShapeView
+// purpose :
+// =======================================================================
+void MessageModel_Actions::OnExportToShapeView()
+{
+ TCollection_AsciiString aPluginName ("TKShapeView");
+
+ NCollection_List<Handle(Standard_Transient)> aPluginParameters;
+ if (myParameters->FindParameters (aPluginName))
+ aPluginParameters = myParameters->Parameters (aPluginName);
+ NCollection_List<TCollection_AsciiString> anItemNames;
+ if (myParameters->FindSelectedNames (aPluginName))
+ anItemNames = myParameters->GetSelectedNames (aPluginName);
+
+ QModelIndexList aSelectedIndices = mySelectionModel->selectedIndexes();
+ QStringList anExportedPointers;
+ for (QModelIndexList::const_iterator aSelIt = aSelectedIndices.begin(); aSelIt != aSelectedIndices.end(); aSelIt++)
+ {
+ QModelIndex anIndex = *aSelIt;
+ if (anIndex.column() != 0)
+ continue;
+
+ TreeModel_ItemBasePtr anItemBase = TreeModel_ModelBase::GetItemByIndex (anIndex);
+ if (!anItemBase)
+ continue;
+
+ MessageModel_ItemAlertPtr anAlertItem = itemDynamicCast<MessageModel_ItemAlert> (anItemBase);
+ if (!anAlertItem)
+ continue;
+
+ Handle(Message_Alert) anAlert = anAlertItem->GetAlert();
+ if (anAlert.IsNull())
+ continue;
+
+ Handle(Message_AlertExtended) anExtAlert = Handle(Message_AlertExtended)::DownCast (anAlert);
+ if (anExtAlert.IsNull())
+ continue;
+
+ Handle(Message_Attribute) anAttribute = anExtAlert->Attribute();
+ if (anAttribute.IsNull())
+ continue;
+
+ if (!anAttribute->IsKind (STANDARD_TYPE (TopoDS_AlertAttribute)))
+ continue;
+
+ const TopoDS_Shape aShape = Handle(TopoDS_AlertAttribute)::DownCast (anAttribute)->GetShape();
+ if (aShape.IsNull())
+ continue;
+ aPluginParameters.Append (aShape.TShape());
+ anItemNames.Append (TInspectorAPI_PluginParameters::ParametersToString (aShape));
+
+ anExportedPointers.append (MessageModel_Tools::GetPointerInfo (aShape.TShape(), true).ToCString());
+ }
+
+ if (anExportedPointers.empty())
+ return;
+ myParameters->SetSelectedNames (aPluginName, anItemNames);
+ myParameters->SetParameters (aPluginName, aPluginParameters);
+ QMessageBox::information (0, "Information", QString ("TShapes '%1' are sent to %2 tool.")
+ .arg (anExportedPointers.join (", ")).arg (QString (aPluginName.ToCString())));
+}
--- /dev/null
+// 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 MessageModel_Actions_H
+#define MessageModel_Actions_H
+
+#include <Standard.hxx>
+#include <Standard_Transient.hxx>
+
+#include <inspector/MessageModel_ActionType.hxx>
+#include <inspector/TInspectorAPI_PluginParameters.hxx>
+
+#include <Standard_WarningsDisable.hxx>
+#include <QObject>
+#include <QMap>
+#include <QModelIndexList>
+#include <QPoint>
+#include <QString>
+#include <Standard_WarningsRestore.hxx>
+
+class Message_Report;
+class MessageModel_TreeModel;
+
+class QAction;
+class QItemSelectionModel;
+class QMenu;
+class QWidget;
+
+//! \class MessageModel_Actions
+//! \brief This is a listener of popup context menu items and selection change in message model
+class MessageModel_Actions : public QObject
+{
+ Q_OBJECT
+
+public:
+
+ //! Constructor
+ Standard_EXPORT MessageModel_Actions (QWidget* theParent,
+ MessageModel_TreeModel* theTreeModel,
+ QItemSelectionModel* theModel);
+
+ //! Destructor
+ virtual ~MessageModel_Actions() Standard_OVERRIDE {}
+
+ //! Returns action by the type
+ //! \param theType an action type
+ //! \return an action instance if it exists
+ Standard_EXPORT QAction* GetAction (const MessageModel_ActionType& theType);
+
+ //! Fills popup menu with actions depending on the current selection
+ //! \param theSelectedIndices tree model selected indices
+ //! \param theMenu menu to be filled
+ Standard_EXPORT void AddMenuActions (const QModelIndexList& theSelectedIndices, QMenu* theMenu);
+
+ //! Sets parameters container, it should be used when the plugin is initialized or in update content
+ //! \param theParameters a parameters container
+ void SetParameters (const Handle(TInspectorAPI_PluginParameters)& theParameters)
+ { myParameters = theParameters; }
+
+public slots:
+ //! Set selected report active
+ void OnActivateReport();
+
+ //! Set selected report not active
+ void OnDeactivateReport();
+
+ //! Clears container of alerts of selected report
+ void OnClearReport();
+
+ //! Exports the first selected shape into ShapeViewer plugin.
+ void OnExportToShapeView();
+
+protected:
+ //! Returns report of selected tree view item if a report item is selected
+ //! \param theReportIndex tree model index of the found report
+ //! \return report instance or NULL
+ Handle(Message_Report) getSelectedReport (QModelIndex& theReportIndex) const;
+
+protected:
+ MessageModel_TreeModel* myTreeModel; //< tree model
+ QItemSelectionModel* mySelectionModel; //< selection model
+ Handle(TInspectorAPI_PluginParameters) myParameters; //!< plugins parameters container
+ QMap<MessageModel_ActionType, QAction*> myActions; //!< container of all actions
+};
+
+#endif
--- /dev/null
+// 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.
+
+#include <inspector/MessageModel_ItemAlert.hxx>
+
+#include <inspector/MessageModel_ItemRoot.hxx>
+#include <inspector/MessageModel_ItemReport.hxx>
+#include <inspector/MessageModel_Tools.hxx>
+#include <inspector/MessageModel_TreeModel.hxx>
+
+#include <inspector/ViewControl_Tools.hxx>
+#include <inspector/Convert_TransientShape.hxx>
+#include <inspector/TreeModel_ItemProperties.hxx>
+#include <inspector/TreeModel_Tools.hxx>
+
+#include <Message_AlertExtended.hxx>
+#include <Message_AttributeObject.hxx>
+#include <Message_AttributeMeter.hxx>
+#include <Message_AttributeStream.hxx>
+#include <Message_CompositeAlerts.hxx>
+
+#include <Bnd_Box.hxx>
+#include <Precision.hxx>
+#include <TCollection_AsciiString.hxx>
+#include <TopoDS_AlertAttribute.hxx>
+
+#include <Standard_WarningsDisable.hxx>
+#include <QColor>
+#include <QIcon>
+#include <Standard_WarningsRestore.hxx>
+
+
+// =======================================================================
+// function : initValue
+// purpose :
+// =======================================================================
+QVariant MessageModel_ItemAlert::initValue (const int theRole) const
+{
+ QVariant aParentValue = MessageModel_ItemBase::initValue (theRole);
+ if (aParentValue.isValid())
+ return aParentValue;
+
+ MessageModel_ItemReportPtr aReportItem = MessageModel_ItemReport::FindReportItem (Parent());
+ if (!aReportItem)
+ return QVariant();
+
+ Handle(Message_Report) aReport = aReportItem->GetReport();
+ if (aReport.IsNull())
+ return QVariant();
+
+ if (theRole == Qt::ForegroundRole)
+ {
+ if (!aReport->IsActiveInMessenger())
+ return QColor(Qt::darkGray);
+
+ return QVariant();
+ }
+
+ Handle(Message_Alert) anAlert = getAlert();
+ Handle(Message_AlertExtended) anExtendedAlert = Handle(Message_AlertExtended)::DownCast(anAlert);
+
+ // if the alert is composite, process the real alert
+ if (theRole == Qt::DecorationRole && Column() == 0)
+ {
+ if (anExtendedAlert.IsNull())
+ return QVariant();
+
+ Handle(Message_Attribute) anAttribute = anExtendedAlert->Attribute();
+ if (anAttribute.IsNull())
+ return QVariant();
+
+ if (anAttribute->IsKind (STANDARD_TYPE (TopoDS_AlertAttribute)))
+ return QIcon (":/icons/item_shape.png");
+ else if (!Handle(Message_AttributeStream)::DownCast (anAttribute).IsNull())
+ return QIcon (":/icons/item_streamValues.png");
+ else
+ return QVariant();
+ }
+
+ if (theRole != Qt::DisplayRole && theRole != Qt::ToolTipRole)
+ return QVariant();
+
+ if (anAlert.IsNull())
+ return QVariant();
+
+ if (Column() == 0)
+ {
+ if (theRole == Qt::DisplayRole)
+ {
+ TCollection_AsciiString aMessageKey = anAlert->GetMessageKey();
+ if (aMessageKey.IsEmpty() && !Properties().IsNull())
+ aMessageKey = Properties()->Key();
+ return aMessageKey.ToCString();
+ }
+ else
+ return anAlert->DynamicType()->Name();
+ }
+
+ Message_MetricType aMetricType;
+ int aPosition;
+ if (MessageModel_TreeModel::IsMetricColumn (Column(), aMetricType, aPosition))
+ {
+ if (anExtendedAlert.IsNull())
+ return QVariant();
+
+ Handle(Message_AttributeMeter) anAttribute = Handle(Message_AttributeMeter)::DownCast (anExtendedAlert->Attribute());
+ if (anAttribute.IsNull() || !anAttribute->HasMetric (aMetricType))
+ return QVariant();
+
+ if (!anAttribute->IsMetricValid (aMetricType))
+ return QVariant ("in process");
+
+ if (aMetricType == Message_MetricType_UserTimeCPU ||
+ aMetricType == Message_MetricType_SystemTimeInfo ||
+ aMetricType == Message_MetricType_WallClock)
+ {
+ Standard_Real aCumulativeMetric = anAttribute->StopValue (aMetricType) - anAttribute->StartValue (aMetricType);
+ if (fabs (aCumulativeMetric) < Precision::Confusion())
+ return QVariant();
+
+ if (aPosition == 0) return aCumulativeMetric;
+ else if (aPosition == 1)
+ {
+ Standard_Real aReportCumulativeMetric = MessageModel_ItemReport::CumulativeMetric (aReport, aMetricType);
+ if (fabs (aReportCumulativeMetric) > Precision::Confusion())
+ return 100. * aCumulativeMetric / aReportCumulativeMetric;
+ else
+ return QVariant();
+ }
+ }
+ else
+ {
+ if (aPosition == 0) return anAttribute->StopValue (aMetricType);
+ else if (aPosition == 1)
+ {
+ Standard_Real aCumulativeMetric = anAttribute->StopValue (aMetricType) - anAttribute->StartValue (aMetricType);
+ if (fabs (aCumulativeMetric) < Precision::Confusion())
+ return QVariant();
+ else
+ return aCumulativeMetric;
+ }
+
+ }
+ }
+ return QVariant();
+}
+
+// =======================================================================
+// function : initRowCount
+// purpose :
+// =======================================================================
+int MessageModel_ItemAlert::initRowCount() const
+{
+ const Handle(Message_Alert)& anAlert = getAlert();
+ if (anAlert.IsNull())
+ return 0;
+
+ Handle(Message_AlertExtended) anExtendedAlert = Handle(Message_AlertExtended)::DownCast(anAlert);
+ if (anExtendedAlert.IsNull())
+ return 0;
+
+ Handle(Message_CompositeAlerts) aCompositeAlert = anExtendedAlert->CompositeAlerts();
+ if (aCompositeAlert.IsNull())
+ return 0;
+
+ MessageModel_ItemAlert* aCurrentItem = (MessageModel_ItemAlert*)this;
+ for (int aGravityId = Message_Trace; aGravityId <= Message_Fail; aGravityId++)
+ {
+ const Message_ListOfAlert& anAlerts = aCompositeAlert->Alerts ((Message_Gravity)aGravityId);
+ {
+ for (Message_ListOfAlert::Iterator anIt(anAlerts); anIt.More(); anIt.Next())
+ {
+ Message_ListOfAlert aCurAlerts;
+ aCurAlerts.Append (anIt.Value());
+ aCurrentItem->myChildAlerts.Bind(myChildAlerts.Size(), aCurAlerts);
+ }
+ }
+ }
+
+ return aCurrentItem->myChildAlerts.Size();
+}
+
+// =======================================================================
+// function : initStream
+// purpose :
+// =======================================================================
+void MessageModel_ItemAlert::initStream (Standard_OStream& OS) const
+{
+ Handle(Message_AlertExtended) anExtendedAlert = Handle(Message_AlertExtended)::DownCast (getAlert());
+ if (anExtendedAlert.IsNull() || anExtendedAlert->Attribute().IsNull())
+ return;
+
+ Handle(Message_Attribute) anAttribute = anExtendedAlert->Attribute();
+ if (anAttribute.IsNull())
+ return;
+
+ if (Handle(Message_AttributeStream)::DownCast(anAttribute).IsNull())
+ return;
+
+ Handle(Message_AttributeStream) anAttributeStream = Handle(Message_AttributeStream)::DownCast (anExtendedAlert->Attribute());
+ OS << anAttributeStream->Stream().str();
+}
+
+// =======================================================================
+// function : SetStream
+// purpose :
+// =======================================================================
+bool MessageModel_ItemAlert::SetStream (const Standard_SStream& theSStream, Standard_Integer& theStartPos,
+ Standard_Integer& theLastPos) const
+{
+ Handle(Message_AlertExtended) anExtendedAlert = Handle(Message_AlertExtended)::DownCast (getAlert());
+ if (anExtendedAlert.IsNull() || anExtendedAlert->Attribute().IsNull())
+ return false;
+
+ Handle(Message_Attribute) anAttribute = anExtendedAlert->Attribute();
+ if (anAttribute.IsNull())
+ return false;
+
+ if (Handle(Message_AttributeStream)::DownCast(anAttribute).IsNull())
+ return false;
+
+ Handle(Message_AttributeStream) anAttributeStream = Handle(Message_AttributeStream)::DownCast (anExtendedAlert->Attribute());
+ TCollection_AsciiString aStreamValue = Standard_Dump::Text (anAttributeStream->Stream());
+
+ TCollection_AsciiString aNewValue = Standard_Dump::Text (theSStream);
+
+ Standard_SStream aStream;
+ aStream << aStreamValue.SubString (1, theStartPos - 1);
+ aStream << aNewValue;
+ if (theLastPos + 1 <= aStreamValue.Length())
+ aStream << aStreamValue.SubString (theLastPos + 1, aStreamValue.Length());
+
+ //TCollection_AsciiString aStreamValue_debug = Standard_Dump::Text (aStream);
+
+ anAttributeStream->SetStream (aStream);
+
+ return true;
+}
+
+// =======================================================================
+// function : createChild
+// purpose :
+// =======================================================================
+TreeModel_ItemBasePtr MessageModel_ItemAlert::createChild (int theRow, int theColumn)
+{
+ return MessageModel_ItemAlert::CreateItem (currentItem(), theRow, theColumn);
+}
+
+// =======================================================================
+// function : Init
+// purpose :
+// =======================================================================
+void MessageModel_ItemAlert::Init()
+{
+ MessageModel_ItemReportPtr aReportItem = itemDynamicCast<MessageModel_ItemReport> (Parent());
+ MessageModel_ItemAlertPtr anAlertItem;
+ Handle(Message_Alert) anAlert;
+ if (aReportItem)
+ {
+ Message_ListOfAlert anAlerts;
+ if (aReportItem->GetChildAlerts (Row(), anAlerts))
+ {
+ myAlert = anAlerts.First();
+ }
+ }
+ else
+ {
+ anAlertItem = itemDynamicCast<MessageModel_ItemAlert> (Parent());
+ if (anAlertItem)
+ {
+ Message_ListOfAlert anAlerts;
+ if (anAlertItem->GetChildAlerts (Row(), anAlerts))
+ {
+ myAlert = anAlerts.First();
+ }
+ }
+ }
+
+ Handle(Message_AlertExtended) anExtendedAlert = Handle(Message_AlertExtended)::DownCast(myAlert);
+ if (!anExtendedAlert.IsNull() && !anExtendedAlert->Attribute().IsNull())
+ {
+ Handle(Message_Attribute) anAttribute = anExtendedAlert->Attribute();
+ if (!anAttribute.IsNull())
+ {
+ //if (!Handle(Message_AttributeStream)::DownCast(anAttribute).IsNull())
+ //{
+ // if (GetProperties().IsNull())
+ // {
+ // TreeModel_ItemBasePtr anItem = Parent()->Child (Row(), Column(), false);
+ // SetProperties (new MessageModel_ItemPropertiesAttributeStream (anItem));
+ // }
+ // Handle(Message_AttributeStream) anAttributeStream = Handle(Message_AttributeStream)::DownCast (anExtendedAlert->Attribute());
+ // Handle(MessageModel_ItemPropertiesAttributeStream) aProperties = Handle(MessageModel_ItemPropertiesAttributeStream)::DownCast (GetProperties());
+ // aProperties->Init (anAttributeStream->GetStream());
+ //}
+ ////if (anAttribute->IsKind (STANDARD_TYPE (Message_AttributeObject)))
+ //// myPresentation = Handle(Message_AttributeObject)::DownCast (anAttribute)->GetObject();
+ if (anAttribute->IsKind (STANDARD_TYPE (TopoDS_AlertAttribute)))
+ myPresentation = new Convert_TransientShape (Handle(TopoDS_AlertAttribute)::DownCast (anAttribute)->GetShape());
+ }
+ //TCollection_AsciiString aDescription = anExtendedAlert->Attribute()->GetDescription();
+ //Bnd_Box aBox;
+ //if (aBox.Init (Standard_SStream (aDescription.ToCString())))
+ // myPresentation =new Convert_TransientShape (Convert_Tools::CreateShape (aBox));
+ }
+ MessageModel_ItemBase::Init();
+}
+
+// =======================================================================
+// function : Reset
+// purpose :
+// =======================================================================
+void MessageModel_ItemAlert::Reset()
+{
+ MessageModel_ItemBase::Reset();
+ myAlert = Handle(Message_Alert)();
+ myChildAlerts.Clear();
+ myPresentation = NULL;
+}
+
+// =======================================================================
+// function : initItem
+// purpose :
+// =======================================================================
+void MessageModel_ItemAlert::initItem() const
+{
+ if (IsInitialized())
+ return;
+ const_cast<MessageModel_ItemAlert*>(this)->Init();
+}
+
+// =======================================================================
+// function : getAlert
+// purpose :
+// =======================================================================
+const Handle(Message_Alert)& MessageModel_ItemAlert::getAlert() const
+{
+ initItem();
+ return myAlert;
+}
--- /dev/null
+// 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 MessageModel_ItemAlert_H
+#define MessageModel_ItemAlert_H
+
+#include <inspector/MessageModel_ItemBase.hxx>
+#include <Message_Alert.hxx>
+#include <Message_ListOfAlert.hxx>
+#include <Message_Report.hxx>
+#include <NCollection_DataMap.hxx>
+#include <Standard.hxx>
+#include <TopoDS_Shape.hxx>
+
+#include <Standard_WarningsDisable.hxx>
+#include <QMap>
+#include <QVariant>
+#include <Standard_WarningsRestore.hxx>
+
+#include <NCollection_List.hxx>
+#include <NCollection_Vector.hxx>
+
+class QAbstractTableModel;
+
+class MessageModel_ItemAlert;
+typedef QExplicitlySharedDataPointer<MessageModel_ItemAlert> MessageModel_ItemAlertPtr;
+
+//! \class MessageModel_ItemAlert
+//! This item is connected to Message_Alert.
+//! Parent is either MessageModel_ItemRoot or MessageModel_ItemAlert, children are MessageModel_ItemAlert or no children
+class MessageModel_ItemAlert : public MessageModel_ItemBase
+{
+public:
+
+ //! Creates an item wrapped by a shared pointer
+ //! \param theRow the item row positition in the parent item
+ //! \param theColumn the item column positition in the parent item
+ //! \return the pointer to the created item
+ static MessageModel_ItemAlertPtr CreateItem (TreeModel_ItemBasePtr theParent, const int theRow, const int theColumn)
+ { return MessageModel_ItemAlertPtr (new MessageModel_ItemAlert (theParent, theRow, theColumn)); }
+
+ //! Destructor
+ virtual ~MessageModel_ItemAlert() Standard_OVERRIDE {};
+
+ //! Returns the current shape
+ const Handle(Message_Alert)& GetAlert() const { return myAlert; }
+
+ //! Returns alert of the report for the parameter row
+ Standard_Boolean GetChildAlerts (const int theRow, Message_ListOfAlert& theAlerts) const { return myChildAlerts.Find(theRow, theAlerts); }
+
+ //! Inits the item, fills internal containers
+ Standard_EXPORT virtual void Init() Standard_OVERRIDE;
+
+ //! Resets cached values
+ Standard_EXPORT virtual void Reset() Standard_OVERRIDE;
+
+ //! Return data value for the role.
+ //! \param theRole a value role
+ //! \return the value
+ Standard_EXPORT virtual QVariant initValue (const int theRole) const Standard_OVERRIDE;
+
+ //! \return number of children.
+ Standard_EXPORT virtual int initRowCount() const Standard_OVERRIDE;
+
+ //! Returns stream value of the item to fulfill property panel.
+ //! \return stream value or dummy
+ Standard_EXPORT virtual bool SetStream (const Standard_SStream& theSStream, Standard_Integer& theStartPos,
+ Standard_Integer& theLastPos) const Standard_OVERRIDE;
+
+ //! Sets some shape to present the item
+ //! \param theShape shape instance
+ void SetCustomShape (const TopoDS_Shape& theShape) { myCustomShape = theShape; }
+
+ //! Returns custom shape to present the item
+ //! \return instance of the shape
+ const TopoDS_Shape& GetCustomShape() const { return myCustomShape; }
+
+ //! Returns presentation of the attribute to be visualized in the view
+ //! \param theRow a model index row
+ //! \param theColumn a model index column
+ //! \thePresentations [out] container of presentation handles to be visualized
+ virtual void Presentations (NCollection_List<Handle(Standard_Transient)>& thePresentations) Standard_OVERRIDE
+ { TreeModel_ItemBase::Presentations (thePresentations); thePresentations.Append (myPresentation); }
+
+
+ ////! Returns summ of children alert elapsed times. The method is recusive.
+ ////! \param theAlert a message alert
+ ////! \return double value
+ //Standard_EXPORT static double CumulativeMetric (const Handle(Message_Alert)& theAlert);
+
+protected:
+
+ //! Initialize the current item. It is empty because Reset() is also empty.
+ virtual void initItem() const Standard_OVERRIDE;
+
+ //! Returns stream value of the item to fulfill property panel.
+ //! \return stream value or dummy
+ Standard_EXPORT virtual void initStream (Standard_OStream& OS) 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;
+
+ //! Returns current alert, initialized item if it has not been initialized yet
+ //! \return alert value
+ const Handle(Message_Alert)& getAlert() const;
+
+private:
+
+ //! Constructor
+ MessageModel_ItemAlert (TreeModel_ItemBasePtr theParent, const int theRow, const int theColumn)
+ : MessageModel_ItemBase (theParent, theRow, theColumn) {}
+
+private:
+ Handle(Message_Alert) myAlert;
+
+ NCollection_DataMap<Standard_Integer, Message_ListOfAlert> myChildAlerts; //!< container of child alerts
+
+ TopoDS_Shape myCustomShape;
+ Handle(Standard_Transient) myPresentation;
+};
+
+#endif
--- /dev/null
+// 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.
+
+
+#include <inspector/MessageModel_ItemBase.hxx>
+#include <inspector/MessageModel_ItemRoot.hxx>
+
+// =======================================================================
+// function : isReversed
+// purpose :
+// =======================================================================
+Standard_Boolean MessageModel_ItemBase::isReversed() const
+{
+ TreeModel_ItemBasePtr aParentItem = GetRootItem();
+ MessageModel_ItemRootPtr aRootItem = itemDynamicCast<MessageModel_ItemRoot> (aParentItem);
+ return aRootItem ? aRootItem->IsReversed() : Standard_False;
+}
+
+// =======================================================================
+// function : GetRootItem
+// purpose :
+// =======================================================================
+TreeModel_ItemBasePtr MessageModel_ItemBase::GetRootItem() const
+{
+ TreeModel_ItemBasePtr anItem = Parent();
+ while (anItem)
+ {
+ if (MessageModel_ItemRootPtr aThisRootItem = itemDynamicCast<MessageModel_ItemRoot> (anItem))
+ {
+ return aThisRootItem;
+ }
+ anItem = anItem->Parent();
+ }
+ return TreeModel_ItemBasePtr();
+}
--- /dev/null
+// 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 MessageModel_ItemBase_H
+#define MessageModel_ItemBase_H
+
+#include <Standard.hxx>
+#include <TopoDS_Shape.hxx>
+#include <inspector/TreeModel_ItemBase.hxx>
+
+class MessageModel_ItemBase;
+typedef QExplicitlySharedDataPointer<MessageModel_ItemBase> MessageModel_ItemBasePtr;
+
+//! \class MessageModel_ItemBase
+// \brief Declaration of the tree model base item.
+class MessageModel_ItemBase : public TreeModel_ItemBase
+{
+public:
+
+ //! Resets cached values
+ virtual void Reset() Standard_OVERRIDE { TreeModel_ItemBase::Reset(); }
+
+protected:
+
+ //! Initialize the current item. It creates a backup of the specific item information
+ virtual void initItem() const {};
+
+ //! Constructor
+ //! param theParent a parent item
+ //! \param theRow the item row positition in the parent item
+ //! \param theColumn the item column positition in the parent item
+ MessageModel_ItemBase (TreeModel_ItemBasePtr theParent, const int theRow, const int theColumn)
+ : TreeModel_ItemBase (theParent, theRow, theColumn) {}
+
+ //! Return whether the view is reversed or not
+ //! \return boolean value
+ Standard_Boolean isReversed() const;
+
+ //! Return root item
+ //! \return an item instance
+ TreeModel_ItemBasePtr GetRootItem() const;
+};
+
+#endif
\ No newline at end of file
--- /dev/null
+// 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.
+
+#include <inspector/MessageModel_ItemReport.hxx>
+
+#include <inspector/MessageModel_ItemAlert.hxx>
+#include <inspector/MessageModel_ItemRoot.hxx>
+#include <inspector/MessageModel_Tools.hxx>
+#include <inspector/MessageModel_TreeModel.hxx>
+
+#include <Message.hxx>
+#include <Message_Alert.hxx>
+#include <Message_AttributeMeter.hxx>
+#include <Message_Messenger.hxx>
+#include <Message_PrinterToReport.hxx>
+#include <OSD_Path.hxx>
+
+#include <Standard_WarningsDisable.hxx>
+#include <QColor>
+#include <Standard_WarningsRestore.hxx>
+
+// =======================================================================
+// function : initValue
+// purpose :
+// =======================================================================
+QVariant MessageModel_ItemReport::initValue (const int theRole) const
+{
+ QVariant aParentValue = MessageModel_ItemBase::initValue (theRole);
+ if (aParentValue.isValid())
+ return aParentValue;
+
+ const Handle(Message_Report)& aReport = getReport();
+ if (aReport.IsNull())
+ return QVariant();
+
+ if (theRole == Qt::ForegroundRole)
+ {
+ if (!aReport->IsActiveInMessenger())
+ return QColor(Qt::darkGray);
+
+ return QVariant();
+ }
+ if (theRole == Qt::ToolTipRole && !myDescription.IsEmpty() && Column() == 0) // display the exported file name in tool tip
+ {
+ OSD_Path aPath(myDescription);
+ return QString ("%1%2").arg (aPath.Name().ToCString()).arg (aPath.Extension().ToCString());
+ }
+
+ if (theRole != Qt::DisplayRole)
+ return QVariant();
+
+ if (Column() == 0)
+ return aReport->DynamicType()->Name();
+
+ Message_MetricType aMetricType;
+ int aPosition;
+ if (MessageModel_TreeModel::IsMetricColumn (Column(), aMetricType, aPosition) &&
+ (aMetricType == Message_MetricType_UserTimeCPU || aMetricType == Message_MetricType_SystemTimeInfo ||
+ aMetricType == Message_MetricType_WallClock))
+ {
+ if (aPosition == 0) return CumulativeMetric (aReport, aMetricType);
+ else if (aPosition == 1) return "100";
+ }
+ return QVariant();
+}
+
+// =======================================================================
+// function : initRowCount
+// purpose :
+// =======================================================================
+int MessageModel_ItemReport::initRowCount() const
+{
+ const Handle(Message_Report)& aReport = getReport();
+ if (aReport.IsNull())
+ return 0;
+
+ MessageModel_ItemReport* aCurrentItem = (MessageModel_ItemReport*)this;
+ for (int aGravityId = Message_Trace; aGravityId <= Message_Fail; aGravityId++)
+ {
+ const Message_ListOfAlert& anAlerts = aReport->GetAlerts ((Message_Gravity)aGravityId);
+ for (Message_ListOfAlert::Iterator anIt(anAlerts); anIt.More(); anIt.Next())
+ {
+ Message_ListOfAlert aCurAlerts;
+ aCurAlerts.Append (anIt.Value());
+ aCurrentItem->myChildAlerts.Bind(myChildAlerts.Size(), aCurAlerts);
+ }
+ }
+ return aCurrentItem->myChildAlerts.Size();
+}
+
+// =======================================================================
+// function : createChild
+// purpose :
+// =======================================================================
+TreeModel_ItemBasePtr MessageModel_ItemReport::createChild (int theRow, int theColumn)
+{
+ return MessageModel_ItemAlert::CreateItem (currentItem(), theRow, theColumn);
+}
+
+// =======================================================================
+// function : Init
+// purpose :
+// =======================================================================
+void MessageModel_ItemReport::Init()
+{
+ MessageModel_ItemRootPtr aRootItem = itemDynamicCast<MessageModel_ItemRoot> (Parent());
+ myReport = aRootItem ? aRootItem->GetReport (Row(), myDescription) : Handle(Message_Report)();
+
+ MessageModel_ItemBase::Init();
+}
+
+// =======================================================================
+// function : getReport
+// purpose :
+// =======================================================================
+const Handle(Message_Report)& MessageModel_ItemReport::getReport() const
+{
+ initItem();
+ return myReport;
+}
+
+// =======================================================================
+// function : Reset
+// purpose :
+// =======================================================================
+void MessageModel_ItemReport::Reset()
+{
+ MessageModel_ItemBase::Reset();
+ myReport = Handle(Message_Report)();
+ myChildAlerts.Clear();
+}
+
+// =======================================================================
+// function : initItem
+// purpose :
+// =======================================================================
+void MessageModel_ItemReport::initItem() const
+{
+ if (IsInitialized())
+ return;
+ const_cast<MessageModel_ItemReport*>(this)->Init();
+}
+
+// =======================================================================
+// function : FindReportItem
+// purpose :
+// =======================================================================
+MessageModel_ItemReportPtr MessageModel_ItemReport::FindReportItem (const TreeModel_ItemBasePtr& theItem)
+{
+ TreeModel_ItemBasePtr anItem = theItem;
+ while (anItem)
+ {
+ if (MessageModel_ItemReportPtr aReportItem = itemDynamicCast<MessageModel_ItemReport>(anItem))
+ return aReportItem;
+
+ anItem = anItem->Parent();
+ }
+ return MessageModel_ItemReportPtr();
+}
+
+// =======================================================================
+// function : FindReport
+// purpose :
+// =======================================================================
+Handle(Message_Report) MessageModel_ItemReport::FindReport (const MessageModel_ItemBasePtr& theItem)
+{
+ Handle(Message_Report) aReport;
+
+ MessageModel_ItemBasePtr anItem = theItem;
+ while (anItem)
+ {
+ MessageModel_ItemReportPtr aReportItem = itemDynamicCast<MessageModel_ItemReport>(anItem);
+
+ if (aReportItem)
+ return aReportItem->GetReport();
+
+ anItem = itemDynamicCast<MessageModel_ItemBase>(anItem->Parent());
+ }
+ return NULL;
+}
+
+// =======================================================================
+// function : CumulativeMetric
+// purpose :
+// =======================================================================
+Standard_Real MessageModel_ItemReport::CumulativeMetric (const Handle(Message_Report)& theReport, const Message_MetricType theMetricType)
+{
+ if (!theReport->ActiveMetrics().Contains (theMetricType))
+ return 0;
+
+ Standard_Real aMetric = 0;
+ for (int iGravity = Message_Trace; iGravity <= Message_Fail; ++iGravity)
+ {
+ const Message_ListOfAlert& anAlerts = theReport->GetAlerts ((Message_Gravity)iGravity);
+ Handle(Message_AttributeMeter) aFirstAttribute/*, aLastAttribute*/;
+ for (Message_ListOfAlert::Iterator anAlertsIterator (anAlerts); anAlertsIterator.More(); anAlertsIterator.Next())
+ {
+ Handle(Message_AlertExtended) anAlert = Handle(Message_AlertExtended)::DownCast (anAlertsIterator.Value());
+ if (anAlert.IsNull())
+ continue;
+ Handle(Message_AttributeMeter) anAttribute = Handle(Message_AttributeMeter)::DownCast (anAlert->Attribute());
+ if (anAttribute.IsNull() || !anAttribute->HasMetric (theMetricType) || !anAttribute->IsMetricValid (theMetricType))
+ continue;
+
+ //if (aFirstAttribute.IsNull())
+ // aFirstAttribute = anAttribute;
+ //else
+ //{
+ //aLastAttribute = anAttribute;
+ //}
+ aMetric += anAttribute->StopValue (theMetricType) - anAttribute->StartValue (theMetricType);
+ }
+ //if (aFirstAttribute.IsNull())
+ // continue;
+ //if (aLastAttribute.IsNull())
+ // aLastAttribute = aFirstAttribute;
+
+ //aMetric += aLastAttribute->StopValue (theMetricType) - aFirstAttribute->StartValue (theMetricType);
+ }
+ return aMetric;
+}
--- /dev/null
+// 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 MessageModel_ItemReport_H
+#define MessageModel_ItemReport_H
+
+#include <inspector/MessageModel_ItemBase.hxx>
+#include <Standard.hxx>
+#include <TCollection_AsciiString.hxx>
+#include <Message_Alert.hxx>
+#include <Message_Report.hxx>
+#include <NCollection_DataMap.hxx>
+
+#include <Standard_WarningsDisable.hxx>
+#include <QMap>
+#include <QVariant>
+#include <Standard_WarningsRestore.hxx>
+
+class MessageModel_ItemReport;
+typedef QExplicitlySharedDataPointer<MessageModel_ItemReport> MessageModel_ItemReportPtr;
+
+//! \class MessageModel_ItemReport
+//! This item is connected to Message_Alert.
+//! Parent is MessageModel_ItemRoot, children are MessageModel_ItemAlert or no children
+class MessageModel_ItemReport : public MessageModel_ItemBase
+{
+public:
+
+ //! Creates an item wrapped by a shared pointer
+ //! \param theRow the item row positition in the parent item
+ //! \param theColumn the item column positition in the parent item
+ //! \return the pointer to the created item
+ static MessageModel_ItemReportPtr CreateItem (TreeModel_ItemBasePtr theParent, const int theRow, const int theColumn)
+ { return MessageModel_ItemReportPtr (new MessageModel_ItemReport (theParent, theRow, theColumn)); }
+
+ //! Destructor
+ virtual ~MessageModel_ItemReport() Standard_OVERRIDE {};
+
+ //! Returns the current shape
+ const Handle(Message_Report)& GetReport() const { return myReport; }
+
+ //! Returns alert of the report for the parameter row
+ Standard_Boolean GetChildAlerts (const int theRow, Message_ListOfAlert& theAlerts) const { return myChildAlerts.Find(theRow, theAlerts); }
+
+ //! Returns the report description or NULL
+ const TCollection_AsciiString& GetDescription() const { return myDescription; }
+
+ //! Inits the item, fills internal containers
+ Standard_EXPORT virtual void Init() Standard_OVERRIDE;
+
+ //! Resets cached values
+ Standard_EXPORT virtual void Reset() Standard_OVERRIDE;
+
+ //! Return data value for the role.
+ //! \param theRole a value role
+ //! \return the value
+ Standard_EXPORT virtual QVariant initValue (const int theRole) const Standard_OVERRIDE;
+
+ //! \return number of children.
+ Standard_EXPORT virtual int initRowCount() const Standard_OVERRIDE;
+
+ //! Returns report of the tree model item. Iterates up by parents intil the report item is found.
+ //! \return an item or NULL
+ Standard_EXPORT static MessageModel_ItemReportPtr FindReportItem (const TreeModel_ItemBasePtr& theItem);
+
+ //! Returns report of the item
+ static Handle(Message_Report) FindReport (const MessageModel_ItemBasePtr& thetItem);
+
+ //! Returns report cumulative metric as stop time of the last alert minus start time of the first alert
+ Standard_EXPORT static Standard_Real CumulativeMetric (const Handle(Message_Report)& theReport, const Message_MetricType theMetricType);
+
+protected:
+
+ //! Initialize the current item. It is empty because Reset() is also empty.
+ virtual void initItem() 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;
+
+ //! Returns number of child shapes. Init item if it is not initialized
+ //! \return integer value
+ int getRowCount() const;
+
+ //! Returns current shape, initialized item if it has not been initialized yet
+ //! \return shape value
+ const Handle(Message_Report)& getReport() const;
+
+private:
+
+ //! Constructor
+ MessageModel_ItemReport (TreeModel_ItemBasePtr theParent, const int theRow, const int theColumn)
+ : MessageModel_ItemBase (theParent, theRow, theColumn) {}
+
+private:
+
+ NCollection_DataMap<Standard_Integer, Message_ListOfAlert> myChildAlerts; //!< container of child alerts
+
+ Handle(Message_Report) myReport; //!< current report
+ TCollection_AsciiString myDescription; //!< description
+};
+
+#endif
--- /dev/null
+// 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.
+
+
+#include <inspector/MessageModel_ItemRoot.hxx>
+#include <inspector/MessageModel_ItemReport.hxx>
+
+// =======================================================================
+// function : SetReport
+// purpose :
+// =======================================================================
+void MessageModel_ItemRoot::SetReport (const int theRowId, const Handle(Message_Report)& theReport,
+ const TCollection_AsciiString& theReportDescription)
+{
+ NCollection_List<MessageModel_ReportInformation>::Iterator aReportsIt (myReports);
+ for (int aRowId = 0; aReportsIt.More(); aReportsIt.Next(), aRowId++)
+ {
+ if (aRowId == theRowId)
+ break;
+ }
+ aReportsIt.Value().myReport = theReport;
+ aReportsIt.Value().myDescription = theReportDescription;
+}
+
+// =======================================================================
+// function : GetReport
+// purpose :
+// =======================================================================
+const Handle(Message_Report)& MessageModel_ItemRoot::GetReport (const int theRowId,
+ TCollection_AsciiString& theReportDescription)
+{
+ NCollection_List<MessageModel_ReportInformation>::Iterator aReportsIt (myReports);
+ for (int aRowId = 0; aReportsIt.More(); aReportsIt.Next(), aRowId++)
+ {
+ if (aRowId == theRowId)
+ break;
+ }
+ theReportDescription = aReportsIt.Value().myDescription;
+ return aReportsIt.Value().myReport;
+}
+
+// =======================================================================
+// function : HasReport
+// purpose :
+// =======================================================================
+Standard_Boolean MessageModel_ItemRoot::HasReport (const Handle(Message_Report)& theReport)
+{
+ NCollection_List<MessageModel_ReportInformation>::Iterator aReportsIt (myReports);
+ for (int aRowId = 0; aReportsIt.More(); aReportsIt.Next(), aRowId++)
+ {
+ if (aReportsIt.Value().myReport == theReport)
+ return Standard_True;
+ }
+ return Standard_False;
+}
+
+// =======================================================================
+// function : initValue
+// purpose :
+// =======================================================================
+QVariant MessageModel_ItemRoot::initValue (const int theRole) const
+{
+ QVariant aParentValue = MessageModel_ItemBase::initValue (theRole);
+ if (aParentValue.isValid())
+ return aParentValue;
+
+ if (Column() != 0)
+ return QVariant();
+
+ if (theRole == Qt::DisplayRole)
+ return myName.IsEmpty() ? "Message_Reports" : myName.ToCString();
+
+ return QVariant();
+}
+
+// =======================================================================
+// function : createChild
+// purpose :
+// =======================================================================
+TreeModel_ItemBasePtr MessageModel_ItemRoot::createChild (int theRow, int theColumn)
+{
+ return MessageModel_ItemReport::CreateItem (currentItem(), theRow, theColumn);
+}
+
--- /dev/null
+// 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 MessageModel_ItemRoot_H
+#define MessageModel_ItemRoot_H
+
+#include <Message_Alert.hxx>
+#include <Message_Report.hxx>
+#include <NCollection_List.hxx>
+#include <Standard.hxx>
+#include <TCollection_AsciiString.hxx>
+
+#include <inspector/MessageModel_ItemBase.hxx>
+
+class MessageModel_ItemRoot;
+typedef QExplicitlySharedDataPointer<MessageModel_ItemRoot> MessageModel_ItemRootPtr;
+
+//! \struct to extend report by description
+struct MessageModel_ReportInformation
+{
+ //! Constructor
+ MessageModel_ReportInformation (Handle(Message_Report) theReport, const TCollection_AsciiString& theDescription)
+ : myReport (theReport), myDescription (theDescription) {}
+
+ Handle(Message_Report) myReport; //! report
+ TCollection_AsciiString myDescription; //! report description
+};
+
+//! \class MessageModel_ItemRoot
+//! Collects message reports that should be visualized in tree view. Reports are cached and if reports are not needed,
+//! cache should be cleared using RemoveAllReports
+//! Parent is NULL, children are MessageModel_ItemReport items.
+class MessageModel_ItemRoot : public MessageModel_ItemBase
+{
+public:
+
+ //! Creates an item wrapped by a shared pointer
+ static MessageModel_ItemRootPtr CreateItem (TreeModel_ItemBasePtr theParent, const int theRow, const int theColumn)
+ { return MessageModel_ItemRootPtr (new MessageModel_ItemRoot (theParent, theRow, theColumn)); }
+
+ //! Destructor
+ virtual ~MessageModel_ItemRoot() Standard_OVERRIDE {};
+
+ //! Appends new report
+ //! \param theReport a report instance
+ //! \param theReportDescription an additional report information
+ void AddReport (const Handle(Message_Report)& theReport, const TCollection_AsciiString& theReportDescription)
+ { myReports.Append (MessageModel_ReportInformation (theReport, theReportDescription)); }
+
+ //! Set report, se it into the given row index
+ //! \param theRowId a report child row
+ //! \param theReport a report instance
+ //! \param theReportDescription an additional report information
+ Standard_EXPORT void SetReport (const int theRowId, const Handle(Message_Report)& theReport,
+ const TCollection_AsciiString& theReportDescription = "");
+
+ //! Returns true if report exists is in the list of the current reports
+ //! \param theReport a report instance
+ //! \return boolen value
+ Standard_EXPORT Standard_Boolean HasReport (const Handle(Message_Report)& theReport);
+
+ //!< Returns processed reports
+ const NCollection_List<MessageModel_ReportInformation>& Reports() const { return myReports; }
+
+ //! Clears internal container of added reports
+ void RemoveAllReports() { myReports.Clear(); }
+
+ //! Returns report by the number
+ //! \param theRowId an index of the report in the internal container.
+ Standard_EXPORT const Handle(Message_Report)& GetReport (const int theRowId, TCollection_AsciiString& theReportDescription);
+
+ //! Set the view reversed. If reversed, the last report alert is upper item in the tree view
+ //! \param theReversed boolean flag
+ void SetReversed (const Standard_Boolean& theReversed) { myIsReversed = theReversed; }
+
+ //! Return whether the view is reversed or not
+ //! \return boolean value
+ Standard_Boolean IsReversed() const { return myIsReversed; };
+
+ //! Set the view reversed. If reversed, the last report alert is upper item in the tree view
+ //! \param theReversed boolean flag
+ void SetName (const TCollection_AsciiString& theName) { myName = theName; }
+
+protected:
+
+ //! Return data value for the role.
+ //! \param theRole a value role
+ //! \return the value
+ virtual QVariant initValue (const int theRole) const Standard_OVERRIDE;
+
+ //! \return number of children.
+ virtual int initRowCount() const Standard_OVERRIDE { return myReports.Size(); }
+
+ //! 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;
+
+private:
+
+ //! Constructor
+ //! param theParent a parent item
+ MessageModel_ItemRoot (TreeModel_ItemBasePtr theParent, const int theRow, const int theColumn)
+ : MessageModel_ItemBase (theParent, theRow, theColumn), myIsReversed (Standard_False) {}
+
+private:
+
+ NCollection_List<MessageModel_ReportInformation> myReports; //!< reports sent by algorithms
+ Standard_Boolean myIsReversed; //!< state if the model is reversed
+ TCollection_AsciiString myName; //!< DisplayRole data, if defined
+};
+
+#endif
--- /dev/null
+// 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.
+
+#include <inspector/MessageModel_Tools.hxx>
+#include <inspector/MessageModel_ItemAlert.hxx>
+
+#include <inspector/ViewControl_Table.hxx>
+#include <inspector/ViewControl_TableModelValues.hxx>
+
+#include <BRep_Builder.hxx>
+#include <BRepBuilderAPI_MakeVertex.hxx>
+#include <BRepBuilderAPI_MakeEdge.hxx>
+#include <BRepTools.hxx>
+#include <Message_AlertExtended.hxx>
+#include <Message_AttributeObject.hxx>
+#include <Message_AttributeStream.hxx>
+
+#include <Precision.hxx>
+#include <TopoDS_AlertAttribute.hxx>
+#include <TopoDS_Edge.hxx>
+
+// =======================================================================
+// function : GetPointerInfo
+// purpose :
+// =======================================================================
+TCollection_AsciiString MessageModel_Tools::GetPointerInfo (const Handle(Standard_Transient)& thePointer, const bool isShortInfo)
+{
+ if (thePointer.IsNull())
+ return TCollection_AsciiString();
+
+ std::ostringstream aPtrStr;
+ aPtrStr << thePointer.operator->();
+ if (!isShortInfo)
+ return aPtrStr.str().c_str();
+
+ TCollection_AsciiString anInfoPtr (aPtrStr.str().c_str());
+ for (int aSymbolId = 1; aSymbolId < anInfoPtr.Length(); aSymbolId++)
+ {
+ if (anInfoPtr.Value(aSymbolId) != '0')
+ {
+ anInfoPtr = anInfoPtr.SubString (aSymbolId, anInfoPtr.Length());
+ anInfoPtr.Prepend("0x");
+ return anInfoPtr;
+ }
+ }
+ return aPtrStr.str().c_str();
+}
--- /dev/null
+// 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 MessageModel_Tools_H
+#define MessageModel_Tools_H
+
+#include <Standard.hxx>
+
+#include <TCollection_AsciiString.hxx>
+#include <Message_ListOfAlert.hxx>
+#include <NCollection_DataMap.hxx>
+#include <NCollection_Vector.hxx>
+#include <Standard_Transient.hxx>
+#include <TopoDS_Shape.hxx>
+
+#include <inspector/TreeModel_ItemBase.hxx>
+
+#include <Standard_WarningsDisable.hxx>
+#include <QList>
+#include <Standard_WarningsRestore.hxx>
+
+class Message_Alert;
+class ViewControl_TableModelValues;
+
+class ViewControl_Table;
+
+//! \class MessageModel_Tools
+//! It gives auxiliary methods for Message classes manipulation
+class MessageModel_Tools
+{
+public:
+
+ //! Convert pointer to string value
+ //! \param thePointer a pointer
+ //! \param isShortInfo if true, all '0' symbols in the beginning of the pointer are skipped
+ //! \return the string value
+ Standard_EXPORT static TCollection_AsciiString GetPointerInfo (const Handle(Standard_Transient)& thePointer,
+ const bool isShortInfo = true);
+};
+
+#endif
--- /dev/null
+// 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.
+
+#include <inspector/MessageModel_TreeModel.hxx>
+
+#include <inspector/MessageModel_ItemAlert.hxx>
+#include <inspector/MessageModel_ItemRoot.hxx>
+#include <inspector/MessageModel_ItemReport.hxx>
+#include <inspector/TreeModel_ColumnType.hxx>
+
+#include <Message.hxx>
+
+const int COLUMN_NAME_WIDTH = 230;
+const int COLUMN_SIZE_WIDTH = 30;
+
+const int COLUMN_REAL_VALUE_WIDTH = 115;
+const int COLUMN_PERCENT_VALUE_WIDTH = 50;
+
+// =======================================================================
+// function : Constructor
+// purpose :
+// =======================================================================
+MessageModel_TreeModel::MessageModel_TreeModel (QObject* theParent)
+: TreeModel_ModelBase (theParent), myIsReversed (Standard_False)
+{
+}
+
+// =======================================================================
+// function : InitColumns
+// purpose :
+// =======================================================================
+void MessageModel_TreeModel::InitColumns()
+{
+ // 0 - Name, 1 - visibility, 2 - Row
+ setHeaderItem (TreeModel_ColumnType_Name, TreeModel_HeaderSection ("Name", COLUMN_NAME_WIDTH));
+ setHeaderItem (TreeModel_ColumnType_Visibility, TreeModel_HeaderSection ("Visibility", TreeModel_ModelBase::ColumnVisibilityWidth()));
+ setHeaderItem (TreeModel_ColumnType_Row, TreeModel_HeaderSection ("Row", COLUMN_SIZE_WIDTH, Standard_True /*hidden*/));
+
+ int aNextIndex = 3;
+ for (int aMetricId = (int)Message_MetricType_None + 1; aMetricId <= (int)Message_MetricType_MemHeapUsage; aMetricId++)
+ {
+ Message_MetricType aMetricType = (Message_MetricType)aMetricId;
+ OSD_MemInfo::Counter aMemInfo;
+ bool isMemInfo = Message::ToOSDMetric (aMetricType, aMemInfo);
+
+ setHeaderItem (aNextIndex++,
+ TreeModel_HeaderSection (QString("%1 [%2]").arg (Message::MetricToString (aMetricType)).arg(isMemInfo ? "Mb" : "s"),
+ COLUMN_REAL_VALUE_WIDTH));
+ setHeaderItem (aNextIndex++, TreeModel_HeaderSection (isMemInfo ? "Delta" : "%", COLUMN_PERCENT_VALUE_WIDTH));
+ }
+}
+
+// =======================================================================
+// function : GetMetricColumns
+// purpose :
+// =======================================================================
+void MessageModel_TreeModel::GetMetricColumns (const Message_MetricType theMetricType, QList<int>& theMetricColumns)
+{
+ theMetricColumns.clear();
+ int aNextIndex = 3; // after default parent columns, see InitColumns
+ for (int aMetricId = (int)Message_MetricType_None + 1; aMetricId <= (int)Message_MetricType_MemHeapUsage; aMetricId++)
+ {
+ if (theMetricType != (Message_MetricType)aMetricId)
+ {
+ aNextIndex += 2;
+ continue;
+ }
+ theMetricColumns.append (aNextIndex++);
+ theMetricColumns.append (aNextIndex++);
+ }
+}
+
+// =======================================================================
+// function : IsMetricColumn
+// purpose :
+// =======================================================================
+bool MessageModel_TreeModel::IsMetricColumn (const int theColumnId, Message_MetricType& theMetricType, int& thePosition)
+{
+ int aNextIndex = 3; // after default parent columns, see InitColumns
+ for (int aMetricId = (int)Message_MetricType_None + 1; aMetricId <= (int)Message_MetricType_MemHeapUsage; aMetricId++)
+ {
+ if (theColumnId == aNextIndex || theColumnId == aNextIndex + 1)
+ {
+ theMetricType = (Message_MetricType)aMetricId;
+ thePosition = theColumnId - aNextIndex;
+ return true;
+ }
+ aNextIndex += 2;
+ }
+ return false;
+}
+
+// =======================================================================
+// function : createRootItem
+// purpose :
+// =======================================================================
+TreeModel_ItemBasePtr MessageModel_TreeModel::createRootItem (const int theColumnId)
+{
+ return MessageModel_ItemRoot::CreateItem (TreeModel_ItemBasePtr(), 0, theColumnId);
+}
+
+// =======================================================================
+// function : HasShape
+// purpose :
+// =======================================================================
+Standard_Boolean MessageModel_TreeModel::HasReport (const Handle(Message_Report)& theReport)
+{
+ if (columnCount() == 0)
+ return Standard_False;
+
+ MessageModel_ItemRootPtr aRootItem = itemDynamicCast<MessageModel_ItemRoot> (RootItem (0));
+ return aRootItem && aRootItem->HasReport (theReport);
+}
+
+// =======================================================================
+// function : AddShape
+// purpose :
+// =======================================================================
+void MessageModel_TreeModel::AddReport (const Handle(Message_Report)& theReport,
+ const TCollection_AsciiString& theReportDescription)
+{
+ for (int aColId = 0, aNbColumns = columnCount(); aColId < aNbColumns; aColId++)
+ {
+ MessageModel_ItemRootPtr aRootItem = itemDynamicCast<MessageModel_ItemRoot> (RootItem (aColId));
+ if (!aRootItem)
+ continue;
+ aRootItem->AddReport (theReport, theReportDescription);
+ aRootItem->SetReversed (myIsReversed);
+ }
+
+ Reset();
+ EmitLayoutChanged();
+}
+
+// =======================================================================
+// function : SetReport
+// purpose :
+// =======================================================================
+void MessageModel_TreeModel::SetReport (const int theRowId, const Handle(Message_Report)& theReport,
+ const TCollection_AsciiString& theReportDescription)
+{
+ for (int aColId = 0, aNbColumns = columnCount(); aColId < aNbColumns; aColId++)
+ {
+ MessageModel_ItemRootPtr aRootItem = itemDynamicCast<MessageModel_ItemRoot> (RootItem (aColId));
+ if (!aRootItem)
+ continue;
+ aRootItem->SetReport (theRowId, theReport, theReportDescription);
+ }
+ Reset();
+ EmitLayoutChanged();
+}
+
+// =======================================================================
+// function : Reports
+// purpose :
+// =======================================================================
+const NCollection_List<MessageModel_ReportInformation>& MessageModel_TreeModel::Reports() const
+{
+ MessageModel_ItemRootPtr aRootItem = itemDynamicCast<MessageModel_ItemRoot> (RootItem (0));
+ return aRootItem->Reports();
+}
+
+// =======================================================================
+// function : SetReversed
+// purpose :
+// =======================================================================
+void MessageModel_TreeModel::SetReversed (const Standard_Boolean& theReversed)
+{
+ myIsReversed = theReversed;
+
+ for (int aColId = 0, aNbColumns = columnCount(); aColId < aNbColumns; aColId++)
+ {
+ MessageModel_ItemRootPtr aRootItem = itemDynamicCast<MessageModel_ItemRoot> (RootItem (aColId));
+ if (aRootItem)
+ aRootItem->SetReversed (myIsReversed);
+ }
+
+ Reset();
+ EmitLayoutChanged();
+}
+
+// =======================================================================
+// function : UpdateTreeModel
+// purpose :
+// =======================================================================
+void MessageModel_TreeModel::SetRootItemName (const TCollection_AsciiString& theName)
+{
+ MessageModel_ItemRootPtr aRootItem = itemDynamicCast<MessageModel_ItemRoot> (RootItem (0));
+ if (aRootItem)
+ aRootItem->SetName (theName);
+}
+
+// =======================================================================
+// function : UpdateTreeModel
+// purpose :
+// =======================================================================
+void MessageModel_TreeModel::UpdateTreeModel()
+{
+ Reset();
+ EmitLayoutChanged();
+}
--- /dev/null
+// 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 MessageModel_TreeModel_H
+#define MessageModel_TreeModel_H
+
+#include <inspector/MessageModel_ItemBase.hxx>
+#include <inspector/MessageModel_ItemRoot.hxx>
+#include <Standard.hxx>
+#include <TCollection_AsciiString.hxx>
+#include <Message_Report.hxx>
+#include <inspector/TreeModel_ModelBase.hxx>
+
+#include <Standard_WarningsDisable.hxx>
+#include <QMap>
+#include <QObject>
+#include <Standard_WarningsRestore.hxx>
+
+class MessageModel_TreeModel;
+
+//! \class MessageModel_TreeModel
+//! View model to visualize MessageReport/s content
+class MessageModel_TreeModel : public TreeModel_ModelBase
+{
+public:
+
+ //! Constructor
+ Standard_EXPORT MessageModel_TreeModel (QObject* theParent);
+
+ //! Destructor
+ virtual ~MessageModel_TreeModel() Standard_OVERRIDE {};
+
+ //! Creates model columns and root items.
+ Standard_EXPORT virtual void InitColumns() Standard_OVERRIDE;
+
+ //!< Returns columns of the model for the metric
+ //!< \param theMetricType metric
+ //!< \param theMetricColumns [out] container of metric columns
+ static Standard_EXPORT void GetMetricColumns (const Message_MetricType theMetricType, QList<int>& theMetricColumns);
+
+ //!< Returns metric type for the column
+ //!< \param theColumnId [in] index of the tree column
+ //!< \param theMetricType [out] metric type if found
+ //!< \param thePosition [out] index of the metric column, 0 - is metric, 1 - is delta
+ //!< \return true if the column has metric parameters
+ static Standard_EXPORT bool IsMetricColumn (const int theColumnId, Message_MetricType& theMetricType, int& thePosition);
+
+ //! Returns true if parameter report was added into the model
+ //! \param theReport a report instance
+ //! \return boolen value
+ Standard_EXPORT Standard_Boolean HasReport (const Handle(Message_Report)& theReport);
+
+ //! Add shape, append it to the model root item
+ //! \param theReport a report instance
+ //! \param theReportDescription an additional report information
+ Standard_EXPORT void AddReport (const Handle(Message_Report)& theReport,
+ const TCollection_AsciiString& theReportDescription = "");
+
+ //! Set report, se it into the given row index
+ //! \param theRowId a report child row
+ //! \param theReport a report instance
+ //! \param theReportDescription an additional report information
+ Standard_EXPORT void SetReport (const int theRowId, const Handle(Message_Report)& theReport,
+ const TCollection_AsciiString& theReportDescription = "");
+
+ //!< Returns processed reports
+ Standard_EXPORT const NCollection_List<MessageModel_ReportInformation>& Reports() const;
+
+ //! Set the view reversed. If reversed, the last report alert is upper item in the tree view
+ //! \param theReversed boolean flag
+ Standard_EXPORT void SetReversed (const Standard_Boolean& theReversed);
+
+ //! Return whether the view is reversed or not
+ //! \return boolean value
+ Standard_Boolean IsReversed() const { return myIsReversed; };
+
+ //! Sets the text value of the Root item, only "Name" column accepts the parameter value
+ //! \theName visulized text of root item
+ Standard_EXPORT void SetRootItemName (const TCollection_AsciiString& theName);
+
+ //! Updates tree model
+ Standard_EXPORT void UpdateTreeModel();
+
+protected:
+ //! Creates root item
+ //! \param theColumnId index of a column
+ virtual TreeModel_ItemBasePtr createRootItem (const int theColumnId) Standard_OVERRIDE;
+
+private:
+ Standard_Boolean myIsReversed; //!< state if the model is reversed
+};
+
+#endif
--- /dev/null
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!-- Created with Inkscape (http://www.inkscape.org/) -->
+
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ width="20"
+ height="20"
+ viewBox="0 0 5.2916664 5.2916666"
+ version="1.1"
+ id="svg8"
+ inkscape:version="0.92.2 (5c3e80d, 2017-08-06)"
+ sodipodi:docname="item_shape.svg"
+ inkscape:export-filename="D:\OCCT\master_CR29451_1\tools\MessageModel\icons\item_shape.png"
+ inkscape:export-xdpi="96"
+ inkscape:export-ydpi="96">
+ <defs
+ id="defs2">
+ <inkscape:perspective
+ sodipodi:type="inkscape:persp3d"
+ inkscape:vp_x="-2.6544163 : -0.28690906 : 1"
+ inkscape:vp_y="0 : 1028.295 : 0"
+ inkscape:vp_z="9.504499 : -1.1228559 : 1"
+ inkscape:persp3d-origin="2.7661607 : -1.3768436 : 1"
+ id="perspective3711" />
+ </defs>
+ <sodipodi:namedview
+ id="base"
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1.0"
+ inkscape:pageopacity="0.0"
+ inkscape:pageshadow="2"
+ inkscape:zoom="15.839192"
+ inkscape:cx="4.9829441"
+ inkscape:cy="7.75434"
+ inkscape:document-units="px"
+ inkscape:current-layer="layer1"
+ showgrid="false"
+ fit-margin-top="0"
+ fit-margin-left="0"
+ fit-margin-right="0"
+ fit-margin-bottom="0"
+ inkscape:window-width="1446"
+ inkscape:window-height="676"
+ inkscape:window-x="1766"
+ inkscape:window-y="124"
+ inkscape:window-maximized="0"
+ units="px" />
+ <metadata
+ id="metadata5">
+ <rdf:RDF>
+ <cc:Work
+ rdf:about="">
+ <dc:format>image/svg+xml</dc:format>
+ <dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+ <dc:title></dc:title>
+ </cc:Work>
+ </rdf:RDF>
+ </metadata>
+ <g
+ inkscape:label="Layer 1"
+ inkscape:groupmode="layer"
+ id="layer1"
+ transform="translate(71.966667,-93.642022)">
+ <g
+ sodipodi:type="inkscape:box3d"
+ id="g3741"
+ inkscape:perspectiveID="#perspective3711"
+ inkscape:corner0="0.78884625 : 0.0054590483 : 0 : 1"
+ inkscape:corner7="-0.14713316 : 0.0022509206 : 0.25 : 1">
+ <path
+ sodipodi:type="inkscape:box3dside"
+ id="path3743"
+ style="fill:#353564;fill-rule:evenodd;stroke:none;stroke-width:1.45609081;stroke-linejoin:round"
+ inkscape:box3dsidetype="6"
+ d="m -71.590875,96.691829 v 1.844151 l 1.119347,0.186449 v -1.618024 z"
+ points="-71.590875,98.53598 -70.471528,98.722429 -70.471528,97.104405 -71.590875,96.691829 " />
+ <path
+ sodipodi:type="inkscape:box3dside"
+ id="path3753"
+ style="fill:#e9e9ff;fill-rule:evenodd;stroke:none;stroke-width:1.45609081;stroke-linejoin:round"
+ inkscape:box3dsidetype="11"
+ d="m -70.471528,97.104405 3.521639,-1.795967 v 2.991206 l -3.521639,0.422785 z"
+ points="-66.949889,95.308438 -66.949889,98.299644 -70.471528,98.722429 -70.471528,97.104405 " />
+ <path
+ sodipodi:type="inkscape:box3dside"
+ id="path3745"
+ style="fill:#4d4d9f;fill-rule:evenodd;stroke:none;stroke-width:1.45609081;stroke-linejoin:round"
+ inkscape:box3dsidetype="5"
+ d="m -71.590875,96.691829 3.325505,-2.775198 1.315481,1.391807 -3.521639,1.795967 z"
+ points="-68.26537,93.916631 -66.949889,95.308438 -70.471528,97.104405 -71.590875,96.691829 " />
+ <path
+ sodipodi:type="inkscape:box3dside"
+ id="path3751"
+ style="fill:#afafde;fill-rule:evenodd;stroke:none;stroke-width:1.45609081;stroke-linejoin:round"
+ inkscape:box3dsidetype="13"
+ d="m -71.590875,98.53598 3.325505,-0.751334 1.315481,0.514998 -3.521639,0.422785 z"
+ points="-68.26537,97.784646 -66.949889,98.299644 -70.471528,98.722429 -71.590875,98.53598 " />
+ <path
+ sodipodi:type="inkscape:box3dside"
+ id="path3749"
+ style="fill:#d7d7ff;fill-rule:evenodd;stroke:none;stroke-width:1.45609081;stroke-linejoin:round"
+ inkscape:box3dsidetype="14"
+ d="m -68.26537,93.916631 v 3.868015 l 1.315481,0.514998 v -2.991206 z"
+ points="-68.26537,97.784646 -66.949889,98.299644 -66.949889,95.308438 -68.26537,93.916631 " />
+ <path
+ sodipodi:type="inkscape:box3dside"
+ id="path3747"
+ style="fill:#8686bf;fill-rule:evenodd;stroke:none;stroke-width:1.45609081;stroke-linejoin:round"
+ inkscape:box3dsidetype="3"
+ d="m -71.590875,96.691829 3.325505,-2.775198 v 3.868015 l -3.325505,0.751334 z"
+ points="-68.26537,93.916631 -68.26537,97.784646 -71.590875,98.53598 -71.590875,96.691829 " />
+ </g>
+ </g>
+</svg>
--- /dev/null
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!-- Created with Inkscape (http://www.inkscape.org/) -->
+
+<svg
+ xmlns:osb="http://www.openswatchbook.org/uri/2009/osb"
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ width="20"
+ height="20"
+ viewBox="0 0 5.2916664 5.2916666"
+ version="1.1"
+ id="svg8"
+ inkscape:version="0.92.2 (5c3e80d, 2017-08-06)"
+ sodipodi:docname="item_vectorOfReal.svg"
+ inkscape:export-filename="D:\OCCT\master_CR29451_1\tools\MessageModel\icons\item_vectorOfRealVec3.png"
+ inkscape:export-xdpi="96"
+ inkscape:export-ydpi="96">
+ <defs
+ id="defs2">
+ <linearGradient
+ id="linearGradient4578"
+ osb:paint="solid">
+ <stop
+ style="stop-color:#000000;stop-opacity:1;"
+ offset="0"
+ id="stop4576" />
+ </linearGradient>
+ <inkscape:perspective
+ sodipodi:type="inkscape:persp3d"
+ inkscape:vp_x="-2.6544163 : -0.28690906 : 1"
+ inkscape:vp_y="0 : 1028.295 : 0"
+ inkscape:vp_z="9.504499 : -1.1228559 : 1"
+ inkscape:persp3d-origin="2.7661607 : -1.3768436 : 1"
+ id="perspective3711" />
+ </defs>
+ <sodipodi:namedview
+ id="base"
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1.0"
+ inkscape:pageopacity="0.0"
+ inkscape:pageshadow="2"
+ inkscape:zoom="15.839192"
+ inkscape:cx="-10.548151"
+ inkscape:cy="10.279721"
+ inkscape:document-units="px"
+ inkscape:current-layer="layer1"
+ showgrid="false"
+ fit-margin-top="0"
+ fit-margin-left="0"
+ fit-margin-right="0"
+ fit-margin-bottom="0"
+ inkscape:window-width="1446"
+ inkscape:window-height="838"
+ inkscape:window-x="1733"
+ inkscape:window-y="67"
+ inkscape:window-maximized="0"
+ units="px" />
+ <metadata
+ id="metadata5">
+ <rdf:RDF>
+ <cc:Work
+ rdf:about="">
+ <dc:format>image/svg+xml</dc:format>
+ <dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+ <dc:title />
+ </cc:Work>
+ </rdf:RDF>
+ </metadata>
+ <g
+ inkscape:label="Layer 1"
+ inkscape:groupmode="layer"
+ id="layer1"
+ transform="translate(71.966667,-93.642022)">
+ <rect
+ id="rect3769"
+ width="4.660512"
+ height="4.443356"
+ x="-71.632576"
+ y="94.056023"
+ style="opacity:1;fill:none;fill-opacity:1;stroke:#8c8c8c;stroke-width:0.26458332;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" />
+ <rect
+ id="rect3769-3"
+ width="4.7041783"
+ height="2.2966287"
+ x="-71.676239"
+ y="96.202751"
+ style="opacity:1;fill:none;fill-opacity:1;stroke:#8c8c8c;stroke-width:0.19110738;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" />
+ <rect
+ id="rect3769-9"
+ width="2.3560426"
+ height="4.4502382"
+ x="-71.617508"
+ y="94.071091"
+ style="opacity:1;fill:none;fill-opacity:1;stroke:#8c8c8c;stroke-width:0.18826659;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" />
+ </g>
+</svg>
--- /dev/null
+MessageView_ActionsTest.cxx
+MessageView_ActionsTest.hxx
+MessageView_Communicator.cxx
+MessageView_Communicator.hxx
+MessageView_VisibilityState.cxx
+MessageView_VisibilityState.hxx
+MessageView_Window.cxx
+MessageView_Window.hxx
--- /dev/null
+// 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.
+
+#include <inspector/MessageView_ActionsTest.hxx>
+
+#include <inspector/MessageModel_ItemReport.hxx>
+#include <inspector/MessageModel_ItemRoot.hxx>
+#include <inspector/MessageModel_ItemAlert.hxx>
+#include <inspector/MessageModel_Tools.hxx>
+#include <inspector/MessageModel_TreeModel.hxx>
+#include <inspector/TInspectorAPI_PluginParameters.hxx>
+#include <inspector/ViewControl_Tools.hxx>
+
+#include <Message.hxx>
+#include <Message_AlertExtended.hxx>
+#include <Message_Messenger.hxx>
+#include <Message_PrinterToReport.hxx>
+
+#include <gp_Ax1.hxx>
+#include <gp_Ax2.hxx>
+#include <gp_Ax3.hxx>
+#include <Bnd_Box.hxx>
+#include <Bnd_OBB.hxx>
+#include <BRepBuilderAPI_MakeEdge.hxx>
+#include <OSD_Chronometer.hxx>
+#include <Quantity_Color.hxx>
+#include <Quantity_ColorRGBA.hxx>
+#include <TCollection_AsciiString.hxx>
+#include <TopoDS_AlertAttribute.hxx>
+
+#include <Standard_WarningsDisable.hxx>
+#include <QAction>
+#include <QFileDialog>
+#include <QItemSelectionModel>
+#include <QMenu>
+#include <QMessageBox>
+#include <QWidget>
+#include <Standard_WarningsRestore.hxx>
+
+//#define DEBUG_ALERTS
+
+#ifdef DEBUG_ALERTS
+#include <Message_Level.hxx>
+#endif
+
+#include <ctime>
+
+
+// =======================================================================
+// function : Constructor
+// purpose :
+// =======================================================================
+MessageView_ActionsTest::MessageView_ActionsTest (QWidget* theParent,
+ MessageModel_TreeModel* theTreeModel, QItemSelectionModel* theModel)
+: QObject (theParent), myTreeModel (theTreeModel), mySelectionModel (theModel)
+{
+ myActions.insert (MessageModel_ActionType_TestMetric,
+ ViewControl_Tools::CreateAction ("Test <metric>", SLOT (OnTestMetric()), parent(), this));
+ myActions.insert (MessageModel_ActionType_TestProperties,
+ ViewControl_Tools::CreateAction ("Test <PropertyPanel>", SLOT (OnTestPropertyPanel()), parent(), this));
+ myActions.insert (MessageModel_ActionType_TestMessenger,
+ ViewControl_Tools::CreateAction ("Test <Message_Messenger>", SLOT (OnTestMessenger()), parent(), this));
+ myActions.insert (MessageModel_ActionType_TestReportTree,
+ ViewControl_Tools::CreateAction ("Test <Tree of messages>", SLOT (OnTestReportTree()), parent(), this));
+ myActions.insert (MessageModel_ActionType_TestReportTree2,
+ ViewControl_Tools::CreateAction ("Test <Tree of messages> 2", SLOT (OnTestReportTree2()), parent(), this));
+}
+
+// =======================================================================
+// function : AddMenuActions
+// purpose :
+// =======================================================================
+void MessageView_ActionsTest::AddMenuActions (const QModelIndexList& theSelectedIndices, QMenu* theMenu)
+{
+ MessageModel_ItemRootPtr aRootItem;
+ MessageModel_ItemReportPtr aReportItem;
+ MessageModel_ItemAlertPtr anAlertItem;
+ for (QModelIndexList::const_iterator aSelIt = theSelectedIndices.begin(); aSelIt != theSelectedIndices.end(); aSelIt++)
+ {
+ QModelIndex anIndex = *aSelIt;
+ if (anIndex.column() != 0)
+ continue;
+
+ TreeModel_ItemBasePtr anItemBase = TreeModel_ModelBase::GetItemByIndex (anIndex);
+ if (!anItemBase)
+ continue;
+
+ aRootItem = itemDynamicCast<MessageModel_ItemRoot> (anItemBase);
+ if (aRootItem)
+ break;
+
+ aReportItem = itemDynamicCast<MessageModel_ItemReport> (anItemBase);
+ if (aReportItem)
+ break;
+
+ anAlertItem = itemDynamicCast<MessageModel_ItemAlert> (anItemBase);
+ if (anAlertItem)
+ break;
+ }
+
+ if (aReportItem && !aReportItem->GetReport().IsNull())
+ {
+ theMenu->addAction (myActions[MessageModel_ActionType_TestMetric]);
+ theMenu->addAction (myActions[MessageModel_ActionType_TestProperties]);
+ theMenu->addAction (myActions[MessageModel_ActionType_TestMessenger]);
+ theMenu->addAction (myActions[MessageModel_ActionType_TestReportTree]);
+ theMenu->addAction (myActions[MessageModel_ActionType_TestReportTree2]);
+
+ bool isReportEnabled = aReportItem->GetReport()->IsActiveInMessenger();
+
+ myActions[MessageModel_ActionType_TestMetric]->setEnabled (isReportEnabled);
+ myActions[MessageModel_ActionType_TestProperties]->setEnabled (isReportEnabled);
+ myActions[MessageModel_ActionType_TestMessenger]->setEnabled (isReportEnabled);
+ myActions[MessageModel_ActionType_TestReportTree]->setEnabled (isReportEnabled);
+ myActions[MessageModel_ActionType_TestReportTree2]->setEnabled (isReportEnabled);
+ }
+ theMenu->addSeparator();
+}
+
+// =======================================================================
+// function : getSelectedReport
+// purpose :
+// =======================================================================
+Handle(Message_Report) MessageView_ActionsTest::getSelectedReport (QModelIndex& theReportIndex) const
+{
+ MessageModel_ItemReportPtr aReportItem;
+ QModelIndexList aSelectedIndices = mySelectionModel->selectedIndexes();
+ for (QModelIndexList::const_iterator aSelIt = aSelectedIndices.begin(); aSelIt != aSelectedIndices.end(); aSelIt++)
+ {
+ QModelIndex anIndex = *aSelIt;
+ if (anIndex.column() != 0)
+ continue;
+
+ TreeModel_ItemBasePtr anItemBase = TreeModel_ModelBase::GetItemByIndex (anIndex);
+ if (!anItemBase)
+ continue;
+
+ aReportItem = itemDynamicCast<MessageModel_ItemReport> (anItemBase);
+ theReportIndex = anIndex;
+ if (aReportItem)
+ break;
+ }
+ if (!aReportItem)
+ return NULL;
+
+ return aReportItem->GetReport();
+}
+
+// =======================================================================
+// function : OnTestMetric
+// purpose :
+// =======================================================================
+void MessageView_ActionsTest::OnTestMetric()
+{
+#ifdef DEBUG_ALERTS
+ QModelIndex aReportIndex;
+ Handle(Message_Report) aReport = getSelectedReport (aReportIndex);
+ if (aReport.IsNull())
+ return;
+
+ OCCT_ADD_MESSAGE_LEVEL_SENTRY ("MessageModel_Actions::OnTestMetric()");
+ unsigned int start_time = clock();
+ //Standard_Real aSystemSeconds, aCurrentSeconds;
+ //OSD_Chronometer::GetThreadCPU (aCurrentSeconds, aSystemSeconds);
+
+ Standard_Integer aCounter = 1500;//0;
+ Standard_Real aValue = 0., aValue2 = 0.1;
+
+ double* aMemValue;
+ for (int aTopIt = 0; aTopIt < 4; aTopIt++)
+ {
+ Message::SendInfo() << "Calculate";
+ for (int j = 0; j < aCounter; j++)
+ {
+ for (int i = 0; i < aCounter; i++)
+ {
+ aValue = (aValue * 2. + 3.) * 0.5 - 0.3 * 0.5;
+
+ Standard_Real aValue3 = aValue + aValue2 * 0.2;
+ (void)aValue3;
+
+ aMemValue = new double;
+ }
+ }
+ }
+
+ //((MessageModel_TreeModel*)mySelectionModel->model())->EmitLayoutChanged();
+
+ myTreeModel->UpdateTreeModel();
+
+ //Standard_Real aSystemSeconds1, aCurrentSeconds1;
+ //OSD_Chronometer::GetThreadCPU (aCurrentSeconds1, aSystemSeconds1);
+
+ //std::cout << aValue << std::endl;
+ //std::cout << "user time = " << aCurrentSeconds1 - aCurrentSeconds
+ // << ", system time = " << aSystemSeconds1 - aSystemSeconds << std::endl;
+
+ unsigned int end_time = clock();
+ std::cout << "clock() = " << end_time - start_time << std::endl;
+#endif
+}
+
+// =======================================================================
+// function : OnTestPropertyPanel
+// purpose :
+// =======================================================================
+void MessageView_ActionsTest::OnTestPropertyPanel()
+{
+#ifdef DEBUG_ALERTS
+ QModelIndex aReportIndex;
+ Handle(Message_Report) aReport = getSelectedReport (aReportIndex);
+ if (aReport.IsNull())
+ return;
+
+ OCCT_ADD_MESSAGE_LEVEL_SENTRY ("MessageModel_Actions::OnTestPropertyPanel()");
+
+ OCCT_SEND_MESSAGE ("Values")
+ OCCT_SEND_MESSAGE ("Values2")
+ // gp_XYZ
+ {
+ gp_XYZ aCoords (1.3, 2.3, 3.4);
+ OCCT_SEND_DUMPJSON (&aCoords, "gp_XYZ")
+ }
+ // gp_Dir
+ {
+ gp_Dir aDir (0.3, 0.3, 0.4);
+ OCCT_SEND_DUMPJSON (&aDir, "gp_Dir")
+ }
+ // gp_Ax1
+ {
+ gp_Ax1 aCoords (gp_Pnt (1.3, 2.3, 3.4), gp_Dir (0.3, 0.3, 0.4));
+ OCCT_SEND_DUMPJSON (&aCoords, "gp_Ax1")
+ }
+ // gp_Ax2
+ {
+ gp_Ax2 aCoords (gp_Pnt (10.3, 20.3, 30.4), gp_Dir (0.3, 0.3, 0.4));
+ OCCT_SEND_DUMPJSON (&aCoords, "gp_Ax2")
+ }
+ // gp_Ax3
+ {
+ gp_Ax3 aPln (gp_Pnt (10., 20., 15.), gp_Dir (0., 0., 1.), gp_Dir (1., 0., 0.));
+ OCCT_SEND_DUMPJSON (&aPln, "gp_Ax3")
+ }
+ // gp_Trsf
+ {
+ gp_Trsf aTrsf;
+ aTrsf.SetRotation (gp::OZ(), 0.3);
+ aTrsf.SetTranslationPart (gp_Vec (15., 15., 15.));
+ aTrsf.SetScaleFactor (3.);
+
+ OCCT_SEND_DUMPJSON (&aTrsf, "gp_Trsf")
+ }
+ // Bnd_Box
+ {
+ Bnd_Box aBox (gp_Pnt (20., 15., 10.), gp_Pnt (25., 20., 15.));
+ OCCT_SEND_DUMPJSON (&aBox, "Bnd_Box")
+ }
+ // Bnd_OBB
+ {
+ Bnd_OBB anOBB (gp_Pnt (-10., -15., -10.), gp_Dir (1., 0., 0.), gp_Dir (0., 1., 0.), gp_Dir (0., 0., 1.),
+ 5., 10., 5.);
+ OCCT_SEND_DUMPJSON (&anOBB, "Bnd_OBB");
+ }
+ // Quantity_ColorRGBA
+ {
+ Quantity_ColorRGBA aColor (0.2f, 0.8f, 0.8f, 0.2f);
+ OCCT_SEND_DUMPJSON (&aColor, "Quantity_ColorRGBA");
+ }
+ // Quantity_Color
+ {
+ Quantity_Color aColor (0.8, 0.8, 0.8, Quantity_TOC_RGB);
+ OCCT_SEND_DUMPJSON (&aColor, "Quantity_Color");
+ }
+
+ // stream of some table values
+ {
+ Standard_SStream aStream;
+ OCCT_DUMP_FIELD_VALUES_NUMERICAL (aStream, "value_1", 1, 100);
+ OCCT_DUMP_FIELD_VALUES_STRING (aStream, "value_2", 2, "value_1", "value_2");
+ OCCT_SEND_STREAM (aStream, "Table: Name to value");
+ }
+
+ // SHAPE messages
+ {
+ BRepBuilderAPI_MakeEdge aBuilder (gp_Pnt (0., 0., 0.), gp_Pnt (20., 10., 20.));
+ TopoDS_Shape aShape = aBuilder.Shape();
+
+ MESSAGE_INFO_SHAPE (aShape, "Shape message edge");
+ }
+
+ myTreeModel->UpdateTreeModel();
+#endif
+}
+
+// =======================================================================
+// function : createShapeOnLevel
+// purpose :
+// =======================================================================
+void createShapeOnLevel()
+{
+ OCCT_ADD_MESSAGE_LEVEL_SENTRY ("createShapeOnLevel")
+
+ Message_Messenger::StreamBuffer sout = Message::SendInfo();
+
+ BRepBuilderAPI_MakeEdge aBuilder (gp_Pnt (0., 0., 0.), gp_Pnt (20., 10., 20.));
+ TopoDS_Shape aShape = aBuilder.Shape();
+
+ MESSAGE_INFO_SHAPE (aShape, "Shape message edge ON LEVEL");
+ //sout << "Shape message edge" << aShape;
+}
+
+// =======================================================================
+// function : createShape
+// purpose :
+// =======================================================================
+void createShape()
+{
+ Message_Messenger::StreamBuffer sout = Message::SendInfo();
+
+ BRepBuilderAPI_MakeEdge aBuilder (gp_Pnt (0., 0., 0.), gp_Pnt (20., 10., 20.));
+ TopoDS_Shape aShape = aBuilder.Shape();
+
+ MESSAGE_INFO_SHAPE (aShape, "Shape message edge");
+ //sout << "Shape message edge" << aShape;
+
+ createShapeOnLevel();
+}
+
+// =======================================================================
+// function : OnTestMessenger
+// purpose :
+// =======================================================================
+void MessageView_ActionsTest::OnTestMessenger()
+{
+ // string messages
+ Message_Messenger::StreamBuffer sout = Message::SendInfo();
+ Standard_Integer aTraceLevel_prev = Message::DefaultMessenger()->TraceLevel();
+ Message::DefaultMessenger()->SetTraceLevel (1);
+
+ OCCT_ADD_MESSAGE_LEVEL_SENTRY ("MessageModel_Actions::OnTestMessenger()")
+
+ sout << "IGESBasic_Hierarchy" << std::endl;
+ sout << "Number of property valueaMessenger : " << 15 << std::endl;
+ sout << "Line Font : " << 1 << std::endl << "View Number : " << 3 << std::endl;
+ sout << "Entity level : " << 1 << std::endl;
+ sout << "Blank statuaMessenger : " << 0 << std::endl;
+ sout << "Line weight : " << 14 << std::endl;
+ sout << "Color number : " << 5 << std::endl;
+
+ // stream messages
+ // gp_XYZ
+ {
+ gp_XYZ aCoords (1.3, 2.3, 3.4);
+ Standard_SStream aStream;
+ //aCoords.DumpJson (aStream);
+ //sout << "gp_XYZ" << aStream << std::endl;
+ aCoords.DumpJson (sout);
+ }
+ // Bnd_Box
+ {
+ Bnd_Box aBox (gp_Pnt (20., 15., 10.), gp_Pnt (25., 20., 15.));
+ Standard_SStream aStream;
+ //aBox.DumpJson (aStream);
+ //sout << "Bnd_Box" << aStream;
+ aBox.DumpJson (sout);
+ }
+
+ // object messages
+ Handle(Standard_Transient) anObject = new Message_AlertExtended();
+ //sout << "Message_AlertExtended" << anObject;
+
+ // shape messages
+ {
+ BRepBuilderAPI_MakeEdge aBuilder (gp_Pnt (0., 0., 0.), gp_Pnt (20., 10., 20.));
+ TopoDS_Shape aShape = aBuilder.Shape();
+
+ MESSAGE_INFO_SHAPE (aShape, "Shape message edge");
+ //sout << "Shape message edge" << aShape;
+
+ createShape();
+ }
+ myTreeModel->UpdateTreeModel();
+ Message::DefaultMessenger()->SetTraceLevel (aTraceLevel_prev);
+}
+
+// =======================================================================
+// function : levelAlerts
+// purpose :
+// =======================================================================
+void levelAlerts (const int theCurrentLevel, const int theTopLevel)
+{
+ if (theTopLevel - theCurrentLevel <= 0)
+ return;
+
+ OCCT_ADD_MESSAGE_LEVEL_SENTRY (TCollection_AsciiString ("Level: " ) + theCurrentLevel)
+
+ Message_Messenger::StreamBuffer sout = Message::SendInfo();
+ sout << "Alert(" << theCurrentLevel << "): " << 1 << ", " << 2 << std::endl;
+ sout << "Alert(" << theCurrentLevel << "): " << 3 << ", " << 4 << std::endl;
+
+ //for (int i = 0; i < 2; i++)
+ levelAlerts (theCurrentLevel + 1, theTopLevel);
+
+ sout << "Alert(" << theCurrentLevel << "): " << 4 << ", " << 5 << std::endl;
+}
+
+// =======================================================================
+// function : levelAlert
+// purpose :
+// =======================================================================
+void levelAlert (const int theCurrentLevel, const int theTopLevel)
+{
+ if (theTopLevel - theCurrentLevel <= 0)
+ return;
+
+ OCCT_ADD_MESSAGE_LEVEL_SENTRY ("levelAlert")
+
+ Message_Messenger::StreamBuffer sout = Message::SendInfo();
+ sout << "Level: " << theCurrentLevel << "(Single, no alerts on the level)" << std::endl;
+
+ //for (int i = 0; i < 2; i++)
+ levelAlerts (theCurrentLevel + 1, theTopLevel);
+}
+
+// =======================================================================
+// function : OnTestReportTree
+// purpose :
+// =======================================================================
+void MessageView_ActionsTest::OnTestReportTree()
+{
+ OCCT_ADD_MESSAGE_LEVEL_SENTRY ("MessageModel_Actions::OnTestReportTree()")
+ Message_Messenger::StreamBuffer sout = Message::SendInfo();
+
+ // string messages
+ //sout << "Alert: " << 1 << std::endl;
+ //sout << "Alert: " << 2 << std::endl;
+
+ int aTopLevel = 3;
+ levelAlerts (1, aTopLevel);
+
+ //sout << "Alert: " << 3 << std::endl;
+ //levelAlerts (1, aTopLevel);
+
+ sout << "Alert: " << 4 << std::endl;
+ levelAlert (1, aTopLevel);
+
+ myTreeModel->UpdateTreeModel();
+}
+
+// =======================================================================
+// function : OnTestReportTree2
+// purpose :
+// =======================================================================
+void MessageView_ActionsTest::OnTestReportTree2()
+{
+ OCCT_ADD_MESSAGE_LEVEL_SENTRY ("MessageModel_Actions::OnTestReportTree()")
+ Message_Messenger::StreamBuffer sout = Message::SendInfo();
+
+ // string messages
+ //sout << "Alert: " << 1 << std::endl;
+ //sout << "Alert: " << 2 << std::endl;
+
+ int aTopLevel = 3;
+ levelAlerts (1, aTopLevel);
+
+ //sout << "Alert: " << 3 << std::endl;
+ //levelAlerts (1, aTopLevel);
+
+ //sout << "Alert: " << 4 << std::endl;
+ //levelAlert (1, aTopLevel);
+
+ myTreeModel->UpdateTreeModel();
+}
--- /dev/null
+// Copyright (c) 2020 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 MessageView_ActionsTest_H
+#define MessageView_ActionsTest_H
+
+#include <Standard.hxx>
+#include <Standard_Handle.hxx>
+#include <Standard_Transient.hxx>
+
+#include <inspector/MessageModel_ActionType.hxx>
+
+#include <Standard_WarningsDisable.hxx>
+#include <QObject>
+#include <QMap>
+#include <QModelIndexList>
+#include <QPoint>
+#include <QString>
+#include <Standard_WarningsRestore.hxx>
+
+class Message_Report;
+class MessageModel_TreeModel;
+class QItemSelectionModel;
+
+class QAction;
+class QWidget;
+class QMenu;
+
+//! \class MessageView_ActionsTest
+//! Window that unites all MessageView controls.
+class MessageView_ActionsTest : public QObject
+{
+ Q_OBJECT
+public:
+
+ //! Constructor
+ MessageView_ActionsTest (QWidget* theParent, MessageModel_TreeModel* theTreeModel, QItemSelectionModel* theModel);
+
+ //! Destructor
+ virtual ~MessageView_ActionsTest() {}
+
+ //! Fills popup menu with actions depending on the current selection
+ //! \param theSelectedIndices tree model selected indices
+ //! \param theMenu menu to be filled
+ Standard_EXPORT void AddMenuActions (const QModelIndexList& theSelectedIndices, QMenu* theMenu);
+
+public slots:
+ //! Sending several alerts to check metric of message-alert-tool mechanizm
+ void OnTestMetric();
+
+ //! Sending several alerts to check property panel/presentations of message-alert-tool mechanizm
+ void OnTestPropertyPanel();
+
+ //! Sending several alerts to check property panel/presentations of messenger-alert-tool mechanizm
+ void OnTestMessenger();
+
+ //! Check tree of alerts
+ void OnTestReportTree();
+
+ //! Check tree of alerts
+ void OnTestReportTree2();
+
+protected:
+ //! Returns report of selected tree view item if a report item is selected
+ //! \param theReportIndex tree model index of the found report
+ //! \return report instance or NULL
+ Handle(Message_Report) getSelectedReport (QModelIndex& theReportIndex) const;
+
+protected:
+ MessageModel_TreeModel* myTreeModel; //< tree model
+ QItemSelectionModel* mySelectionModel; //< selection model
+ QMap<MessageModel_ActionType, QAction*> myActions; //!< container of all actions
+};
+
+#endif
--- /dev/null
+// 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.
+
+#include <inspector/MessageView_Communicator.hxx>
+
+
+// =======================================================================
+// function : CreateCommunicator
+// purpose : Creates a communicator by the library loading
+// =======================================================================
+Standard_EXPORTEXTERNC TInspectorAPI_Communicator* CreateCommunicator()
+{
+ return new MessageView_Communicator();
+}
--- /dev/null
+// 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 MessageView_Communicator_H
+#define MessageView_Communicator_H
+
+#include <inspector/MessageView_Window.hxx>
+#include <inspector/TInspectorAPI_Communicator.hxx>
+
+//! \class MessageView_Communicator.
+//! \brief This is a connector from TInspector application to MessageView window
+class MessageView_Communicator : public TInspectorAPI_Communicator
+{
+public:
+
+ //! Constructor
+ MessageView_Communicator() : TInspectorAPI_Communicator(), myWindow (new MessageView_Window (0)) {}
+
+ //! Destructor
+ virtual ~MessageView_Communicator() Standard_OVERRIDE {}
+
+ //! Provides the container with a parent where this container should be inserted.
+ //! If Qt implementation, it should be QWidget with QLayout set inside
+ //! \param theParent a parent class
+ virtual void SetParent (void* theParent) Standard_OVERRIDE { myWindow->SetParent (theParent); }
+
+ //! Sets parameters container, it should be used when the plugin is initialized or in update content
+ //! \param theParameters a parameters container
+ virtual void SetParameters (const Handle(TInspectorAPI_PluginParameters)& theParameters) Standard_OVERRIDE
+ { myWindow->SetParameters (theParameters); }
+
+ //! Provide container for actions available in inspector on general level
+ //! \param theMenu if Qt implementation, it is QMenu object
+ virtual void FillActionsMenu(void* theMenu) Standard_OVERRIDE { myWindow->FillActionsMenu (theMenu); }
+
+ //! Returns plugin preferences, empty implementation by default
+ //! \param theItem container of preference elements
+ virtual void GetPreferences (TInspectorAPI_PreferencesDataMap& theItem) Standard_OVERRIDE
+ { myWindow->GetPreferences (theItem); }
+
+ //! Stores plugin preferences, empty implementation by default
+ //! \param theItem container of preference elements
+ virtual void SetPreferences (const TInspectorAPI_PreferencesDataMap& theItem) Standard_OVERRIDE
+ { myWindow->SetPreferences (theItem); }
+
+ //! Calls update of the plugin's content
+ virtual void UpdateContent() Standard_OVERRIDE { myWindow->UpdateContent(); }
+
+private:
+
+ MessageView_Window* myWindow; //!< current window
+};
+
+#endif
--- /dev/null
+// 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.
+
+#include <inspector/MessageView_VisibilityState.hxx>
+#include <inspector/MessageModel_ItemAlert.hxx>
+
+#include <Message_AlertExtended.hxx>
+#include <Message_AttributeStream.hxx>
+
+#include <TopoDS_AlertAttribute.hxx>
+
+// =======================================================================
+// function : CanBeVisible
+// purpose :
+// =======================================================================
+bool MessageView_VisibilityState::CanBeVisible (const QModelIndex& theIndex) const
+{
+ MessageModel_ItemAlertPtr anAlertItem = getAlertItem (theIndex);
+ if (anAlertItem)
+ {
+ NCollection_List<Handle(Standard_Transient)> aPresentations;
+ anAlertItem->Presentations (aPresentations);
+ if (!aPresentations.IsEmpty())
+ return true;
+ }
+
+ return !Shape (theIndex).IsNull();// || hasTableValues (theIndex);
+}
+
+// =======================================================================
+// function : SetVisible
+// purpose :
+// =======================================================================
+bool MessageView_VisibilityState::SetVisible (const QModelIndex& theIndex, const bool theState, const bool toEmitDataChanged)
+{
+ TopoDS_Shape aShape = Shape (theIndex);
+ if (aShape.IsNull())
+ return false;
+
+ myDisplayer->SetVisible (aShape, theState, myPresentationType);
+
+ if (!theState) {
+ MessageModel_ItemAlertPtr anAlertItem = getAlertItem (theIndex);
+ if (anAlertItem && !anAlertItem->GetCustomShape().IsNull())
+ anAlertItem->SetCustomShape (TopoDS_Shape());
+ }
+
+ if (toEmitDataChanged)
+ {
+ QModelIndex anIndex = theIndex;
+ if (theIndex.column() != TreeModel_ColumnType_Visibility)
+ anIndex = theIndex.model()->index(theIndex.row(), TreeModel_ColumnType_Visibility, theIndex.parent());
+
+ getModel()->EmitDataChanged (anIndex, anIndex);
+ }
+ return true;
+}
+
+// =======================================================================
+// function : IsVisible
+// purpose :
+// =======================================================================
+bool MessageView_VisibilityState::IsVisible (const QModelIndex& theIndex) const
+{
+ return myDisplayer->IsVisible (Shape (theIndex), myPresentationType);
+}
+
+// =======================================================================
+// function : OnClicked
+// purpose :
+// =======================================================================
+void MessageView_VisibilityState::OnClicked (const QModelIndex& theIndex)
+{
+ processClicked (theIndex);
+ emit itemClicked (theIndex);
+}
+
+// =======================================================================
+// function : getAlertItem
+// purpose :
+// =======================================================================
+MessageModel_ItemAlertPtr MessageView_VisibilityState::getAlertItem (const QModelIndex& theIndex) const
+{
+ TreeModel_ItemBasePtr anItemBase = TreeModel_ModelBase::GetItemByIndex (theIndex);
+ if (!anItemBase)
+ return MessageModel_ItemAlertPtr();
+
+ MessageModel_ItemAlertPtr anAlertItem = itemDynamicCast<MessageModel_ItemAlert>(anItemBase);
+ return anAlertItem;
+}
+
+// =======================================================================
+// function : Shape
+// purpose :
+// =======================================================================
+TopoDS_Shape MessageView_VisibilityState::Shape (const QModelIndex& theIndex) const
+{
+ MessageModel_ItemAlertPtr anAlertItem = getAlertItem (theIndex);
+ if (!anAlertItem)
+ return TopoDS_Shape();
+
+ /*if (!anAlertItem->GetCustomShape().IsNull())
+ return anAlertItem->GetCustomShape();
+
+ Handle(Message_Alert) anAlert = anAlertItem->GetAlert();
+ if (anAlert.IsNull())
+ return TopoDS_Shape();
+
+ Handle(Message_AlertExtended) anAlertExtended = Handle(Message_AlertExtended)::DownCast(anAlert);
+ if (anAlertExtended.IsNull())
+ return TopoDS_Shape();
+
+ Handle(TopoDS_AlertAttribute) aShapeAttribute = Handle(TopoDS_AlertAttribute)::DownCast (anAlertExtended->Attribute());
+ if (!aShapeAttribute.IsNull())
+ return aShapeAttribute->GetShape();
+ */
+ return TopoDS_Shape();
+}
+
+// =======================================================================
+// function : hasTableValues
+// purpose :
+// =======================================================================
+bool MessageView_VisibilityState::hasTableValues (const QModelIndex& theIndex) const
+{
+ MessageModel_ItemAlertPtr anAlertItem = getAlertItem (theIndex);
+ if (!anAlertItem)
+ return false;
+
+ Handle(Message_Alert) anAlert = anAlertItem->GetAlert();
+ if (anAlert.IsNull())
+ return false;
+
+ if (anAlert->IsKind (STANDARD_TYPE (Message_AttributeStream)))
+ return true;
+
+ return false;
+}
\ No newline at end of file
--- /dev/null
+// 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 MessageView_VisibilityState_H
+#define MessageView_VisibilityState_H
+
+#include <inspector/TreeModel_VisibilityState.hxx>
+
+#include <inspector/MessageModel_ItemAlert.hxx>
+
+#include <inspector/View_Displayer.hxx>
+
+#include <Standard.hxx>
+#include <Standard_Macro.hxx>
+#include <TopoDS_Shape.hxx>
+
+class TreeModel_ModelBase;
+
+//! \class MessageView_VisibilityState
+//! \brief Class provides connection between model and visualization control
+class MessageView_VisibilityState : public QObject, public TreeModel_VisibilityState
+{
+ Q_OBJECT
+public:
+ //! Constructor
+ MessageView_VisibilityState (TreeModel_ModelBase* theModel)
+ : TreeModel_VisibilityState (theModel), myPresentationType (View_PresentationType_Main) {}
+
+ //! Destructor
+ ~MessageView_VisibilityState() {}
+
+ //! Sets current displayer
+ //! \theDisplayer class that provides connection to visualized objects
+ void SetDisplayer (View_Displayer* theDisplayer) { myDisplayer = theDisplayer; }
+
+ //! Sets presentation type for displayer
+ //! \param theType type value
+ void SetPresentationType (const View_PresentationType theType) { myPresentationType = theType; }
+
+ //! Returns true if visibility of the item can be changed
+ //! \param theIndex tree model index
+ //! \return boolean value
+ Standard_EXPORT virtual bool CanBeVisible (const QModelIndex& theIndex) const Standard_OVERRIDE;
+
+ //! Sets visibility state
+ //! \theIndex tree model index
+ //! \param theState visibility state
+ //! \param toEmitDataChanged boolean flag whether emit of the model should be done immediatelly
+ //! \return true if state is changed
+ Standard_EXPORT virtual bool SetVisible (const QModelIndex& theIndex, const bool theState, const bool toEmitDataChanged) Standard_OVERRIDE;
+
+ //! Returns visibility state value
+ Standard_EXPORT virtual bool IsVisible (const QModelIndex& theIndex) const Standard_OVERRIDE;
+
+public slots:
+ //! Processes the mouse clicked on the index.
+ //! It changes the item visibility if model allows to change it.
+ //! \theIndex tree model index
+ void OnClicked (const QModelIndex& theIndex);
+
+signals:
+ //! Signal after OnClicked is performed
+ //! \theIndex tree model index
+ void itemClicked (const QModelIndex& theIndex);
+
+protected:
+ //! Gets the alert item
+ //! \theIndex tree model index
+ //! \return item or NULL
+ MessageModel_ItemAlertPtr getAlertItem (const QModelIndex& theIndex) const;
+
+ //! Gets shape of the view model by the parameter index if it has a shape
+ //! \param theIndex tree model index
+ //! \return shape instance
+ TopoDS_Shape Shape (const QModelIndex& theIndex) const;
+
+ //! Returns true if alert of the item has table values
+ //! \param theIndex tree model index
+ //! \return boolean result
+ bool hasTableValues (const QModelIndex& theIndex) const;
+
+private:
+ View_Displayer* myDisplayer; //! view displayer
+ View_PresentationType myPresentationType; //! presentation type
+};
+
+#endif
--- /dev/null
+// 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.
+
+#include <inspector/MessageView_Window.hxx>
+#include <inspector/MessageView_VisibilityState.hxx>
+#include <inspector/MessageView_ActionsTest.hxx>
+
+#include <inspector/MessageModel_Actions.hxx>
+#include <inspector/MessageModel_ItemAlert.hxx>
+#include <inspector/MessageModel_ItemReport.hxx>
+#include <inspector/MessageModel_ItemRoot.hxx>
+#include <inspector/MessageModel_Tools.hxx>
+#include <inspector/MessageModel_TreeModel.hxx>
+
+#include <inspector/TreeModel_ContextMenu.hxx>
+#include <inspector/TreeModel_Tools.hxx>
+
+#include <inspector/ViewControl_PropertyView.hxx>
+#include <inspector/ViewControl_TableModelValues.hxx>
+#include <inspector/ViewControl_TreeView.hxx>
+#include <inspector/Convert_Tools.hxx>
+
+#include <inspector/View_Viewer.hxx>
+#include <inspector/View_Widget.hxx>
+
+#include <AIS_Shape.hxx>
+#include <Graphic3d_Camera.hxx>
+#include <OSD_Environment.hxx>
+#include <OSD_Directory.hxx>
+#include <OSD_Protection.hxx>
+#include <Message.hxx>
+#include <TCollection_AsciiString.hxx>
+
+#define DEBUG_ALERTS
+
+#include <XmlDrivers_MessageReportStorage.hxx>
+
+#include <inspector/ViewControl_Tools.hxx>
+#include <inspector/View_Displayer.hxx>
+#include <inspector/View_ToolBar.hxx>
+#include <inspector/View_Widget.hxx>
+#include <inspector/View_Window.hxx>
+#include <inspector/View_Viewer.hxx>
+
+#include <BRep_Builder.hxx>
+#include <BRepTools.hxx>
+#include <OSD_File.hxx>
+#include <OSD_Path.hxx>
+
+#include <QApplication>
+#include <QAction>
+#include <QComboBox>
+#include <QDockWidget>
+#include <QDir>
+#include <QFile>
+#include <QFileDialog>
+#include <QHeaderView>
+#include <QMainWindow>
+#include <QMenu>
+#include <QMessageBox>
+#include <QPlainTextEdit>
+#include <QPushButton>
+#include <QTextEdit>
+#include <QTextStream>
+#include <QToolBar>
+#include <QToolButton>
+#include <QTreeView>
+#include <QWidget>
+#include <QVBoxLayout>
+
+const int DEFAULT_TEXT_VIEW_WIDTH = 800;// 800;
+const int DEFAULT_TEXT_VIEW_HEIGHT = 700;
+const int DEFAULT_TEXT_VIEW_POSITION_X = 430;
+const int DEFAULT_TEXT_VIEW_POSITION_Y = 30;
+const int DEFAULT_TEXT_VIEW_DELTA = 100;
+
+const int DEFAULT_SHAPE_VIEW_WIDTH = 400;// 900;
+const int DEFAULT_SHAPE_VIEW_HEIGHT = 450;
+const int DEFAULT_SHAPE_VIEW_POSITION_X = 60;
+const int DEFAULT_SHAPE_VIEW_POSITION_Y = 60;
+
+const int DEFAULT_DETACH_POSITION_X = 5;
+const int DEFAULT_DETACH_POSITION_Y = 450;
+
+const int MESSAGEVIEW_DEFAULT_TREE_VIEW_WIDTH = 950; //600
+const int MESSAGEVIEW_DEFAULT_TREE_VIEW_HEIGHT = 500;
+
+const int MESSAGEVIEW_DEFAULT_VIEW_WIDTH = 200;// 400;
+const int MESSAGEVIEW_DEFAULT_VIEW_HEIGHT = 300;// 1000;
+
+#include <Prs3d_PointAspect.hxx>
+#include <Prs3d_ShadingAspect.hxx>
+Handle(Prs3d_Drawer) GetPreviewAttributes (const Handle(AIS_InteractiveContext)& theContext)
+{
+ Handle(Prs3d_Drawer) myDrawer = new Prs3d_Drawer();
+ myDrawer->Link (theContext->DefaultDrawer());
+
+ Quantity_Color aColor(Quantity_NOC_TOMATO);//Quantity_NOC_GREENYELLOW));//Quantity_NOC_BLUE1));
+ Standard_ShortReal aTransparency = 0.8;
+
+ // point parameters
+ myDrawer->SetPointAspect (new Prs3d_PointAspect (Aspect_TOM_O_PLUS, aColor, 3.0));
+
+ // shading parameters
+ Graphic3d_MaterialAspect aShadingMaterial;
+ aShadingMaterial.SetReflectionModeOff (Graphic3d_TOR_SPECULAR);
+ aShadingMaterial.SetMaterialType (Graphic3d_MATERIAL_ASPECT);
+
+ myDrawer->SetShadingAspect (new Prs3d_ShadingAspect());
+ myDrawer->ShadingAspect()->Aspect()->SetInteriorStyle (Aspect_IS_SOLID);
+ myDrawer->ShadingAspect()->SetColor (aColor);
+ myDrawer->ShadingAspect()->SetMaterial (aShadingMaterial);
+
+ myDrawer->ShadingAspect()->Aspect()->ChangeFrontMaterial().SetTransparency (aTransparency);
+ myDrawer->ShadingAspect()->Aspect()->ChangeBackMaterial() .SetTransparency (aTransparency);
+ myDrawer->SetTransparency (aTransparency);
+
+ // common parameters
+ myDrawer->SetZLayer (Graphic3d_ZLayerId_Topmost);
+
+ return myDrawer;
+}
+
+// =======================================================================
+// function : Constructor
+// purpose :
+// =======================================================================
+MessageView_Window::MessageView_Window (QWidget* theParent)
+: QObject (theParent)
+{
+ myMainWindow = new QMainWindow (theParent);
+
+ myTreeView = new ViewControl_TreeView (myMainWindow);
+ ((ViewControl_TreeView*)myTreeView)->SetPredefinedSize (QSize (MESSAGEVIEW_DEFAULT_TREE_VIEW_WIDTH,
+ MESSAGEVIEW_DEFAULT_TREE_VIEW_HEIGHT));
+ MessageModel_TreeModel* aModel = new MessageModel_TreeModel (myTreeView);
+ aModel->InitColumns();
+ //aModel->SetReversed (Standard_True);
+
+ connect (myTreeView->header(), SIGNAL (sectionResized (int, int, int)),
+ this, SLOT(onHeaderResized (int, int, int)));
+
+ myTreeView->setModel (aModel);
+ MessageView_VisibilityState* aVisibilityState = new MessageView_VisibilityState (aModel);
+ aModel->SetVisibilityState (aVisibilityState);
+ connect (aVisibilityState, SIGNAL (itemClicked (const QModelIndex&)), this, SLOT(onTreeViewVisibilityClicked(const QModelIndex&)));
+
+ TreeModel_Tools::UseVisibilityColumn (myTreeView);
+ TreeModel_Tools::SetDefaultHeaderSections (myTreeView);
+
+ QItemSelectionModel* aSelectionModel = new QItemSelectionModel (aModel);
+ myTreeView->setSelectionMode (QAbstractItemView::ExtendedSelection);
+ myTreeView->setSelectionModel (aSelectionModel);
+ connect (aSelectionModel, SIGNAL (selectionChanged (const QItemSelection&, const QItemSelection&)),
+ this, SLOT (onTreeViewSelectionChanged (const QItemSelection&, const QItemSelection&)));
+
+ myTreeViewActions = new MessageModel_Actions (myMainWindow, aModel, aSelectionModel);
+ myTestViewActions = new MessageView_ActionsTest (myMainWindow, aModel, aSelectionModel);
+
+ myTreeView->setContextMenuPolicy (Qt::CustomContextMenu);
+ connect (myTreeView, SIGNAL (customContextMenuRequested (const QPoint&)),
+ this, SLOT (onTreeViewContextMenuRequested (const QPoint&)));
+ //new TreeModel_ContextMenu (myTreeView);
+
+ connect (myTreeView->header(), SIGNAL (sectionResized (int, int, int)),
+ this, SLOT(onHeaderResized (int, int, int)));
+
+ QModelIndex aParentIndex = myTreeView->model()->index (0, 0);
+ myTreeView->setExpanded (aParentIndex, true);
+
+ myMainWindow->setCentralWidget (myTreeView);
+
+ // property view
+ myPropertyView = new ViewControl_PropertyView (myMainWindow);
+ myPropertyPanelWidget = new QDockWidget (tr ("PropertyPanel"), myMainWindow);
+ myPropertyPanelWidget->setObjectName (myPropertyPanelWidget->windowTitle());
+ myPropertyPanelWidget->setTitleBarWidget (new QWidget(myMainWindow));
+ myPropertyPanelWidget->setWidget (myPropertyView->GetControl());
+ myMainWindow->addDockWidget (Qt::RightDockWidgetArea, myPropertyPanelWidget);
+ connect (myPropertyPanelWidget->toggleViewAction(), SIGNAL(toggled(bool)), this, SLOT (onPropertyPanelShown (bool)));
+ connect (myPropertyView, SIGNAL (propertyViewDataChanged()), this, SLOT (onPropertyViewDataChanged()));
+
+
+ // view
+ myViewWindow = new View_Window (myMainWindow, false);
+ connect (myViewWindow, SIGNAL(eraseAllPerformed()), this, SLOT(onEraseAllPerformed()));
+ aVisibilityState->SetDisplayer (myViewWindow->Displayer());
+ aVisibilityState->SetPresentationType (View_PresentationType_Main);
+ myViewWindow->ViewWidget()->SetPredefinedSize (MESSAGEVIEW_DEFAULT_VIEW_WIDTH, MESSAGEVIEW_DEFAULT_VIEW_HEIGHT);
+
+ myViewDockWidget = new QDockWidget (tr ("View"), myMainWindow);
+ myViewDockWidget->setObjectName (myViewDockWidget->windowTitle());
+ myViewDockWidget->setWidget (myViewWindow);
+ myMainWindow->addDockWidget (Qt::RightDockWidgetArea, myViewDockWidget);
+
+ myMainWindow->resize (DEFAULT_SHAPE_VIEW_WIDTH, DEFAULT_SHAPE_VIEW_HEIGHT);
+ myMainWindow->move (DEFAULT_SHAPE_VIEW_POSITION_X, DEFAULT_SHAPE_VIEW_POSITION_Y);
+
+ updateVisibleColumns();
+}
+
+// =======================================================================
+// function : SetParent
+// purpose :
+// =======================================================================
+void MessageView_Window::SetParent (void* theParent)
+{
+ QWidget* aParent = (QWidget*)theParent;
+ if (aParent)
+ {
+ QLayout* aLayout = aParent->layout();
+ if (aLayout)
+ aLayout->addWidget (GetMainWindow());
+ }
+ else
+ {
+ GetMainWindow()->setParent (0);
+ GetMainWindow()->setVisible (true);
+ }
+}
+
+// =======================================================================
+// function : FillActionsMenu
+// purpose :
+// =======================================================================
+void MessageView_Window::FillActionsMenu (void* theMenu)
+{
+ QMenu* aMenu = (QMenu*)theMenu;
+ QList<QDockWidget*> aDockwidgets = myMainWindow->findChildren<QDockWidget*>();
+ for (QList<QDockWidget*>::iterator it = aDockwidgets.begin(); it != aDockwidgets.end(); ++it)
+ {
+ QDockWidget* aDockWidget = *it;
+ if (aDockWidget->parentWidget() == myMainWindow)
+ aMenu->addAction (aDockWidget->toggleViewAction());
+ }
+}
+
+// =======================================================================
+// function : GetPreferences
+// purpose :
+// =======================================================================
+void MessageView_Window::GetPreferences (TInspectorAPI_PreferencesDataMap& theItem)
+{
+ theItem.Clear();
+ theItem.Bind ("geometry", TreeModel_Tools::ToString (myMainWindow->saveState()).toStdString().c_str());
+
+ QMap<QString, QString> anItems;
+ TreeModel_Tools::SaveState (myTreeView, anItems);
+ for (QMap<QString, QString>::const_iterator anItemsIt = anItems.begin(); anItemsIt != anItems.end(); anItemsIt++)
+ {
+ theItem.Bind (anItemsIt.key().toStdString().c_str(), anItemsIt.value().toStdString().c_str());
+ }
+
+ anItems.clear();
+ View_Window::SaveState(myViewWindow, anItems);
+ for (QMap<QString, QString>::const_iterator anItemsIt = anItems.begin(); anItemsIt != anItems.end(); anItemsIt++)
+ {
+ theItem.Bind (anItemsIt.key().toStdString().c_str(), anItemsIt.value().toStdString().c_str());
+ }
+}
+
+// =======================================================================
+// function : SetPreferences
+// purpose :
+// =======================================================================
+void MessageView_Window::SetPreferences (const TInspectorAPI_PreferencesDataMap& theItem)
+{
+ for (TInspectorAPI_IteratorOfPreferencesDataMap anItemIt (theItem); anItemIt.More(); anItemIt.Next())
+ {
+ if (anItemIt.Key().IsEqual ("geometry"))
+ myMainWindow->restoreState (TreeModel_Tools::ToByteArray (anItemIt.Value().ToCString()));
+ else if (TreeModel_Tools::RestoreState (myTreeView, anItemIt.Key().ToCString(), anItemIt.Value().ToCString()))
+ continue;
+ else if (myViewWindow && View_Window::RestoreState(myViewWindow, anItemIt.Key().ToCString(), anItemIt.Value().ToCString()))
+ continue;
+ }
+}
+
+// =======================================================================
+// function : UpdateContent
+// purpose :
+// =======================================================================
+void MessageView_Window::UpdateContent()
+{
+ bool isUpdated = false;
+ TCollection_AsciiString aName = "TKMessageView";
+ if (myParameters->FindParameters (aName))
+ {
+ NCollection_List<Handle(Standard_Transient)> aParameters = myParameters->Parameters (aName);
+ // Init will remove from parameters those, that are processed only one time (TShape)
+ Init (aParameters);
+ myParameters->SetParameters (aName, aParameters);
+ isUpdated = true;
+ }
+ if (myParameters->FindFileNames (aName))
+ {
+ for (NCollection_List<TCollection_AsciiString>::Iterator aFilesIt (myParameters->FileNames (aName));
+ aFilesIt.More(); aFilesIt.Next())
+ openFile (aFilesIt.Value());
+
+ NCollection_List<TCollection_AsciiString> aNames;
+ myParameters->SetFileNames (aName, aNames);
+ isUpdated = true;
+ }
+ Handle(Message_Report) aDefaultReport = Message::DefaultReport();
+ MessageModel_TreeModel* aViewModel = dynamic_cast<MessageModel_TreeModel*> (myTreeView->model());
+ if (!aDefaultReport.IsNull() && !aViewModel->HasReport (aDefaultReport))
+ {
+ addReport (aDefaultReport);
+ }
+ // reload report of selected item
+ //onReloadReport();
+
+ updateTreeModel();
+ updateVisibleColumns();
+}
+
+// =======================================================================
+// function : Init
+// purpose :
+// =======================================================================
+void MessageView_Window::Init (NCollection_List<Handle(Standard_Transient)>& theParameters)
+{
+ Handle(AIS_InteractiveContext) aContext;
+ NCollection_List<Handle(Standard_Transient)> aParameters;
+
+ Handle(Graphic3d_Camera) aViewCamera;
+
+ for (NCollection_List<Handle(Standard_Transient)>::Iterator aParamsIt (theParameters);
+ aParamsIt.More(); aParamsIt.Next())
+ {
+ Handle(Standard_Transient) anObject = aParamsIt.Value();
+ Handle(Message_Report) aMessageReport = Handle(Message_Report)::DownCast (anObject);
+ if (!aMessageReport.IsNull())
+ {
+ addReport (aMessageReport);
+ }
+ else if (!Handle(AIS_InteractiveContext)::DownCast (anObject).IsNull())
+ {
+ aParameters.Append (anObject);
+ if (aContext.IsNull())
+ aContext = Handle(AIS_InteractiveContext)::DownCast (anObject);
+ }
+ else if (!Handle(Graphic3d_Camera)::DownCast (anObject).IsNull())
+ {
+ aViewCamera = Handle(Graphic3d_Camera)::DownCast (anObject);
+ }
+ }
+ MessageModel_TreeModel* aTreeModel = dynamic_cast<MessageModel_TreeModel*> (myTreeView->model());
+ if (!aTreeModel)
+ return;
+
+ aTreeModel->EmitLayoutChanged();
+
+ if (!aContext.IsNull())
+ {
+ myViewWindow->SetContext (View_ContextType_External, aContext);
+ //myViewWindow->GetViewToolBar()->SetCurrentContextType (View_ContextType_External);
+ }
+
+ //if (!aViewCamera.IsNull())
+ // myViewWindow->View()->Viewer()->View()->Camera()->Copy (aViewCamera);
+
+ theParameters = aParameters;
+}
+
+// =======================================================================
+// function : openFile
+// purpose :
+// =======================================================================
+void MessageView_Window::openFile(const TCollection_AsciiString& theFileName)
+{
+ if (theFileName.IsEmpty())
+ return;
+
+ const Handle(Message_Report)& aReport = Message::DefaultReport (Standard_True);
+
+ //Handle(Message_Report) aReport = new Message_Report();
+ if (aReport->MessageWriter().IsNull())
+ aReport->SetMessageWriter (new XmlDrivers_MessageReportStorage());
+
+ aReport->MessageWriter()->SetFileName (TCollection_AsciiString (theFileName));
+ aReport->MessageWriter()->ImportReport (aReport);
+
+ addReport (aReport, theFileName);
+}
+
+// =======================================================================
+// function : updateTreeModel
+// purpose :
+// =======================================================================
+void MessageView_Window::updateTreeModel()
+{
+ MessageModel_TreeModel* aViewModel = dynamic_cast<MessageModel_TreeModel*> (myTreeView->model());
+ if (!aViewModel)
+ return;
+
+ aViewModel->UpdateTreeModel();
+}
+
+// =======================================================================
+// function : addReport
+// purpose :
+// =======================================================================
+void MessageView_Window::addReport (const Handle(Message_Report)& theReport,
+ const TCollection_AsciiString& theReportDescription)
+{
+ MessageModel_TreeModel* aModel = dynamic_cast<MessageModel_TreeModel*> (myTreeView->model());
+ aModel->AddReport (theReport, theReportDescription);
+
+ //updateVisibleColumns();
+}
+
+// =======================================================================
+// function : onTreeViewVisibilityClicked
+// purpose :
+// =======================================================================
+void MessageView_Window::onTreeViewVisibilityClicked(const QModelIndex& theIndex)
+{
+ MessageModel_TreeModel* aTreeModel = dynamic_cast<MessageModel_TreeModel*> (myTreeView->model());
+ TreeModel_VisibilityState* aVisibilityState = aTreeModel->GetVisibilityState();
+ if (!aVisibilityState->IsVisible (theIndex))
+ myPropertyView->ClearActiveTablesSelection();
+}
+
+// =======================================================================
+// function : onTreeViewSelectionChanged
+// purpose :
+// =======================================================================
+void MessageView_Window::onTreeViewSelectionChanged (const QItemSelection&, const QItemSelection&)
+{
+ if (!myPropertyPanelWidget->toggleViewAction()->isChecked())
+ return;
+
+ updatePropertyPanelBySelection();
+ updatePreviewPresentation();
+}
+
+// =======================================================================
+// function : onTreeViewContextMenuRequested
+// purpose :
+// =======================================================================
+void MessageView_Window::onTreeViewContextMenuRequested (const QPoint& thePosition)
+{
+ QMenu* aMenu = new QMenu (GetMainWindow());
+
+ MessageModel_ItemRootPtr aRootItem;
+ MessageModel_ItemReportPtr aReportItem;
+ QModelIndexList aSelectedIndices = myTreeView->selectionModel()->selectedIndexes();
+
+ for (QModelIndexList::const_iterator aSelIt = aSelectedIndices.begin(); aSelIt != aSelectedIndices.end(); aSelIt++)
+ {
+ QModelIndex anIndex = *aSelIt;
+ if (anIndex.column() != 0)
+ continue;
+
+ TreeModel_ItemBasePtr anItemBase = TreeModel_ModelBase::GetItemByIndex (anIndex);
+ if (!anItemBase)
+ continue;
+
+ aRootItem = itemDynamicCast<MessageModel_ItemRoot> (anItemBase);
+ if (aRootItem)
+ break;
+ aReportItem = itemDynamicCast<MessageModel_ItemReport> (anItemBase);
+ if (aReportItem)
+ break;
+ }
+ if (aRootItem)
+ {
+ aMenu->addAction (ViewControl_Tools::CreateAction (tr ("Create Default Report"),
+ SLOT (onCreateDefaultReport()), myMainWindow, this));
+ // unite
+ //MessageModel_TreeModel* aTreeModel = dynamic_cast<MessageModel_TreeModel*> (myTreeView->model());
+ //aMenu->addAction (ViewControl_Tools::CreateAction (aTreeModel->IsUniteAlerts() ? tr ("SetUniteAlerts - OFF") : tr ("SetUniteAlerts - ON"),
+ // SLOT (onUniteAlerts()), myMainWindow, this));
+ // reversed
+ //aMenu->addAction (ViewControl_Tools::CreateAction (aTreeModel->IsReversed() ? tr ("SetReversed - OFF") : tr ("SetReversed - ON"),
+ // SLOT (onSetReversedAlerts()), myMainWindow, this));
+ }
+ else if (aReportItem)
+ {
+ aMenu->addAction (ViewControl_Tools::CreateAction (tr ("Export Report"), SLOT (onExportReport()), myMainWindow, this));
+ const TCollection_AsciiString& aDescription = aReportItem->GetDescription();
+ if (!aDescription.IsEmpty())
+ {
+ OSD_Path aPath(aDescription);
+ OSD_File aDescriptionFile (aPath);
+ if (aDescriptionFile.IsReadable())
+ aMenu->addAction (ViewControl_Tools::CreateAction (tr ("Reload"), SLOT (onReloadReport()), myMainWindow, this));
+ }
+ Handle(Message_Report) aReport = aReportItem->GetReport();
+ QAction* anAction = ViewControl_Tools::CreateAction (tr ("Export by alert"), SLOT (onAutoExportActivate()), myMainWindow, this);
+ anAction->setCheckable (true);
+ anAction->setChecked (aReport->WriteFileOnEachAlert());
+ aMenu->addAction (anAction);
+
+ anAction = ViewControl_Tools::CreateAction (tr ("Export trace only"), SLOT (onExportTraceOnly()), myMainWindow, this);
+ anAction->setCheckable (true);
+ bool isTraceOnly = aReport->MessageWriter().IsNull() ? false : aReport->MessageWriter()->Gravity() == Message_Trace;
+ anAction->setChecked (isTraceOnly);
+ aMenu->addAction (anAction);
+ }
+ aMenu->addSeparator();
+
+ aMenu->addAction (ViewControl_Tools::CreateAction (tr ("Preview children presentations"), SLOT (onPreviewChildren()), myMainWindow, this));
+ aMenu->addSeparator();
+
+ myTreeViewActions->AddMenuActions (aSelectedIndices, aMenu);
+ addActivateMetricActions (aMenu);
+
+#ifdef DEBUG_ALERTS
+ aMenu->addSeparator();
+ myTestViewActions->AddMenuActions (aSelectedIndices, aMenu);
+#endif
+
+ QPoint aPoint = myTreeView->mapToGlobal (thePosition);
+ aMenu->exec (aPoint);
+}
+
+// =======================================================================
+// function : onPropertyPanelShown
+// purpose :
+// =======================================================================
+void MessageView_Window::onPropertyPanelShown (bool isToggled)
+{
+ if (!isToggled)
+ return;
+
+ updatePropertyPanelBySelection();
+}
+
+// =======================================================================
+// function : onPropertyViewDataChanged
+// purpose :
+// =======================================================================
+void MessageView_Window::onPropertyViewDataChanged()
+{
+ QItemSelectionModel* aModel = myTreeView->selectionModel();
+ if (!aModel)
+ return;
+ QModelIndex anIndex = TreeModel_ModelBase::SingleSelected (aModel->selectedIndexes(), 0);
+ TreeModel_ItemBasePtr anItemBase = TreeModel_ModelBase::GetItemByIndex (anIndex);
+ if (!anItemBase)
+ return;
+
+ updatePropertyPanelBySelection();
+ updatePreviewPresentation();
+}
+
+// =======================================================================
+// function : onHeaderResized
+// purpose :
+// =======================================================================
+void MessageView_Window::onHeaderResized (int theSectionId, int, int)
+{
+ TreeModel_ModelBase* aViewModel = dynamic_cast<TreeModel_ModelBase*> (myTreeView->model());
+
+ TreeModel_HeaderSection* aSection = aViewModel->ChangeHeaderItem (theSectionId);
+ aSection->SetWidth (myTreeView->columnWidth (theSectionId));
+}
+
+// =======================================================================
+// function : onEraseAllPerformed
+// purpose :
+// =======================================================================
+void MessageView_Window::onEraseAllPerformed()
+{
+ MessageModel_TreeModel* aTreeModel = dynamic_cast<MessageModel_TreeModel*> (myTreeView->model());
+
+ // TODO: provide update for only visibility state for better performance TopoDS_Shape myCustomShape;
+
+ aTreeModel->Reset();
+ aTreeModel->EmitLayoutChanged();
+}
+
+// =======================================================================
+// function : onExportReport
+// purpose :
+// =======================================================================
+void MessageView_Window::onExportReport()
+{
+ QItemSelectionModel* aModel = myTreeView->selectionModel();
+ if (!aModel)
+ return;
+ QModelIndex anIndex = TreeModel_ModelBase::SingleSelected (aModel->selectedIndexes(), 0);
+ TreeModel_ItemBasePtr anItemBase = TreeModel_ModelBase::GetItemByIndex (anIndex);
+ if (!anItemBase)
+ return;
+ MessageModel_ItemReportPtr aReportItem = itemDynamicCast<MessageModel_ItemReport>(anItemBase);
+ if (!aReportItem)
+ return;
+
+ QString aFilter (tr ("Document file (*.json *)"));
+ QString aSelectedFilter;
+ QString aFileName = QFileDialog::getSaveFileName (0, tr ("Export report to file"), QString(), aFilter, &aSelectedFilter);
+
+ Handle(Message_Report) aReport = aReportItem->GetReport();
+ Standard_SStream aStream;
+ aReport->DumpJson(aStream);
+
+ QFile aLogFile(aFileName);
+ if (!aLogFile.open(QFile::WriteOnly | QFile::Text))
+ {
+ return;
+ }
+ QTextStream anOut( &aLogFile );
+ anOut << Standard_Dump::FormatJson (aStream).ToCString();//aStream.str().c_str();
+ aLogFile.close();
+}
+
+// =======================================================================
+// function : onCreateDefaultReport
+// purpose :
+// =======================================================================
+void MessageView_Window::onCreateDefaultReport()
+{
+ if (!Message::DefaultReport().IsNull())
+ {
+ return;
+ }
+
+ addReport (Message::DefaultReport (Standard_True));
+}
+
+// =======================================================================
+// function : onImportReport
+// purpose :
+// =======================================================================
+//void MessageView_Window::onUniteAlerts()
+//{
+ //MessageModel_TreeModel* aTreeModel = dynamic_cast<MessageModel_TreeModel*> (myTreeView->model());
+ //Standard_Boolean isUniteAlerts = aTreeModel->IsUniteAlerts();
+
+ //aTreeModel->SetUniteAlerts (!isUniteAlerts);
+//}
+
+// =======================================================================
+// function : onSetReversedAlerts
+// purpose :
+// =======================================================================
+void MessageView_Window::onSetReversedAlerts()
+{
+ MessageModel_TreeModel* aTreeModel = dynamic_cast<MessageModel_TreeModel*> (myTreeView->model());
+ Standard_Boolean isReversed = aTreeModel->IsReversed();
+
+ aTreeModel->SetReversed (!isReversed);
+}
+
+// =======================================================================
+// function : onReloadReport
+// purpose :
+// =======================================================================
+void MessageView_Window::onReloadReport()
+{
+ QItemSelectionModel* aModel = myTreeView->selectionModel();
+ if (!aModel)
+ return;
+ QModelIndex anIndex = TreeModel_ModelBase::SingleSelected (aModel->selectedIndexes(), 0);
+ TreeModel_ItemBasePtr anItemBase = TreeModel_ModelBase::GetItemByIndex (anIndex);
+ if (!anItemBase)
+ return;
+ MessageModel_ItemReportPtr aReportItem = itemDynamicCast<MessageModel_ItemReport>(anItemBase);
+ if (!aReportItem)
+ aReportItem = MessageModel_ItemReport::FindReportItem (anItemBase);
+
+ if (!aReportItem)
+ return;
+
+ const TCollection_AsciiString aDescription = aReportItem->GetDescription();
+ if (aDescription.IsEmpty())
+ return;
+
+ Handle(Message_Report) aReport = aReportItem->GetReport();
+ aReport->Clear();
+ if (aReport->MessageWriter().IsNull())
+ aReport->SetMessageWriter (new XmlDrivers_MessageReportStorage());
+
+ aReport->MessageWriter()->SetFileName (TCollection_AsciiString (aDescription));
+ if (!aReport->MessageWriter()->ImportReport (aReport))
+ return;
+
+ MessageModel_TreeModel* aTreeModel = dynamic_cast<MessageModel_TreeModel*> (myTreeView->model());
+ aModel->clearSelection();
+ aTreeModel->SetReport (aReportItem->Row(), aReport, aDescription);
+}
+
+// =======================================================================
+// function : onAutoExportActivate
+// purpose :
+// =======================================================================
+void MessageView_Window::onAutoExportActivate()
+{
+ QItemSelectionModel* aModel = myTreeView->selectionModel();
+ if (!aModel)
+ return;
+ QModelIndex anIndex = TreeModel_ModelBase::SingleSelected (aModel->selectedIndexes(), 0);
+ TreeModel_ItemBasePtr anItemBase = TreeModel_ModelBase::GetItemByIndex (anIndex);
+ if (!anItemBase)
+ return;
+ MessageModel_ItemReportPtr aReportItem = itemDynamicCast<MessageModel_ItemReport>(anItemBase);
+ if (!aReportItem)
+ aReportItem = MessageModel_ItemReport::FindReportItem (anItemBase);
+
+ if (!aReportItem)
+ return;
+
+ Handle(Message_Report) aReport = aReportItem->GetReport();
+ QAction* anAction = (QAction*)(sender());
+ aReport->SetWriteFileOnEachAlert (anAction->isChecked());
+}
+
+// =======================================================================
+// function : onExportTraceOnly
+// purpose :
+// =======================================================================
+void MessageView_Window::onExportTraceOnly()
+{
+ QItemSelectionModel* aModel = myTreeView->selectionModel();
+ if (!aModel)
+ return;
+ QModelIndex anIndex = TreeModel_ModelBase::SingleSelected (aModel->selectedIndexes(), 0);
+ TreeModel_ItemBasePtr anItemBase = TreeModel_ModelBase::GetItemByIndex (anIndex);
+ if (!anItemBase)
+ return;
+ MessageModel_ItemReportPtr aReportItem = itemDynamicCast<MessageModel_ItemReport>(anItemBase);
+ if (!aReportItem)
+ aReportItem = MessageModel_ItemReport::FindReportItem (anItemBase);
+
+ if (!aReportItem)
+ return;
+
+ Handle(Message_Report) aReport = aReportItem->GetReport();
+ if (aReport->MessageWriter().IsNull())
+ return;
+
+ QAction* anAction = (QAction*)(sender());
+ aReport->MessageWriter()->SetGravity (anAction->isChecked() ? Message_Trace : Message_Info);
+}
+
+// =======================================================================
+// function : onPreviewChildren
+// purpose :
+// =======================================================================
+void MessageView_Window::onPreviewChildren()
+{
+ QItemSelectionModel* aModel = myTreeView->selectionModel();
+ if (!aModel)
+ return;
+
+ QModelIndexList aSelectedIndices = myTreeView->selectionModel()->selectedIndexes();
+ NCollection_List<Handle(Standard_Transient)> aPresentations;
+ TreeModel_ModelBase::SubItemsPresentations (aSelectedIndices, aPresentations);
+
+ displayer()->UpdatePreview (View_DisplayActionType_DisplayId, aPresentations);
+}
+
+// =======================================================================
+// function : addActivateMetricActions
+// purpose :
+// =======================================================================
+void MessageView_Window::addActivateMetricActions (QMenu* theMenu)
+{
+ Handle(Message_Report) aReport = Message::DefaultReport();
+ if (aReport.IsNull())
+ {
+ return;
+ }
+
+ QMenu* aSubMenu = new QMenu ("Activate metric");
+ for (int aMetricId = (int)Message_MetricType_None + 1; aMetricId <= (int)Message_MetricType_MemHeapUsage; aMetricId++)
+ {
+ Message_MetricType aMetricType = (Message_MetricType)aMetricId;
+ QAction* anAction = ViewControl_Tools::CreateAction (Message::MetricToString (aMetricType),
+ SLOT (OnActivateMetric()), parent(), this);
+ anAction->setCheckable (true);
+ anAction->setChecked (aReport->ActiveMetrics().Contains (aMetricType));
+ aSubMenu->addAction (anAction);
+ }
+ aSubMenu->addSeparator();
+ aSubMenu->addAction (ViewControl_Tools::CreateAction ("Deactivate all", SLOT (OnDeactivateAllMetrics()), parent(), this));
+
+ theMenu->addMenu (aSubMenu);
+}
+
+// =======================================================================
+// function : OnActivateMetric
+// purpose :
+// =======================================================================
+void MessageView_Window::OnActivateMetric()
+{
+ QAction* anAction = (QAction*)(sender());
+
+ Message_MetricType aMetricType;
+ if (!Message::MetricFromString (anAction->text().toStdString().c_str(), aMetricType))
+ return;
+
+ Handle(Message_Report) aReport = Message::DefaultReport();
+ const NCollection_Map<Message_MetricType>& anActiveMetrics = aReport->ActiveMetrics();
+
+ aReport->SetActiveMetric (aMetricType, !anActiveMetrics.Contains (aMetricType));
+
+ updateVisibleColumns();
+}
+
+// =======================================================================
+// function : OnDeactivateAllMetrics
+// purpose :
+// =======================================================================
+void MessageView_Window::OnDeactivateAllMetrics()
+{
+ Handle(Message_Report) aReport = Message::DefaultReport();
+ if (aReport.IsNull())
+ return;
+ aReport->ClearMetrics();
+
+ updateVisibleColumns();
+}
+
+// =======================================================================
+// function : displayer
+// purpose :
+// =======================================================================
+View_Displayer* MessageView_Window::displayer()
+{
+ return myViewWindow->Displayer();
+}
+
+// =======================================================================
+// function : updatePropertyPanelBySelection
+// purpose :
+// =======================================================================
+void MessageView_Window::updatePropertyPanelBySelection()
+{
+ /*QItemSelectionModel* aModel = myTreeView->selectionModel();
+ if (!aModel)
+ return;
+
+ QModelIndex anIndex = TreeModel_ModelBase::SingleSelected (aModel->selectedIndexes(), 0);
+ TreeModel_ItemBasePtr anItemBase = TreeModel_ModelBase::GetItemByIndex (anIndex);
+ if (!anItemBase)
+ return;
+
+ QList<ViewControl_TableModelValues*> aTableValues;
+ MessageModel_Tools::GetPropertyTableValues (anItemBase, aTableValues);
+
+ myPropertyView->Init (aTableValues);*/
+ ViewControl_TableModelValues* aTableValues = 0;
+
+ QItemSelectionModel* aModel = myTreeView->selectionModel();
+ if (!aModel)
+ return;
+
+ QModelIndex anIndex = TreeModel_ModelBase::SingleSelected (aModel->selectedIndexes(), 0);
+ TreeModel_ItemBasePtr anItemBase = TreeModel_ModelBase::GetItemByIndex (anIndex);
+ if (anItemBase)
+ {
+ Handle(TreeModel_ItemProperties) anItemProperties = anItemBase->Properties ();
+ if (!anItemProperties.IsNull())
+ {
+ aTableValues = new ViewControl_TableModelValues();
+ aTableValues->SetProperties (anItemProperties);
+ }
+ }
+ myPropertyView->Init (aTableValues);
+}
+
+// =======================================================================
+// function : updatePreviewPresentation
+// purpose :
+// =======================================================================
+void MessageView_Window::updatePreviewPresentation()
+{
+ Handle(AIS_InteractiveContext) aContext = myViewWindow->ViewToolBar()->CurrentContext();
+ if (aContext.IsNull())
+ return;
+
+ NCollection_List<Handle(Standard_Transient)> aPresentations;
+ QModelIndexList aSelectedIndices = myTreeView->selectionModel()->selectedIndexes();
+ for (QModelIndexList::const_iterator aSelIt = aSelectedIndices.begin(); aSelIt != aSelectedIndices.end(); aSelIt++)
+ {
+ QModelIndex anIndex = *aSelIt;
+ if (anIndex.column() != 0)
+ continue;
+
+ TreeModel_ItemBasePtr anItemBase = TreeModel_ModelBase::GetItemByIndex (anIndex);
+ if (!anItemBase)
+ continue;
+
+ anItemBase->Presentations (aPresentations);
+ }
+
+ displayer()->UpdatePreview (View_DisplayActionType_DisplayId, aPresentations);
+}
+
+// =======================================================================
+// function : updateVisibleColumns
+// purpose :
+// =======================================================================
+void MessageView_Window::updateVisibleColumns()
+{
+ MessageModel_TreeModel* aViewModel = dynamic_cast<MessageModel_TreeModel*> (myTreeView->model());
+
+ NCollection_Map<Message_MetricType> anActiveMetrics;
+ for (NCollection_List<MessageModel_ReportInformation>::Iterator anIterator (aViewModel->Reports()); anIterator.More(); anIterator.Next())
+ {
+ Handle(Message_Report) aReport = anIterator.Value().myReport;
+ for (NCollection_Map<Message_MetricType>::Iterator aMetricsIterator (aReport->ActiveMetrics()); aMetricsIterator.More(); aMetricsIterator.Next())
+ {
+ if (anActiveMetrics.Contains (aMetricsIterator.Value()))
+ continue;
+ anActiveMetrics.Add (aMetricsIterator.Value());
+ }
+ }
+
+ for (int aMetricId = (int)Message_MetricType_None + 1; aMetricId <= (int)Message_MetricType_MemHeapUsage; aMetricId++)
+ {
+ Message_MetricType aMetricType = (Message_MetricType)aMetricId;
+ QList<int> aMetricColumns;
+ aViewModel->GetMetricColumns (aMetricType, aMetricColumns);
+ bool isColumnHidden = !anActiveMetrics.Contains (aMetricType);
+ for (int i = 0; i < aMetricColumns.size(); i++)
+ {
+ int aColumnId = aMetricColumns[i];
+ myTreeView->setColumnHidden (aColumnId, isColumnHidden);
+ TreeModel_HeaderSection* aSection = aViewModel->ChangeHeaderItem (aColumnId);
+ aSection->SetIsHidden (isColumnHidden);
+ }
+ }
+}
--- /dev/null
+// 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 MessageView_Window_H
+#define MessageView_Window_H
+
+#include <Message_Report.hxx>
+#include <Standard.hxx>
+#include <TCollection_AsciiString.hxx>
+
+#include <inspector/MessageModel_Actions.hxx>
+#include <inspector/TInspectorAPI_PluginParameters.hxx>
+
+#include <AIS_InteractiveContext.hxx>
+#include <AIS_InteractiveObject.hxx>
+#include <TopoDS_Shape.hxx>
+
+#ifdef _MSC_VER
+#pragma warning(disable : 4127) // conditional expression is constant
+#endif
+#include <QItemSelection>
+#include <QList>
+#include <QModelIndexList>
+#include <QObject>
+#include <QPoint>
+#include <QString>
+#include <QTreeView>
+
+class View_Displayer;
+class View_Window;
+
+class ViewControl_PropertyView;
+
+class MessageView_ActionsTest;
+
+class QDockWidget;
+class QMainWindow;
+class QMenu;
+class QWidget;
+
+//! \class MessageView_Window
+//! Window that unites all MessageView controls.
+class MessageView_Window : public QObject
+{
+ Q_OBJECT
+public:
+
+ //! Constructor
+ Standard_EXPORT MessageView_Window (QWidget* theParent);
+
+ //! Destructor
+ virtual ~MessageView_Window() {}
+
+ //! Provides the container with a parent where this container should be inserted.
+ //! If Qt implementation, it should be QWidget with QLayout set inside
+ //! \param theParent a parent class
+ Standard_EXPORT void SetParent (void* theParent);
+
+ //! Sets parameters container, it should be used when the plugin is initialized or in update content
+ //! \param theParameters a parameters container
+ void SetParameters (const Handle(TInspectorAPI_PluginParameters)& theParameters)
+ { myParameters = theParameters; myTreeViewActions->SetParameters (theParameters); }
+
+ //! Provide container for actions available in inspector on general level
+ //! \param theMenu if Qt implementation, it is QMenu object
+ Standard_EXPORT virtual void FillActionsMenu (void* theMenu);
+
+ //! Returns plugin preferences: dock widgets state, tree view columns.
+ //! \param theItem container of preference elements
+ Standard_EXPORT void GetPreferences (TInspectorAPI_PreferencesDataMap& theItem);
+
+ //! Applies plugin preferences
+ //! \param theItem container of preference elements
+ Standard_EXPORT void SetPreferences (const TInspectorAPI_PreferencesDataMap& theItem);
+
+ //! Applyes parameters to Init controls, opens files if there are in parameters, updates OCAF tree view model
+ Standard_EXPORT void UpdateContent();
+
+ //! Returns main control
+ QMainWindow* GetMainWindow() const { return myMainWindow; }
+
+ //! Returns current tree view
+ QTreeView* GetTreeView() const { return myTreeView; }
+
+protected:
+ //! Appends shape into tree view model
+ //! \param theShape a shape instance
+ //! \param theReportDescription an additional report information
+ void addReport (const Handle(Message_Report)& theReport,
+ const TCollection_AsciiString& theReportDescription = "");
+
+private:
+
+ //! Fills controls of the plugin by parameters:
+ //! - Fine AIS_InteractiveObject and fills View if it if it differs from the current context
+ //! \param theParameters a parameters container
+ void Init (NCollection_List<Handle(Standard_Transient)>& theParameters);
+
+ //! Read Shape from the file name, add Shape into tree view
+ //! \param theFileName BREP file name
+ void openFile (const TCollection_AsciiString& theFileName);
+
+ //! Updates tree model
+ void updateTreeModel();
+
+protected slots:
+ //! Updates property view selection in table if the item is hidden
+ //! \param theIndex tree view model index
+ void onTreeViewVisibilityClicked(const QModelIndex& theIndex);
+
+ //! Udpates all controls by changed selection in OCAF tree view
+ //! \param theSelected list of selected tree view items
+ //! \param theDeselected list of deselected tree view items
+ void onTreeViewSelectionChanged (const QItemSelection& theSelected, const QItemSelection& theDeselected);
+
+ //! Shows context menu for tree view selected item. It contains expand/collapse actions.
+ //! \param thePosition a clicked point
+ void onTreeViewContextMenuRequested (const QPoint& thePosition);
+
+ //! Display content of selected tree view item if isToggled is true
+ //! \param isToggled true if the property dock widget is shown
+ void onPropertyPanelShown (bool isToggled);
+
+ //! Update tree view item, preview presentation by item value change
+ void onPropertyViewDataChanged();
+
+ //! Update tree view header item width
+ void onHeaderResized (int theSectionId, int, int);
+
+ //! Updates visibility states by erase all in context
+ void onEraseAllPerformed();
+
+ //! Export report into document
+ void onExportReport();
+
+ //! Create default report into document
+ void onCreateDefaultReport();
+
+ //! Unite alerts in view model
+ //void onUniteAlerts();
+
+ //! Sets report reversed
+ void onSetReversedAlerts();
+
+ //! Reads if possible report of a selected item and updates this report in tree view
+ void onReloadReport();
+
+ //! Sets report state to write it by each message alert
+ void onAutoExportActivate();
+
+ //! Sets report writer state to write only trace information of alerts
+ void onExportTraceOnly();
+
+ //! Iterates by children items of selected items and display its presentations if found
+ void onPreviewChildren();
+
+ //! Switch active state in report for clicked type of metric
+ void OnActivateMetric();
+
+ //! Deactivate all types of metrics for the current report
+ void OnDeactivateAllMetrics();
+
+protected:
+ //! Appends items to activate report metrics
+ void addActivateMetricActions (QMenu* theMenu);
+
+ //! Returns displayer where the presentations/preview should be shown/erased
+ //! If default view is created, it returns displayer of this view
+ Standard_EXPORT View_Displayer* displayer();
+
+ //! Updates property panel content by item selected in tree view.
+ void updatePropertyPanelBySelection();
+
+ //!< Updates presentation of preview for parameter shapes. Creates a compound of the shapes
+ void updatePreviewPresentation();
+
+ //!< Sets reports metric columns visible if used
+ void updateVisibleColumns();
+
+private:
+ QMainWindow* myMainWindow; //!< main control, parent for all MessageView controls
+ QDockWidget* myViewDockWidget; //!< view dock widget to hide/show
+
+ QDockWidget* myPropertyPanelWidget; //!< property pane dockable widget
+ ViewControl_PropertyView* myPropertyView; //!< property control to display model item values if exist
+
+ View_Window* myViewWindow; //!< OCC 3d view to visualize presentations
+ QTreeView* myTreeView; //!< tree view visualized shapes
+ MessageModel_Actions* myTreeViewActions; //!< processing history view actions
+ MessageView_ActionsTest* myTestViewActions; //!< check view actions
+
+ Handle(TInspectorAPI_PluginParameters) myParameters; //!< plugins parameters container
+
+ Handle(AIS_InteractiveObject) myPreviewPresentation; //!< presentation of preview for a selected object
+};
+
+#endif
#include <inspector/ShapeView_ItemShape.hxx>
#include <inspector/ShapeView_TreeModel.hxx>
#include <inspector/ShapeView_VisibilityState.hxx>
+#include <inspector/ViewControl_PropertiesDialog.hxx>
#include <inspector/Convert_Tools.hxx>
#include <inspector/ShapeView_OpenFileDialog.hxx>
#include <inspector/ShapeView_Tools.hxx>
+#include <BRepBuilderAPI_MakeFace.hxx>
+#include <BRepBuilderAPI_MakeWire.hxx>
#include <BRep_Builder.hxx>
#include <BRepTools.hxx>
+#include <IMeshTools_Parameters.hxx>
+#include <BRepMesh_IncrementalMesh.hxx>
+#include <Message_Report.hxx>
+#include <StdPrs_ShadedShape.hxx>
+#include <TopoDS.hxx>
#include <Standard_WarningsDisable.hxx>
#include <QApplication>
aVisibilityState, SLOT (OnClicked(const QModelIndex&)));
QItemSelectionModel* aSelModel = new QItemSelectionModel (myTreeView->model(), myTreeView);
+ myTreeView->setSelectionMode (QAbstractItemView::ExtendedSelection);
myTreeView->setSelectionModel (aSelModel);
connect (aSelModel, SIGNAL (selectionChanged (const QItemSelection&, const QItemSelection&)),
this, SLOT (onTreeViewSelectionChanged (const QItemSelection&, const QItemSelection&)));
QModelIndex anIndex = TreeModel_ModelBase::SingleSelected (aModel->selectedIndexes(), 0);
TreeModel_ItemBasePtr anItemBase = TreeModel_ModelBase::GetItemByIndex (anIndex);
- if (!anItemBase)
- return;
-
QMenu* aMenu = new QMenu(myMainWindow);
+
ShapeView_ItemRootPtr aRootItem = itemDynamicCast<ShapeView_ItemRoot> (anItemBase);
if (aRootItem) {
aMenu->addAction (ViewControl_Tools::CreateAction ("Load BREP file", SLOT (onLoadFile()), myMainWindow, this));
aMenu->addAction (ViewControl_Tools::CreateAction ("Remove all shape items", SLOT (onClearView()), myMainWindow, this));
}
- else {
+ else if (anItemBase) { // single selection
aMenu->addAction (ViewControl_Tools::CreateAction ("Export to BREP", SLOT (onExportToBREP()), myMainWindow, this));
+
ShapeView_ItemShapePtr aShapeItem = itemDynamicCast<ShapeView_ItemShape>(anItemBase);
- const TopoDS_Shape& aShape = aShapeItem->GetItemShape();
- TopAbs_ShapeEnum anExplodeType = aShapeItem->ExplodeType();
- NCollection_List<TopAbs_ShapeEnum> anExplodeTypes;
- ShapeView_Tools::IsPossibleToExplode (aShape, anExplodeTypes);
- if (anExplodeTypes.Size() > 0)
+ if (aShapeItem)
{
- QMenu* anExplodeMenu = aMenu->addMenu ("Explode");
- for (NCollection_List<TopAbs_ShapeEnum>::Iterator anExpIterator (anExplodeTypes); anExpIterator.More();
- anExpIterator.Next())
+ const TopoDS_Shape& aShape = aShapeItem->GetItemShape();
+ TopAbs_ShapeEnum anExplodeType = aShapeItem->ExplodeType();
+ NCollection_List<TopAbs_ShapeEnum> anExplodeTypes;
+ ShapeView_Tools::IsPossibleToExplode (aShape, anExplodeTypes);
+ if (anExplodeTypes.Size() > 0)
{
- TopAbs_ShapeEnum aType = anExpIterator.Value();
- QAction* anAction = ViewControl_Tools::CreateAction (TopAbs::ShapeTypeToString (aType), SLOT (onExplode()), myMainWindow, this);
- anExplodeMenu->addAction (anAction);
- if (anExplodeType == aType)
+ QMenu* anExplodeMenu = aMenu->addMenu ("Explode");
+ for (NCollection_List<TopAbs_ShapeEnum>::Iterator anExpIterator (anExplodeTypes); anExpIterator.More();
+ anExpIterator.Next())
{
- anAction->setCheckable (true);
- anAction->setChecked (true);
+ TopAbs_ShapeEnum aType = anExpIterator.Value();
+ QAction* anAction = ViewControl_Tools::CreateAction (TopAbs::ShapeTypeToString (aType), SLOT (onExplode()), myMainWindow, this);
+ anExplodeMenu->addAction (anAction);
+ if (anExplodeType == aType)
+ {
+ anAction->setCheckable (true);
+ anAction->setChecked (true);
+ }
}
+ QAction* anAction = ViewControl_Tools::CreateAction ("NONE", SLOT (onExplode()), myMainWindow, this);
+ anExplodeMenu->addSeparator();
+ anExplodeMenu->addAction (anAction);
}
- QAction* anAction = ViewControl_Tools::CreateAction ("NONE", SLOT (onExplode()), myMainWindow, this);
- anExplodeMenu->addSeparator();
- anExplodeMenu->addAction (anAction);
}
}
+ aMenu->addAction (ViewControl_Tools::CreateAction ("Create Face", SLOT (onCreateFace()), myMainWindow, this));
+ aMenu->addAction (ViewControl_Tools::CreateAction ("Create Compound", SLOT (onCreateCompound()), myMainWindow, this));
+ aMenu->addAction (ViewControl_Tools::CreateAction ("Algo: Incremental Mesh", SLOT (onIncrementalMesh()), myMainWindow, this));
QPoint aPoint = myTreeView->mapToGlobal (thePosition);
aMenu->exec (aPoint);
anItem->SetFileName (aFileNameIndiced.ToCString());
aFileName = aFileNameIndiced.ToCString();
}
+
+// =======================================================================
+// function : onCreateFace
+// purpose :
+// =======================================================================
+void ShapeView_Window::onCreateFace()
+{
+ /*QItemSelectionModel* aModel = myTreeView->selectionModel();
+ if (!aModel)
+ return;
+ QList<TreeModel_ItemBasePtr> anItems = TreeModel_ModelBase::SelectedItems (aModel->selectedIndexes());
+
+ QList<size_t> aSelectedIds; // Remember of selected address in order to avoid duplicates
+ NCollection_List<Handle(Standard_Transient)> anItemPresentations;
+
+ BRepBuilderAPI_MakeWire aWireBuilder;
+ for (QList<TreeModel_ItemBasePtr>::const_iterator anItemIt = anItems.begin(); anItemIt != anItems.end(); ++anItemIt)
+ {
+ ShapeView_ItemShapePtr anItem = itemDynamicCast<ShapeView_ItemShape>(*anItemIt);
+ if (!anItem)
+ continue;
+
+ const TopoDS_Shape& aShape = anItem->GetItemShape();
+ if (aShape.ShapeType() != TopAbs_EDGE)
+ continue;
+
+ const TopoDS_Edge& aSourceEdge = TopoDS::Edge (aShape);
+ const TopoDS_Edge& anEdgeCopied = TopoDS::Edge (aSourceEdge.EmptyCopied());
+
+ aWireBuilder.Add (anEdgeCopied);//aSourceEdge);
+ }
+ if (!aWireBuilder.IsDone())
+ return;
+
+ BRepBuilderAPI_MakeFace aFaceBuilder;
+
+ const TopoDS_Wire& aWire = aWireBuilder.Wire();
+ const TopoDS_Wire& aWireCopied = TopoDS::Wire (aWire.EmptyCopied());
+
+ aFaceBuilder.Add (aWireCopied);
+
+ addShape (aFaceBuilder.Face());
+ */
+}
+
+// =======================================================================
+// function : onCreateCompound
+// purpose :
+// =======================================================================
+void ShapeView_Window::onCreateCompound()
+{
+ QItemSelectionModel* aModel = myTreeView->selectionModel();
+ if (!aModel)
+ return;
+ QList<TreeModel_ItemBasePtr> anItems = TreeModel_ModelBase::SelectedItems (aModel->selectedIndexes());
+
+ QList<size_t> aSelectedIds; // Remember of selected address in order to avoid duplicates
+ NCollection_List<Handle(Standard_Transient)> anItemPresentations;
+
+ BRep_Builder aBB;
+ TopoDS_Compound aC;
+ aBB.MakeCompound(aC);
+
+ for (QList<TreeModel_ItemBasePtr>::const_iterator anItemIt = anItems.begin(); anItemIt != anItems.end(); ++anItemIt)
+ {
+ ShapeView_ItemShapePtr anItem = itemDynamicCast<ShapeView_ItemShape>(*anItemIt);
+ if (!anItem)
+ return;
+
+ aBB.Add(aC, anItem->GetItemShape());
+ }
+ addShape (aC);
+}
+
+// =======================================================================
+// function : onIncrementalMesh
+// purpose :
+// =======================================================================
+void ShapeView_Window::onIncrementalMesh()
+{
+}
//! Views BREP files of selected items if exist
void onExportToBREP();
+ //! Create a wire of selected edges
+ void onCreateFace();
+
+ //! Create a compound of selected shapes
+ void onCreateCompound();
+
+ //! Perform BRepMesh_IncrementalMesh on the selected shape
+ void onIncrementalMesh();
+
//! Convers file name to Ascii String and perform opeging file
//! \param theFileName a file name to be opened
void onOpenFile(const QString& theFileName) { OpenFile (TCollection_AsciiString (theFileName.toUtf8().data())); }
#include <inspector/TInspector_Communicator.hxx>
+#include <OSD_Directory.hxx>
#include <OSD_Environment.hxx>
#include <TCollection_AsciiString.hxx>
+
#include <inspector/TInspector_Window.hxx>
#include <Standard_WarningsDisable.hxx>
static int argc = 1;
static char* argv[] = { (char*)"", 0 };
#if QT_VERSION > 0x050000
- OSD_Environment anEnvironment ("QTDIR");
- TCollection_AsciiString aPlugindsDirName = anEnvironment.Value();
- aPlugindsDirName += "/plugins";
- QApplication::addLibraryPath (aPlugindsDirName.ToCString());
+ TCollection_AsciiString aPlugindsDirName;
+ if (TInspector_Communicator::PluginsDir (aPlugindsDirName))
+ QApplication::addLibraryPath (aPlugindsDirName.ToCString());
#endif
new QApplication (argc, argv);
}
myWindow = new TInspector_Window();
}
+// =======================================================================
+// function : PluginsDir
+// purpose :
+// =======================================================================
+Standard_Boolean TInspector_Communicator::PluginsDir (TCollection_AsciiString& thePlugindsDirName)
+{
+ OSD_Environment anEnvironment ("QTDIR");
+ TCollection_AsciiString aQtDirValue = anEnvironment.Value();
+ if (!aQtDirValue.IsEmpty())
+ {
+ thePlugindsDirName = aQtDirValue + "/plugins";
+ return Standard_True;
+ }
+ anEnvironment = OSD_Environment ("PATH");
+ TCollection_AsciiString aPathValue = anEnvironment.Value();
+ TCollection_AsciiString aPathSep =
+#ifdef _WIN32
+ ';';
+#else
+ ':';
+#endif
+ for (int i = 1; !aPathValue.IsEmpty(); i++)
+ {
+ Standard_Integer aSepIndex = aPathValue.FirstLocationInSet (aPathSep, 1, aPathValue.Length());
+ if (aSepIndex <= 1)
+ break;
+
+ TCollection_AsciiString aCurPath = aPathValue.SubString (1, aSepIndex - 1);
+ aPathValue = aSepIndex < aPathValue.Length() ? aPathValue.SubString (aSepIndex + 1, aPathValue.Length()) : "";
+ if (aCurPath.IsEmpty())
+ continue;
+
+ aCurPath += "/../plugins";
+ OSD_Path aPath (aCurPath);
+ OSD_Directory aCurDir (aPath);
+ if (aCurDir.Exists())
+ {
+ thePlugindsDirName = aCurPath;
+ return Standard_True;
+ }
+ }
+ return Standard_False;
+}
+
// =======================================================================
// function : SetVisible
// purpose :
//! Destructor
virtual ~TInspector_Communicator() {}
+ //! Returns directory of Qt plugins. Firstly it founds it in QTDIR, else if not defined in PATH
+ Standard_EXPORT static Standard_Boolean PluginsDir (TCollection_AsciiString& thePlugindsDirName);
+
//! Registers plugin into TInspector window
//! \param thePluginName a name of the plugin
void RegisterPlugin (const TCollection_AsciiString& thePluginName) { myWindow->RegisterPlugin (thePluginName); }
#include <inspector/TInspector_Communicator.hxx>
+#include <Message.hxx>
+#include <Message_Report.hxx>
#include <OSD_Environment.hxx>
#include <Standard_WarningsDisable.hxx>
int main (int argc, char** argv)
{
#if QT_VERSION > 0x050000
- TCollection_AsciiString aPlugindsDirName = OSD_Environment ("QTDIR").Value();
- if (!aPlugindsDirName.IsEmpty())
- QApplication::addLibraryPath (QString (aPlugindsDirName.ToCString()) + "/plugins");
+ TCollection_AsciiString aPlugindsDirName;
+ if (TInspector_Communicator::PluginsDir (aPlugindsDirName))
+ QApplication::addLibraryPath (aPlugindsDirName.ToCString());
#endif
QApplication anApp (argc, argv);
if (!strcmp (argv[anArgId], "vinspector"))
aPlugins.insert ("TKVInspector");
+
+ if (!strcmp (argv[anArgId], "messageview"))
+ aPlugins.insert ("TKMessageView");
}
NCollection_List<Handle(Standard_Transient)> aParameters;
aPlugins.insert("TKShapeView");
aPlugins.insert("TKVInspector");
- anActivatedPluginName = "TKDFBrowser";
+ //Handle(Message_Report) aReport = Message::DefaultReport (Standard_True);
+ //aReport->SetLimit (100);//30);
+ aPlugins.insert("TKMessageView");
+
+ //anActivatedPluginName = "TKVInspector";
+ //anActivatedPluginName = "TKMessageView";
+ //anActivatedPluginName = "TKDFBrowser";
+ anActivatedPluginName = "TKShapeView";
}
else
anActivatedPluginName = *aPlugins.rbegin();
--- /dev/null
+project(TKMessageModel)
+
+OCCT_INCLUDE_CMAKE_FILE (adm/cmake/occt_toolkit_prepare_tool)
+OCCT_INCLUDE_CMAKE_FILE (adm/cmake/occt_toolkit)
+OCCT_INCLUDE_CMAKE_FILE (adm/cmake/occt_toolkit_prepare_tool)
--- /dev/null
+TKMath
+TKBin
+TKBRep
+TKGeomBase
+TKG3d
+TKTInspectorAPI
+TKService
+TKTopAlgo
+TKTreeModel
+CSF_QT
--- /dev/null
+EXTERNLIB
+PACKAGES
--- /dev/null
+MessageModel
--- /dev/null
+project(TKMessageView)
+
+OCCT_INCLUDE_CMAKE_FILE (adm/cmake/occt_toolkit_prepare_tool)
+OCCT_INCLUDE_CMAKE_FILE (adm/cmake/occt_toolkit)
+OCCT_INCLUDE_CMAKE_FILE (adm/cmake/occt_toolkit_prepare_tool)
--- /dev/null
+TKTInspectorAPI
+TKMath
+TKMessageModel
+TKBin
+TKBRep
+TKGeomBase
+TKG3d
+TKService
+TKTopAlgo
+TKTreeModel
+TKView
+TKXml
+CSF_QT
--- /dev/null
+EXTERNLIB
+PACKAGES
--- /dev/null
+MessageView
TKV3d
TKView
TKService
+TKTopAlgo
TKTreeModel
TKBO
CSF_QT
\ No newline at end of file
+TKBRep
TKG3d
TKernel
TKMath
if (anArgument == "dfbrowser") { thePluginName = "TKDFBrowser"; return Standard_True; }
else if (anArgument == "shapeview") { thePluginName = "TKShapeView"; return Standard_True; }
else if (anArgument == "vinspector") { thePluginName = "TKVInspector"; return Standard_True; }
+ else if (anArgument == "messageview") { thePluginName = "TKMessageView"; return Standard_True; }
return Standard_False;
}
aPlugins.Append ("TKDFBrowser");
aPlugins.Append ("TKShapeView");
aPlugins.Append ("TKVInspector");
+ aPlugins.Append ("TKMessageView");
}
aPluginNameToActivate = !aPluginNameToActivate.IsEmpty() ? aPluginNameToActivate : aPlugins.First();
}
"\n\t\t: Starts tool of inspection."
"\n\t\t: Options:"
"\n\t\t: -plugins enters plugins that should be added in the inspector."
- "\n\t\t: Available names are: dfbrowser, vinspector and shapeview."
+ "\n\t\t: Available names are: dfbrowser, vinspector, shapeview and messageview."
"\n\t\t: Plugins order will be the same as defined in arguments."
"\n\t\t: 'all' adds all available plugins in the order:"
- "\n\t\t: DFBrowser, VInspector and ShapeView."
+ "\n\t\t: DFBrowser, VInspector, ShapeView and MessageView."
"\n\t\t: If at the first call this option is not used, 'all' option is applied;"
"\n\t\t: -activate activates the plugin in the tool view."
"\n\t\t: If at the first call this option is not used, the first plugin is activated;"
enum TreeModel_ColumnType
{
TreeModel_ColumnType_Name = 0, //! name column
- TreeModel_ColumnType_Visibility //! visibility state column
+ TreeModel_ColumnType_Visibility, //! visibility state column
+ TreeModel_ColumnType_Row //! row of the item column
};
#endif
int aNbSections = aModel->columnCount();
for (int aColumnId = 0; aColumnId < aNbSections; aColumnId++)
{
- QAction* anAction = ViewControl_Tools::CreateAction (aModel->GetHeaderItem (aColumnId).GetName(),
+ QAction* anAction = ViewControl_Tools::CreateAction (aModel->ChangeHeaderItem (aColumnId)->GetName(),
SLOT (onColumnVisibilityChanged()), myTreeView, this);
anAction->setCheckable (true);
anAction->setChecked (!myTreeView->isColumnHidden (aColumnId));
// commercial license or contractual agreement.
#include <inspector/TreeModel_ItemBase.hxx>
+
+#include <inspector/TreeModel_ColumnType.hxx>
#include <inspector/TreeModel_ItemProperties.hxx>
#include <inspector/TreeModel_ItemRole.hxx>
#include <inspector/TreeModel_ItemStream.hxx>
switch (Column())
{
- case 1: { return Row(); }
+ case TreeModel_ColumnType_Row: { return Row(); }
}
return QVariant();
#ifndef TreeModel_ItemBase_H
#define TreeModel_ItemBase_H
-#include <NCollection_List.hxx>
#include <Standard.hxx>
#include <Standard_Macro.hxx>
#include <Standard_Handle.hxx>
#include <Standard_OStream.hxx>
#include <Standard_SStream.hxx>
+#include <NCollection_List.hxx>
#include <inspector/TreeModel_ItemRole.hxx>
//! Returns the item properties
const Handle(TreeModel_ItemProperties)& Properties() const { return myProperties; }
+ //! Returns presentation of the attribute to be visualized in the view
+ //! \thePresentations [out] container of presentation handles to be visualized
Standard_EXPORT virtual void Presentations (NCollection_List<Handle(Standard_Transient)>& thePresentations);
+
protected:
//! \param theParent the parent item
const Standard_SStream& aStream = Item()->Stream();
+ InitByStream (aStream);
+}
+
+// =======================================================================
+// function : InitByStream
+// purpose :
+// =======================================================================
+void TreeModel_ItemProperties::InitByStream (const Standard_SStream& aStream)
+{
NCollection_IndexedDataMap<TCollection_AsciiString, Standard_DumpValue> aValues;
TCollection_AsciiString aStreamText = Standard_Dump::Text (aStream);
Standard_Dump::SplitJson (aStreamText, aValues);
Standard_DumpValue aKeyValue;
if (!aStreamParent)
{
- const Handle(Standard_Transient)& anItemObject = Item()->Object();
- aKey = anItemObject.IsNull() ? "Dump" : anItemObject->DynamicType()->Name();
+ if (!Item() || Item()->Object().IsNull())
+ {
+ aKey = "Dump";
+ }
+ else
+ {
+ const Handle(Standard_Transient)& anItemObject = Item()->Object();
+ aKey = anItemObject.IsNull() ? "Dump" : anItemObject->DynamicType()->Name();
+ }
aKeyValue = Standard_DumpValue (aStreamText, 1);
myKey = aKey;
(int)(aGreen * aDelta), (int)(aBlue * aDelta)));
}
}
+ // in case if the stream alert has empty key avalue, use as the key the first row value
+ if ((myKey.IsEmpty() || myKey.IsEqual ("Dump")) && myRowValues.Size() > 0)
+ {
+ myKey = myRowValues.FindFromIndex (1).Value.toString().toStdString().c_str();
+ }
}
// =======================================================================
// function : SetData
// purpose :
// =======================================================================
-bool TreeModel_ItemProperties::SetData (const int /*theRow*/, const int theColumn, const QVariant& /*theValue*/, int)
+bool TreeModel_ItemProperties::SetData (const int theRow, const int theColumn, const QVariant& theValue, int theRole)
{
if (theColumn == 0)
return false;
+
+ if (theRole == Qt::DisplayRole || theRole == Qt::EditRole)
+ {
+ myRowValues.ChangeFromIndex (theRow + 1).Value = theValue;
+ }
+
return false;
}
// =======================================================================
void TreeModel_ItemProperties::Presentations (NCollection_List<Handle(Standard_Transient)>& thePresentations)
{
+ if (!Item())
+ return;
const Standard_SStream& aStream = Item()->Stream();
Convert_Tools::ConvertStreamToPresentations (aStream, 1, -1, thePresentations);
}
//! Sets the current item
void SetItem (const TreeModel_ItemBasePtr& theItem) { myItem = theItem; }
+ //! Fills properties with the stream value
+ Standard_EXPORT void InitByStream (const Standard_SStream& theStream);
+
//! Returns the current item
TreeModel_ItemBasePtr Item() const { return myItem; }
Standard_EXPORT void Init();
//! If the item has internal values, there should be reseted here.
- Standard_EXPORT virtual void Reset();
+ Standard_EXPORT void Reset();
//! Returns number of table rows
//! \return an integer value
//! \param theColumn a model index column
//! \param theRole a view role
//! \return true if the value is changed
- Standard_EXPORT virtual bool SetData (const int theRow, const int theColumn, const QVariant& theValue,
- int theRole = Qt::DisplayRole);
+ Standard_EXPORT bool SetData (const int theRow, const int theColumn, const QVariant& theValue,
+ int theRole = Qt::DisplayRole);
//! Returns presentation of the attribute to be visualized in the view
//! \thePresentations [out] container of presentation handles to be visualized
- Standard_EXPORT virtual void Presentations (NCollection_List<Handle(Standard_Transient)>& thePresentations);
+ Standard_EXPORT void Presentations (NCollection_List<Handle(Standard_Transient)>& thePresentations);
//! Returns flags for the item: ItemIsEnabled | Qt::ItemIsSelectable.
//! Additional flag for the column 1 is Qt::ItemIsEditable.
//! \param theIndex a model index
//! \return flags
- Standard_EXPORT virtual Qt::ItemFlags TableFlags (const int theRow, const int theColumn) const;
+ Standard_EXPORT Qt::ItemFlags TableFlags (const int theRow, const int theColumn) const;
//! Returns stream value of the item to fulfill property panel.
//! \return stream value or dummy
#include <inspector/TreeModel_ModelBase.hxx>
#include <inspector/TreeModel_ItemBase.hxx>
+#include <inspector/TreeModel_ItemProperties.hxx>
#include <inspector/TreeModel_Tools.hxx>
#include <inspector/TreeModel_VisibilityState.hxx>
// =======================================================================
void TreeModel_ModelBase::InitColumns()
{
- SetHeaderItem (0, TreeModel_HeaderSection ("Name", COLUMN_NAME_WIDTH));
- SetHeaderItem (1, TreeModel_HeaderSection ("Visibility", TreeModel_ModelBase::ColumnVisibilityWidth()));
- SetHeaderItem (2, TreeModel_HeaderSection ("Row", COLUMN_SIZE_WIDTH));
+ setHeaderItem (TreeModel_ColumnType_Name, TreeModel_HeaderSection ("Name", COLUMN_NAME_WIDTH));
+ setHeaderItem (TreeModel_ColumnType_Visibility, TreeModel_HeaderSection ("Visibility", TreeModel_ModelBase::ColumnVisibilityWidth()));
+ setHeaderItem (TreeModel_ColumnType_Row, TreeModel_HeaderSection ("Row", COLUMN_SIZE_WIDTH));
}
// =======================================================================
if (IsUseVisibilityColumn() && theSection == TreeModel_ColumnType_Visibility)
return QVariant();
- return GetHeaderItem (theSection).GetName();
+ return myHeaderValues[theSection].GetName();
}
// =======================================================================
#endif
}
-// =======================================================================
-// function : SetHeaderItem
-// purpose :
-// =======================================================================
-void TreeModel_ModelBase::SetHeaderItem (const int theColumnId, const TreeModel_HeaderSection& theSection)
-{
- if (theSection.IsEmpty())
- {
- // remove section
- myHeaderValues.remove (theColumnId);
- myRootItems.remove (theColumnId);
- }
-
- myHeaderValues[theColumnId] = theSection;
- createRoot (theColumnId);
-}
-
// =======================================================================
// function : Selected
// purpose :
return anItems;
}
+// =======================================================================
+// function : SubItemsPresentations
+// purpose :
+// =======================================================================
+void TreeModel_ModelBase::SubItemsPresentations (const QModelIndexList& theIndices,
+ NCollection_List<Handle(Standard_Transient)>& thePresentations)
+{
+ QList<TreeModel_ItemBasePtr> anItems;
+
+ for (QModelIndexList::const_iterator anIndicesIt = theIndices.begin(); anIndicesIt != theIndices.end(); anIndicesIt++)
+ {
+ TreeModel_ItemBasePtr anItem = TreeModel_ModelBase::GetItemByIndex (*anIndicesIt);
+ if (!anItem || anItems.contains (anItem))
+ continue;
+ subItemsPresentations (anItem, thePresentations);
+ }
+}
+
+// =======================================================================
+// function : subItemPresentations
+// purpose :
+// =======================================================================
+void TreeModel_ModelBase::subItemsPresentations (const TreeModel_ItemBasePtr& theItem,
+ NCollection_List<Handle(Standard_Transient)>& thePresentations)
+{
+ theItem->Presentations (thePresentations);
+
+ QList<TreeModel_ItemBasePtr> anItems;
+ for (int aRowId = 0; aRowId < theItem->rowCount(); aRowId++)
+ {
+ subItemsPresentations (theItem->Child (aRowId, theItem->Column()), thePresentations);
+ }
+}
+
// =======================================================================
// function : createRoot
// purpose :
myRootItems.insert (theColumnId, createRootItem (theColumnId));
}
+// =======================================================================
+// function : setHeaderItem
+// purpose :
+// =======================================================================
+void TreeModel_ModelBase::setHeaderItem (const int theColumnId, const TreeModel_HeaderSection& theSection)
+{
+ if (theSection.IsEmpty())
+ {
+ // remove section
+ myHeaderValues.remove (theColumnId);
+ myRootItems.remove (theColumnId);
+ }
+
+ myHeaderValues[theColumnId] = theSection;
+ createRoot (theColumnId);
+}
+
// =======================================================================
// function : getIndexValue
// purpose :
//! Returns whether the column is hidden by default
//! \param theColumnId a column index
//! \return header section values container
- TreeModel_HeaderSection GetHeaderItem (const int theColumnId) const { return myHeaderValues[theColumnId]; }
-
- //! Sets header properties item.
- //! \param theColumnId a column index
- //! \param theSection a section value
- Standard_EXPORT void SetHeaderItem (const int theColumnId, const TreeModel_HeaderSection& theSection);
+ TreeModel_HeaderSection* ChangeHeaderItem (const int theColumnId) { return &myHeaderValues[theColumnId]; }
//! Returns count of columns in the model
//! \param theParent an index of the parent item
//! \return model items from the list
Standard_EXPORT static QList<TreeModel_ItemBasePtr> SelectedItems (const QModelIndexList& theIndices);
+ //! Returns presentations of sub items
+ //! \param theIndices a container of selected indices
+ //! \thePresentations [out] container of presentation handles to be visualized
+ Standard_EXPORT static void SubItemsPresentations (const QModelIndexList& theIndices,
+ NCollection_List<Handle(Standard_Transient)>& thePresentations);
+
protected:
//! Creates root item
//! \param theColumnId index of a column
virtual TreeModel_ItemBasePtr createRootItem (const int theColumnId) = 0;
+ //! Sets header properties item.
+ //! \param theColumnId a column index
+ //! \param theSection a section value
+ Standard_EXPORT void setHeaderItem (const int theColumnId, const TreeModel_HeaderSection& theSection);
+
//! Converts the item shared pointer to void* type
//! \param theItem
//! \return an item pointer
Standard_EXPORT static void* getIndexValue (const TreeModel_ItemBasePtr& theItem);
+ //! Returns presentations of sub items
+ //! \param theIndices a container of selected indices
+ //! \thePresentations [out] container of presentation handles to be visualized
+ static void subItemsPresentations (const TreeModel_ItemBasePtr& theItem,
+ NCollection_List<Handle(Standard_Transient)>& thePresentations);
+
private:
//! Creates root item
//! \param theColumnId index of a column
QStringList aColumnWidths, aHiddenColumns;
for (int aColumnId = 0; aColumnId < theTreeView->model()->columnCount(); aColumnId++)
{
+ int aWidth = theTreeView->columnWidth (aColumnId);
if (theTreeView->isColumnHidden (aColumnId))
{
aHiddenColumns.append (QString::number (aColumnId));
}
else if (theKey == thePrefix + "columns_hidden")
{
- int aColumnSize = theTreeView->model()->columnCount();
- QStringList aValues = theValue.split (",", QString::SkipEmptyParts);
- QList<int> aColumnIds;
- for (int aValueId = 0; aValueId < aValues.size(); aValueId++)
- {
- if (aValueId < aColumnSize)
- aColumnIds.append (aValues.at (aValueId).toInt());
- }
- for (int aColumnId = 0; aColumnId < aColumnSize; aColumnId++)
- {
- theTreeView->setColumnHidden (aColumnId, aColumnIds.contains(aColumnId) == true);
- }
+ //int aColumnSize = theTreeView->model()->columnCount();
+ //QStringList aValues = theValue.split (",", QString::SkipEmptyParts);
+ //QList<int> aColumnIds;
+ //for (int aValueId = 0; aValueId < aValues.size(); aValueId++)
+ //{
+ // if (aValueId < aColumnSize)
+ // aColumnIds.append (aValues.at (aValueId).toInt());
+ //}
+ //for (int aColumnId = 0; aColumnId < aColumnSize; aColumnId++)
+ //{
+ // theTreeView->setColumnHidden (aColumnId, aColumnIds.contains(aColumnId) == true);
+ //}
}
else
return false;
for (int aColumnId = 0, aNbColumns = aTreeModel->columnCount(); aColumnId < aNbColumns; aColumnId++)
{
- TreeModel_HeaderSection aSection = aTreeModel->GetHeaderItem (aColumnId);
- theTreeView->setColumnWidth (aColumnId, aSection.GetWidth());
- theTreeView->setColumnHidden (aColumnId, aSection.IsHidden());
+ TreeModel_HeaderSection* aSection = aTreeModel->ChangeHeaderItem (aColumnId);
+ theTreeView->setColumnWidth (aColumnId, aSection->GetWidth());
+ theTreeView->setColumnHidden (aColumnId, aSection->IsHidden());
}
}
aHeader->moveSection (TreeModel_ColumnType_Name, TreeModel_ColumnType_Visibility);
TreeModel_ModelBase* aModel = dynamic_cast<TreeModel_ModelBase*> (theTreeView->model());
- aModel->SetHeaderItem (TreeModel_ColumnType_Visibility,
- TreeModel_HeaderSection ("Visibility", TreeModel_ModelBase::ColumnVisibilityWidth()));
+ TreeModel_HeaderSection* anItem = aModel->ChangeHeaderItem ((int)TreeModel_ColumnType_Visibility);
+ anItem->SetIsHidden (theActive);
+ anItem->SetWidth (TreeModel_ModelBase::ColumnVisibilityWidth());
+
aModel->SetUseVisibilityColumn (theActive);
}
VInspector_ItemBase.hxx
VInspector_ItemContext.cxx
VInspector_ItemContext.hxx
+VInspector_ItemContextProperties.cxx
+VInspector_ItemContextProperties.hxx
VInspector_ItemHistoryElement.cxx
VInspector_ItemHistoryElement.hxx
VInspector_ItemHistoryRoot.cxx
VInspector_ItemHistoryTypeInfo.hxx
VInspector_ItemPresentableObject.cxx
VInspector_ItemPresentableObject.hxx
+VInspector_ItemSelectMgrViewerSelector.cxx
+VInspector_ItemSelectMgrViewerSelector.hxx
+VInspector_ItemV3dViewer.cxx
+VInspector_ItemV3dViewer.hxx
VInspector_ToolActionType.hxx
VInspector_ToolBar.cxx
VInspector_ToolBar.hxx
case 3: return Standard_Dump::GetPointerInfo (Object(), true).ToCString();
}
- return QVariant();
+ return TreeModel_ItemBase::initValue (theItemRole);
}
// =======================================================================
//! \return the value
Standard_EXPORT virtual QVariant initValue (const int theItemRole) const Standard_OVERRIDE;
- //! Returns presentation of the attribute to be visualized in the view
- //! \thePresentations [out] container of presentation handles to be visualized
- virtual void Presentations (NCollection_List<Handle(Standard_Transient)>& thePresentations)
- { (void)thePresentations; }
-
//! Returns transform persistent of the item or NULL
Handle(Graphic3d_TransformPers) TransformPersistence() const { return myTransformPersistence; }
#include <AIS.hxx>
#include <AIS_ListOfInteractive.hxx>
#include <SelectMgr_EntityOwner.hxx>
+#include <inspector/VInspector_ItemContextProperties.hxx>
#include <inspector/VInspector_ItemPresentableObject.hxx>
#include <inspector/VInspector_Tools.hxx>
if (Column() != 0)
return 0;
+ int aNbProperties = 1; // item to visualize Viewer information of context
+
Handle(AIS_InteractiveContext) aContext = Handle(AIS_InteractiveContext)::DownCast (Object());
if (aContext.IsNull())
return 0;
aNbPresentations++;
}
- return aNbPresentations;
+ return aNbProperties + aNbPresentations;
}
// =======================================================================
// =======================================================================
TreeModel_ItemBasePtr VInspector_ItemContext::createChild (int theRow, int theColumn)
{
- return VInspector_ItemPresentableObject::CreateItem (currentItem(), theRow, theColumn);
+ if (theRow == 0)
+ return VInspector_ItemContextProperties::CreateItem (currentItem(), theRow, theColumn);
+ else
+ return VInspector_ItemPresentableObject::CreateItem (currentItem(), theRow, theColumn);
}
// =======================================================================
--- /dev/null
+// Created on: 2020-02-10
+// Created by: Natalia ERMOLAEVA
+// Copyright (c) 2020 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.
+
+#include <inspector/VInspector_ItemContextProperties.hxx>
+
+#include <inspector/VInspector_ItemContext.hxx>
+#include <inspector/VInspector_ItemV3dViewer.hxx>
+#include <inspector/VInspector_ItemSelectMgrViewerSelector.hxx>
+
+// =======================================================================
+// function : initValue
+// purpose :
+// =======================================================================
+QVariant VInspector_ItemContextProperties::initValue (int theItemRole) const
+{
+ QVariant aParentValue = VInspector_ItemBase::initValue (theItemRole);
+ if (aParentValue.isValid())
+ return aParentValue;
+
+ if (Column() != 0 || (theItemRole != Qt::DisplayRole && theItemRole != Qt::ToolTipRole))
+ return QVariant();
+
+ return "Properties";
+}
+
+// =======================================================================
+// function : initRowCount
+// purpose :
+// =======================================================================
+int VInspector_ItemContextProperties::initRowCount() const
+{
+ return 2; // V3d_Viewer, SelectMgr_ViewerSelector
+}
+
+// =======================================================================
+// function : createChild
+// purpose :
+// =======================================================================
+TreeModel_ItemBasePtr VInspector_ItemContextProperties::createChild (int theRow, int theColumn)
+{
+ if (theRow == 0)
+ return VInspector_ItemV3dViewer::CreateItem (currentItem(), theRow, theColumn);
+
+ return VInspector_ItemSelectMgrViewerSelector::CreateItem (currentItem(), theRow, theColumn);
+}
+
+// =======================================================================
+// function : initItem
+// purpose :
+// =======================================================================
+void VInspector_ItemContextProperties::initItem() const
+{
+ if (IsInitialized())
+ return;
+ const_cast<VInspector_ItemContextProperties*> (this)->Init();
+}
--- /dev/null
+// Created on: 2020-02-10
+// Created by: Natalia ERMOLAEVA
+// Copyright (c) 2020 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 VInspector_ItemContextProperties_H
+#define VInspector_ItemContextProperties_H
+
+#include <Standard.hxx>
+#include <inspector/VInspector_ItemBase.hxx>
+
+#include <AIS_InteractiveObject.hxx>
+#include <TCollection_AsciiString.hxx>
+
+class VInspector_ItemContextProperties;
+typedef QExplicitlySharedDataPointer<VInspector_ItemContextProperties> VInspector_ItemContextPropertiesPtr;
+
+//! \class VInspector_ItemContextProperties
+//! Item presents additional level of information in the tree model.
+//! Parent is item context, child is v3d viewer item.
+class VInspector_ItemContextProperties : public VInspector_ItemBase
+{
+public:
+
+ //! Creates an item wrapped by a shared pointer
+ static VInspector_ItemContextPropertiesPtr CreateItem (TreeModel_ItemBasePtr theParent, const int theRow, const int theColumn)
+ { return VInspector_ItemContextPropertiesPtr (new VInspector_ItemContextProperties (theParent, theRow, theColumn)); }
+
+ //! Destructor
+ virtual ~VInspector_ItemContextProperties() Standard_OVERRIDE {};
+
+protected:
+ //! Initializes the current item. It is empty because Reset() is also empty.
+ virtual void initItem() const Standard_OVERRIDE;
+
+ //! Returns number of item selected
+ //! \return rows count
+ virtual int initRowCount() const Standard_OVERRIDE;
+
+ //! Returns item information for the given role. Fills internal container if it was not filled yet
+ //! \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;
+
+private:
+
+ //! Constructor
+ //! param theParent a parent item
+ VInspector_ItemContextProperties (TreeModel_ItemBasePtr theParent, const int theRow, const int theColumn)
+ : VInspector_ItemBase (theParent, theRow, theColumn) {}
+
+};
+
+#endif
//! Returns presentation of the attribute to be visualized in the view
//! \thePresentations [out] container of presentation handles to be visualized
- Standard_EXPORT virtual void Presentations (NCollection_List<Handle(Standard_Transient)>& thePresentations);
+ Standard_EXPORT virtual void Presentations (NCollection_List<Handle(Standard_Transient)>& thePresentations) Standard_OVERRIDE;
protected:
--- /dev/null
+// Created on: 2020-02-10
+// Created by: Natalia ERMOLAEVA
+// Copyright (c) 2020 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.
+
+#include <inspector/VInspector_ItemSelectMgrViewerSelector.hxx>
+
+#include <AIS.hxx>
+#include <AIS_InteractiveContext.hxx>
+#include <inspector/VInspector_ItemContext.hxx>
+#include <inspector/VInspector_ItemContextProperties.hxx>
+
+// =======================================================================
+// function : initRowCount
+// purpose :
+// =======================================================================
+int VInspector_ItemSelectMgrViewerSelector::initRowCount() const
+{
+ return 0;
+}
+
+// =======================================================================
+// function : initValue
+// purpose :
+// =======================================================================
+QVariant VInspector_ItemSelectMgrViewerSelector::initValue (const int theItemRole) const
+{
+ QVariant aParentValue = VInspector_ItemBase::initValue (theItemRole);
+ if (aParentValue.isValid())
+ return aParentValue;
+
+ if (theItemRole != Qt::DisplayRole && theItemRole != Qt::EditRole && theItemRole != Qt::ToolTipRole)
+ return QVariant();
+
+ if (GetViewerSelector().IsNull())
+ return Column() == 0 ? "Empty viewer selector" : "";
+
+ return Column() == 0 ? GetViewerSelector()->DynamicType()->Name() : QVariant();
+}
+
+// =======================================================================
+// function : Init
+// purpose :
+// =======================================================================
+void VInspector_ItemSelectMgrViewerSelector::Init()
+{
+ VInspector_ItemContextPropertiesPtr aParentItem = itemDynamicCast<VInspector_ItemContextProperties>(Parent());
+ Handle(SelectMgr_ViewerSelector) aViewerSelector;
+ if (aParentItem)
+ {
+ VInspector_ItemContextPtr aParentContextItem = itemDynamicCast<VInspector_ItemContext>(aParentItem->Parent());
+ if (aParentContextItem)
+ {
+ Handle(AIS_InteractiveContext) aContext = aParentContextItem->GetContext();
+ aViewerSelector = aContext->MainSelector();
+ }
+ }
+ myViewerSelector = aViewerSelector;
+ TreeModel_ItemBase::Init();
+}
+
+// =======================================================================
+// function : Reset
+// purpose :
+// =======================================================================
+void VInspector_ItemSelectMgrViewerSelector::Reset()
+{
+ VInspector_ItemBase::Reset();
+
+ myViewerSelector = NULL;
+}
+
+// =======================================================================
+// function : initItem
+// purpose :
+// =======================================================================
+void VInspector_ItemSelectMgrViewerSelector::initItem() const
+{
+ if (IsInitialized())
+ return;
+ const_cast<VInspector_ItemSelectMgrViewerSelector*>(this)->Init();
+}
+
+// =======================================================================
+// function : initStream
+// purpose :
+// =======================================================================
+void VInspector_ItemSelectMgrViewerSelector::initStream (Standard_OStream& theOStream) const
+{
+ Handle(SelectMgr_ViewerSelector) aViewerSelector = GetViewerSelector();
+ if (aViewerSelector.IsNull())
+ return;
+
+ aViewerSelector->DumpJson (theOStream);
+}
--- /dev/null
+// Created on: 2020-02-10
+// Created by: Natalia ERMOLAEVA
+// Copyright (c) 2020 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 VInspector_ItemSelectMgrViewerSelector_H
+#define VInspector_ItemSelectMgrViewerSelector_H
+
+#include <Standard.hxx>
+#include <inspector/VInspector_ItemBase.hxx>
+
+#include <SelectMgr_ViewerSelector.hxx>
+
+class VInspector_ItemSelectMgrViewerSelector;
+typedef QExplicitlySharedDataPointer<VInspector_ItemSelectMgrViewerSelector> VInspector_ItemSelectMgrViewerSelectorPtr;
+
+//! \class VInspector_ItemSelectMgrViewerSelector
+//! Parent item is context properties, that corresponds to SelectMgr_ViewerSelector
+class VInspector_ItemSelectMgrViewerSelector : public VInspector_ItemBase
+{
+public:
+
+ //! Creates an item wrapped by a shared pointer
+ static VInspector_ItemSelectMgrViewerSelectorPtr CreateItem (TreeModel_ItemBasePtr theParent, const int theRow, const int theColumn)
+ { return VInspector_ItemSelectMgrViewerSelectorPtr (new VInspector_ItemSelectMgrViewerSelector (theParent, theRow, theColumn)); }
+
+ //! Destructor
+ virtual ~VInspector_ItemSelectMgrViewerSelector() Standard_OVERRIDE {};
+
+ //! Inits the item, fills internal containers
+ Standard_EXPORT virtual void Init() Standard_OVERRIDE;
+
+ //! Resets cached values
+ Standard_EXPORT virtual void Reset() Standard_OVERRIDE;
+
+ //! Returns data object of the item.
+ //! \return object
+ virtual const Handle(Standard_Transient)& Object() const { initItem(); return myViewerSelector; }
+
+ //! Returns the current viewer, init item if it was not initialized yet
+ //! \return interactive object
+ Handle(SelectMgr_ViewerSelector) GetViewerSelector() const { return Handle(SelectMgr_ViewerSelector)::DownCast (Object()); }
+
+protected:
+ //! Initializes the current item. It is empty because Reset() is also empty.
+ virtual void initItem() const Standard_OVERRIDE;
+
+ //! Returns number of displayed presentations
+ //! \return rows count
+ Standard_EXPORT virtual int initRowCount() const Standard_OVERRIDE;
+
+ //! Returns item information for the given role. Fills internal container if it was not filled yet
+ //! \param theItemRole a value role
+ //! \return the value
+ Standard_EXPORT virtual QVariant initValue (const int theItemRole) const Standard_OVERRIDE;
+
+ //! Returns stream value of the item to fulfill property panel.
+ //! \return stream value or dummy
+ Standard_EXPORT virtual void initStream (Standard_OStream& theOStream) const Standard_OVERRIDE;
+
+private:
+
+ //! Constructor
+ //! param theParent a parent item
+ //! \param theRow the item row positition in the parent item
+ //! \param theColumn the item column positition in the parent item
+ VInspector_ItemSelectMgrViewerSelector (TreeModel_ItemBasePtr theParent, const int theRow, const int theColumn)
+ : VInspector_ItemBase(theParent, theRow, theColumn) {}
+
+protected:
+
+ Handle(SelectMgr_ViewerSelector) myViewerSelector; //!< the current viewer selector
+};
+
+#endif
--- /dev/null
+// Created on: 2020-02-10
+// Created by: Natalia ERMOLAEVA
+// Copyright (c) 2020 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.
+
+#include <inspector/VInspector_ItemV3dViewer.hxx>
+
+#include <AIS.hxx>
+#include <AIS_InteractiveContext.hxx>
+#include <inspector/VInspector_ItemContext.hxx>
+#include <inspector/VInspector_ItemContextProperties.hxx>
+
+// =======================================================================
+// function : initRowCount
+// purpose :
+// =======================================================================
+int VInspector_ItemV3dViewer::initRowCount() const
+{
+ return 0;
+}
+
+// =======================================================================
+// function : initValue
+// purpose :
+// =======================================================================
+QVariant VInspector_ItemV3dViewer::initValue (const int theItemRole) const
+{
+ QVariant aParentValue = VInspector_ItemBase::initValue (theItemRole);
+ if (aParentValue.isValid())
+ return aParentValue;
+
+ if (theItemRole != Qt::DisplayRole && theItemRole != Qt::EditRole && theItemRole != Qt::ToolTipRole)
+ return QVariant();
+
+ if (GetViewer().IsNull())
+ return Column() == 0 ? "Empty viewer" : "";
+
+ return Column() == 0 ? GetViewer()->DynamicType()->Name() : QVariant();
+}
+
+// =======================================================================
+// function : Init
+// purpose :
+// =======================================================================
+void VInspector_ItemV3dViewer::Init()
+{
+ VInspector_ItemContextPropertiesPtr aParentItem = itemDynamicCast<VInspector_ItemContextProperties>(Parent());
+ Handle(V3d_Viewer) aViewer;
+ if (aParentItem)
+ {
+ VInspector_ItemContextPtr aParentContextItem = itemDynamicCast<VInspector_ItemContext>(aParentItem->Parent());
+ if (aParentContextItem)
+ {
+ Handle(AIS_InteractiveContext) aContext = aParentContextItem->GetContext();
+ aViewer = aContext->CurrentViewer();
+ }
+ }
+ myViewer = aViewer;
+ TreeModel_ItemBase::Init();
+}
+
+// =======================================================================
+// function : Reset
+// purpose :
+// =======================================================================
+void VInspector_ItemV3dViewer::Reset()
+{
+ VInspector_ItemBase::Reset();
+
+ myViewer = NULL;
+}
+
+// =======================================================================
+// function : initItem
+// purpose :
+// =======================================================================
+void VInspector_ItemV3dViewer::initItem() const
+{
+ if (IsInitialized())
+ return;
+ const_cast<VInspector_ItemV3dViewer*>(this)->Init();
+}
+
+// =======================================================================
+// function : initStream
+// purpose :
+// =======================================================================
+void VInspector_ItemV3dViewer::initStream (Standard_OStream& theOStream) const
+{
+ Handle(V3d_Viewer) aViewer = GetViewer();
+ if (aViewer.IsNull())
+ return;
+
+ aViewer->DumpJson (theOStream);
+}
--- /dev/null
+// Created on: 2020-02-10
+// Created by: Natalia ERMOLAEVA
+// Copyright (c) 2020 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 VInspector_ItemV3dViewer_H
+#define VInspector_ItemV3dViewer_H
+
+#include <Standard.hxx>
+#include <inspector/VInspector_ItemBase.hxx>
+
+#include <V3d_Viewer.hxx>
+
+class VInspector_ItemV3dViewer;
+typedef QExplicitlySharedDataPointer<VInspector_ItemV3dViewer> VInspector_ItemV3dViewerPtr;
+
+//! \class VInspector_ItemV3dViewer
+//! Parent item is context properties, that corresponds to AIS_InteractiveContext
+class VInspector_ItemV3dViewer : public VInspector_ItemBase
+{
+public:
+
+ //! Creates an item wrapped by a shared pointer
+ static VInspector_ItemV3dViewerPtr CreateItem (TreeModel_ItemBasePtr theParent, const int theRow, const int theColumn)
+ { return VInspector_ItemV3dViewerPtr (new VInspector_ItemV3dViewer (theParent, theRow, theColumn)); }
+
+ //! Destructor
+ virtual ~VInspector_ItemV3dViewer() Standard_OVERRIDE {};
+
+ //! Inits the item, fills internal containers
+ Standard_EXPORT virtual void Init() Standard_OVERRIDE;
+
+ //! Resets cached values
+ Standard_EXPORT virtual void Reset() Standard_OVERRIDE;
+
+ //! Returns data object of the item.
+ //! \return object
+ virtual const Handle(Standard_Transient)& Object() const { initItem(); return myViewer; }
+
+ //! Returns the current viewer, init item if it was not initialized yet
+ //! \return interactive object
+ Handle(V3d_Viewer) GetViewer() const { return Handle(V3d_Viewer)::DownCast (Object()); }
+
+protected:
+ //! Initializes the current item. It is empty because Reset() is also empty.
+ virtual void initItem() const Standard_OVERRIDE;
+
+ //! Returns number of displayed presentations
+ //! \return rows count
+ Standard_EXPORT virtual int initRowCount() const Standard_OVERRIDE;
+
+ //! Returns item information for the given role. Fills internal container if it was not filled yet
+ //! \param theItemRole a value role
+ //! \return the value
+ Standard_EXPORT virtual QVariant initValue (const int theItemRole) const Standard_OVERRIDE;
+
+ //! Returns stream value of the item to fulfill property panel.
+ //! \return stream value or dummy
+ Standard_EXPORT virtual void initStream (Standard_OStream& theOStream) const Standard_OVERRIDE;
+
+private:
+
+ //! Constructor
+ //! param theParent a parent item
+ //! \param theRow the item row positition in the parent item
+ //! \param theColumn the item column positition in the parent item
+ VInspector_ItemV3dViewer(TreeModel_ItemBasePtr theParent, const int theRow, const int theColumn)
+ : VInspector_ItemBase(theParent, theRow, theColumn) {}
+
+protected:
+
+ Handle(V3d_Viewer) myViewer; //!< the current viewer
+};
+
+#endif
{
TreeModel_ModelBase::InitColumns();
- SetHeaderItem (3, TreeModel_HeaderSection ("Pointer", COLUMN_POINTER_WIDTH));
- SetHeaderItem (4, TreeModel_HeaderSection ("SelectedOwners", -1));
+ setHeaderItem (3, TreeModel_HeaderSection ("Pointer", COLUMN_POINTER_WIDTH));
+ setHeaderItem (4, TreeModel_HeaderSection ("SelectedOwners", -1));
}
// =======================================================================
{
TreeModel_ModelBase::InitColumns();
- SetHeaderItem (0, TreeModel_HeaderSection ("Name", COLUMN_NAME_WIDTH));
- SetHeaderItem (1, TreeModel_HeaderSection ("Visibility", COLUMN_SIZE_WIDTH)); // visualization item
- SetHeaderItem (2, TreeModel_HeaderSection ("Size", COLUMN_SIZE_WIDTH));
- SetHeaderItem (3, TreeModel_HeaderSection ("Pointer", COLUMN_POINTER_WIDTH));
- SetHeaderItem (4, TreeModel_HeaderSection ("Shape type", COLUMN_SHAPE_TYPE_WIDTH));
- SetHeaderItem (5, TreeModel_HeaderSection ("AIS Name", COLUMN_AIS_NAME_WIDTH));
- SetHeaderItem (6, TreeModel_HeaderSection ("Selected/Highlighted", -1));
+ setHeaderItem (0, TreeModel_HeaderSection ("Name", COLUMN_NAME_WIDTH));
+ setHeaderItem (1, TreeModel_HeaderSection ("Visibility", COLUMN_SIZE_WIDTH)); // visualization item
+ setHeaderItem (2, TreeModel_HeaderSection ("Size", COLUMN_SIZE_WIDTH));
+ setHeaderItem (3, TreeModel_HeaderSection ("Pointer", COLUMN_POINTER_WIDTH));
+ setHeaderItem (4, TreeModel_HeaderSection ("Shape type", COLUMN_SHAPE_TYPE_WIDTH));
+ setHeaderItem (5, TreeModel_HeaderSection ("AIS Name", COLUMN_AIS_NAME_WIDTH));
+ setHeaderItem (6, TreeModel_HeaderSection ("Selected/Highlighted", -1));
for (int aColumnId = 0, aNbColumns = columnCount(); aColumnId < aNbColumns; aColumnId++)
{
aTreeModel->InitColumns();
myTreeView->setModel (aTreeModel);
// hide Visibility column
- TreeModel_HeaderSection anItem = aTreeModel->GetHeaderItem ((int)TreeModel_ColumnType_Visibility);
- anItem.SetIsHidden (true);
- aTreeModel->SetHeaderItem ((int)TreeModel_ColumnType_Visibility, anItem);
+ TreeModel_HeaderSection* anItem = aTreeModel->ChangeHeaderItem ((int)TreeModel_ColumnType_Visibility);
+ anItem->SetIsHidden (true);
connect (myTreeView, SIGNAL(customContextMenuRequested(const QPoint&)),
this, SLOT (onTreeViewContextMenuRequested(const QPoint&)));
connect (aSelectionModel, SIGNAL (selectionChanged (const QItemSelection&, const QItemSelection&)),
this, SLOT (onHistoryViewSelectionChanged (const QItemSelection&, const QItemSelection&)));
- anItem = aHistoryModel->GetHeaderItem (0);
+ anItem = aHistoryModel->ChangeHeaderItem (0);
// hide Visibility column
TreeModel_Tools::UseVisibilityColumn (myHistoryView, false);
- anItem = aHistoryModel->GetHeaderItem ((int)TreeModel_ColumnType_Visibility);
- anItem.SetIsHidden (true);
- aHistoryModel->SetHeaderItem ((int)TreeModel_ColumnType_Visibility, anItem);
+ anItem = aHistoryModel->ChangeHeaderItem ((int)TreeModel_ColumnType_Visibility);
+ anItem->SetIsHidden (true);
QModelIndex aParentIndex = myHistoryView->model()->index (0, 0);
myHistoryView->setExpanded (aParentIndex, true);
TCollection_AsciiString aPluginName ("TKShapeView");
NCollection_List<Handle(Standard_Transient)> aParameters;
- if (myParameters->FindParameters (aPluginName))
- aParameters = myParameters->Parameters (aPluginName);
+ //if (myParameters->FindParameters (aPluginName))
+ // aParameters = myParameters->Parameters (aPluginName);
NCollection_List<TCollection_AsciiString> anItemNames;
- if (myParameters->FindSelectedNames (aPluginName))
- anItemNames = myParameters->GetSelectedNames (aPluginName);
+ //if (myParameters->FindSelectedNames (aPluginName))
+ // anItemNames = myParameters->GetSelectedNames (aPluginName);
QStringList anExportedPointers;
if (aSelectedShapes.Extent() > 0)
}
}
- // search for objects to be exported
- QList<TreeModel_ItemBasePtr> anItems = TreeModel_ModelBase::SelectedItems (myTreeView->selectionModel()->selectedIndexes());
- for (QList<TreeModel_ItemBasePtr>::const_iterator anItemIt = anItems.begin(); anItemIt != anItems.end(); ++anItemIt)
- {
- TreeModel_ItemBasePtr anItem = *anItemIt;
- VInspector_ItemBasePtr aVItem = itemDynamicCast<VInspector_ItemBase>(anItem);
- if (!aVItem)
- continue;
-
- const Handle(Standard_Transient)& anObject = aVItem->Object();
- if (anObject.IsNull())
- continue;
-
- aParameters.Append (anObject);
- anItemNames.Append (anObject->DynamicType()->Name());
- anExportedPointers.append (Standard_Dump::GetPointerInfo (anObject, true).ToCString());
- }
+ //// search for objects to be exported
+ //QList<TreeModel_ItemBasePtr> anItems = TreeModel_ModelBase::SelectedItems (myTreeView->selectionModel()->selectedIndexes());
+ //for (QList<TreeModel_ItemBasePtr>::const_iterator anItemIt = anItems.begin(); anItemIt != anItems.end(); ++anItemIt)
+ //{
+ // TreeModel_ItemBasePtr anItem = *anItemIt;
+ // VInspector_ItemBasePtr aVItem = itemDynamicCast<VInspector_ItemBase>(anItem);
+ // if (!aVItem)
+ // continue;
+
+ // const Handle(Standard_Transient)& anObject = aVItem->Object();
+ // if (anObject.IsNull())
+ // continue;
+
+ // aParameters.Append (anObject);
+ // anItemNames.Append (anObject->DynamicType()->Name());
+ // anExportedPointers.append (Standard_Dump::GetPointerInfo (anObject, true).ToCString());
+ //}
if (anExportedPointers.isEmpty())
return;
// =======================================================================
Handle(V3d_View) View_Displayer::GetView() const
{
- Handle(V3d_View) aView;
- if (GetContext().IsNull())
- return aView;
+ Handle(AIS_InteractiveContext) theContext = GetContext();
+ if (theContext.IsNull())
+ return NULL;
- const Handle(V3d_Viewer)& aViewer = GetContext()->CurrentViewer();
- if (!aViewer.IsNull())
- {
- aViewer->InitActiveViews();
- if (aViewer->MoreActiveViews())
- aView = aViewer->ActiveView();
- }
- return aView;
+ const Handle(V3d_Viewer)& aViewer = theContext->CurrentViewer();
+ if (aViewer.IsNull())
+ return NULL;
+
+ aViewer->InitActiveViews();
+ if (!aViewer->MoreActiveViews())
+ return NULL;
+
+ return aViewer->ActiveView();
}
// =======================================================================
myDrawer = new Prs3d_Drawer();
Quantity_Color aColor(Quantity_NOC_TOMATO);
- Standard_ShortReal aTransparency = 0.8f;
+ Standard_ShortReal aTransparency = 0.8;
// point parameters
myDrawer->SetPointAspect (new Prs3d_PointAspect (Aspect_TOM_O_PLUS, aColor, 3.0));
ViewControl_MessageDialog.hxx
ViewControl_PropertyView.cxx
ViewControl_PropertyView.hxx
+ViewControl_PropertiesDialog.cxx
+ViewControl_PropertiesDialog.hxx
ViewControl_Table.cxx
ViewControl_Table.hxx
ViewControl_TableModel.cxx
--- /dev/null
+// Copyright (c) 2020 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.
+
+#include <inspector/ViewControl_PropertiesDialog.hxx>
+
+#include <inspector/ViewControl_TableModel.hxx>
+#include <inspector/TreeModel_ItemProperties.hxx>
+
+#include <Standard_WarningsDisable.hxx>
+#include <QGridLayout>
+#include <QPushButton>
+#include <QWidget>
+#include <Standard_WarningsRestore.hxx>
+
+// =======================================================================
+// function : Constructor
+// purpose :
+// =======================================================================
+ViewControl_PropertiesDialog::ViewControl_PropertiesDialog (QWidget* theParent)
+: QDialog (theParent)
+{
+ setWindowTitle ("Properties");
+
+ QGridLayout* aLayout = new QGridLayout (this);
+ myTable = new ViewControl_Table (this);
+ ViewControl_TableModel* aModel = new ViewControl_TableModel (myTable->TableView());
+ myTable->SetModel (aModel);
+
+ aLayout->addWidget(myTable->TableView(), 0, 0, 1, 3);
+
+ myOkButton = new QPushButton ("Ok", this);
+ myCancelButton = new QPushButton ("Cancel", this);
+ connect (myOkButton, SIGNAL (clicked()), this, SLOT (accept()));
+ connect (myCancelButton, SIGNAL (clicked()), this, SLOT (reject()));
+ aLayout->addWidget (myOkButton, 1, 1);
+ aLayout->addWidget (myCancelButton, 1, 2);
+
+ aLayout->setColumnStretch (0, 1);
+
+ myCancelButton->setDefault (true);
+
+ setMinimumSize (200, 600);
+}
+
+// =======================================================================
+// function : Init
+// purpose :
+// =======================================================================
+void ViewControl_PropertiesDialog::Init (const Handle(TreeModel_ItemProperties)& theProperties)
+{
+ ViewControl_TableModelValues* aTableValues = new ViewControl_TableModelValues();
+ aTableValues->SetProperties (theProperties);
+
+ myTable->Init (aTableValues);
+}
--- /dev/null
+// Copyright (c) 2020 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 ViewControl_PropertiesDialog_H
+#define ViewControl_PropertiesDialog_H
+
+#include <Standard.hxx>
+#include <Standard_Macro.hxx>
+
+#include <inspector/ViewControl_Table.hxx>
+
+#include <Standard_WarningsDisable.hxx>
+#include <QDialog>
+#include <Standard_WarningsRestore.hxx>
+
+class TreeModel_ItemProperties;
+
+class QWidget;
+class QPushButton;
+
+//! \class ViewControl_PropertiesDialog
+//! Dialog providing table of stream values
+class ViewControl_PropertiesDialog : public QDialog
+{
+ Q_OBJECT
+public:
+
+ //! Constructor
+ Standard_EXPORT ViewControl_PropertiesDialog (QWidget* theParent);
+
+ //! Destructor
+ virtual ~ViewControl_PropertiesDialog() {}
+
+ Standard_EXPORT void Init (const Handle(TreeModel_ItemProperties)& theProperties);
+
+private:
+ ViewControl_Table* myTable; //!< table view
+
+ QPushButton* myOkButton; //!< accept button
+ QPushButton* myCancelButton; //!< reject button
+};
+
+
+#endif