// 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 #include #include #if OCC_VERSION_HEX < 0x060901 #include #endif #include #include #include #include #include #include #include #include #include #include #include #include #include // ======================================================================= // function : GetShapeTypeInfo // purpose : // ======================================================================= TCollection_AsciiString VInspector_Tools::GetShapeTypeInfo (const TopAbs_ShapeEnum& theType) { Standard_SStream aSStream; TopAbs::Print (theType, aSStream); return aSStream.str().c_str(); } // ======================================================================= // function : GetPointerInfo // purpose : // ======================================================================= TCollection_AsciiString VInspector_Tools::GetPointerInfo (const Handle(Standard_Transient)& thePointer, const bool isShortInfo) { 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(); } // ======================================================================= // function : SelectedOwners // purpose : // ======================================================================= int VInspector_Tools::SelectedOwners (const Handle(AIS_InteractiveContext)& theContext, const Handle(AIS_InteractiveObject)& theObject, const bool theShapeInfoOnly) { QStringList anObjects; if (theContext.IsNull()) return 0; QList aSelectedIds; // Remember of selected address in order to avoid duplicates for (theContext->InitSelected(); theContext->MoreSelected(); theContext->NextSelected()) { Handle(SelectMgr_EntityOwner) anOwner = theContext->SelectedOwner(); if (anOwner.IsNull()) // TODO: check why it is possible continue; if (!theObject.IsNull()) { Handle(AIS_InteractiveObject) anOwnerPresentation = Handle(AIS_InteractiveObject)::DownCast (anOwner->Selectable()); if (anOwnerPresentation != theObject) continue; } Handle(StdSelect_BRepOwner) BROwnr = Handle(StdSelect_BRepOwner)::DownCast (anOwner); if (theShapeInfoOnly && BROwnr.IsNull()) continue; Standard_Transient* anOwnerPtr = anOwner.operator->(); if (aSelectedIds.contains ((size_t)anOwnerPtr)) continue; aSelectedIds.append ((size_t)anOwnerPtr); anObjects.append (VInspector_Tools::GetPointerInfo (anOwnerPtr, true).ToCString()); } return anObjects.size(); } // ======================================================================= // function : IsOwnerSelected // purpose : // ======================================================================= bool VInspector_Tools::IsOwnerSelected (const Handle(AIS_InteractiveContext)& theContext, const Handle(SelectBasics_EntityOwner)& theOwner) { bool anIsSelected = false; Handle(SelectMgr_EntityOwner) anOwner = Handle(SelectMgr_EntityOwner)::DownCast (theOwner); for (theContext->InitSelected(); theContext->MoreSelected() && !anIsSelected; theContext->NextSelected()) anIsSelected = theContext->SelectedOwner() == anOwner; return anIsSelected; } // ======================================================================= // function : ContextOwners // purpose : // ======================================================================= NCollection_List VInspector_Tools::ContextOwners ( const Handle(AIS_InteractiveContext)& theContext) { NCollection_List aResultOwners; if (theContext.IsNull()) return aResultOwners; AIS_ListOfInteractive aListOfIO; theContext->DisplayedObjects (aListOfIO); QList aSelectedIds; // Remember of selected address in order to avoid duplicates for (AIS_ListIteratorOfListOfInteractive aIt(aListOfIO); aIt.More(); aIt.Next()) { Handle(AIS_InteractiveObject) anIO = aIt.Value(); if (anIO.IsNull()) continue; for (anIO->Init(); anIO->More(); anIO->Next()) { Handle(SelectMgr_Selection) aSelection = anIO->CurrentSelection(); if (aSelection.IsNull()) continue; for (aSelection->Init(); aSelection->More(); aSelection->Next()) { Handle(SelectMgr_SensitiveEntity) anEntity = aSelection->Sensitive(); if (anEntity.IsNull()) continue; const Handle(SelectBasics_SensitiveEntity)& aBase = anEntity->BaseSensitive(); Handle(SelectBasics_EntityOwner) anOwner = aBase->OwnerId(); Standard_Transient* anOwnerPtr = anOwner.operator->(); if (aSelectedIds.contains ((size_t)anOwnerPtr)) continue; aSelectedIds.append ((size_t)anOwnerPtr); aResultOwners.Append (anOwner); } } } return aResultOwners; } // ======================================================================= // function : ActiveOwners // purpose : // ======================================================================= NCollection_List VInspector_Tools::ActiveOwners ( const Handle(AIS_InteractiveContext)& theContext, NCollection_List& theEmptySelectableOwners) { NCollection_List aResultOwners; // only local context is processed: TODO for global context Handle(AIS_InteractiveContext) aContext = theContext; if (aContext.IsNull()) return aResultOwners; NCollection_List anActiveOwners; // OCCT BUG:1 - equal pointer owners are appears in the list #if OCC_VERSION_HEX > 0x060901 aContext->MainSelector()->ActiveOwners (anActiveOwners); #else anActiveOwners = aContext->MainSelector()->ActiveOwners(); #endif QList aSelectedIds; // Remember of selected address in order to avoid duplicates Handle(SelectMgr_EntityOwner) anOwner; for (NCollection_List::Iterator anOwnersIt (anActiveOwners); anOwnersIt.More(); anOwnersIt.Next()) { anOwner = Handle(SelectMgr_EntityOwner)::DownCast (anOwnersIt.Value()); if (anOwner.IsNull()) continue; Standard_Transient* anOwnerPtr = anOwner.operator->(); if (aSelectedIds.contains ((size_t)anOwnerPtr)) continue; aSelectedIds.append ((size_t)anOwnerPtr); aResultOwners.Append (anOwner); Handle(SelectMgr_SelectableObject) aSelectable = anOwner->Selectable(); if (aSelectable.IsNull() || !theContext->IsDisplayed(Handle(AIS_InteractiveObject)::DownCast (aSelectable))) theEmptySelectableOwners.Append (anOwner); } return aResultOwners; } // ======================================================================= // function : AddOrRemoveSelectedShapes // purpose : // ======================================================================= void VInspector_Tools::AddOrRemoveSelectedShapes (const Handle(AIS_InteractiveContext)& theContext, const NCollection_List& theOwners) { // TODO: the next two rows are to be removed later theContext->UnhilightSelected(false); theContext->ClearSelected(false); theContext->UnhilightSelected(Standard_False); //TODO: processing in local context only #if OCC_VERSION_HEX < 0x060901 Handle(AIS_LocalContext) aLContext = theContext->LocalContext(); TCollection_AsciiString aSelectionName = aLContext->SelectionName(); aLContext->UnhilightPicked(Standard_False); #endif for (NCollection_List::Iterator anOwnersIt(theOwners); anOwnersIt.More(); anOwnersIt.Next()) { Handle(SelectMgr_EntityOwner) anOwner = Handle(SelectMgr_EntityOwner)::DownCast (anOwnersIt.Value()); #if OCC_VERSION_HEX > 0x060901 theContext->AddOrRemoveSelected (anOwner, Standard_False); #else AIS_Selection::Selection(aSelectionName.ToCString())->Select(anOwner); anOwner->SetSelected(Standard_True); #endif } theContext->UpdateCurrentViewer(); } // ======================================================================= // function : AddOrRemovePresentations // purpose : // ======================================================================= void VInspector_Tools::AddOrRemovePresentations (const Handle(AIS_InteractiveContext)& theContext, const NCollection_List& thePresentations) { // TODO: the next two rows are to be removed later theContext->UnhilightSelected(false); theContext->ClearSelected(false); for (NCollection_List::Iterator anIOIt (thePresentations); anIOIt.More(); anIOIt.Next()) theContext->AddOrRemoveSelected (anIOIt.Value(), false); theContext->UpdateCurrentViewer(); } // ======================================================================= // function : GetInfo // purpose : // ======================================================================= QList VInspector_Tools::GetInfo (Handle(AIS_InteractiveObject)& theObject) { QList anInfo; anInfo.append (theObject->DynamicType()->Name()); anInfo.append (VInspector_Tools::GetPointerInfo (theObject, true).ToCString()); Handle(AIS_Shape) aShapeIO = Handle(AIS_Shape)::DownCast (theObject); if (aShapeIO.IsNull()) return anInfo; const TopoDS_Shape& aShape = aShapeIO->Shape(); if (!aShape.IsNull()) anInfo.append (VInspector_Tools::GetShapeTypeInfo (aShape.ShapeType()).ToCString()); return anInfo; } // ======================================================================= // function : GetHighlightInfo // purpose : // ======================================================================= QList VInspector_Tools::GetHighlightInfo (const Handle(AIS_InteractiveContext)& theContext) { QList aValues; if (theContext.IsNull()) return aValues; QStringList aSelectedNames; QStringList aSelectedPointers; QStringList aSelectedTypes; QStringList aSelectedOwners; QList aSelectedIds; // Remember of selected address in order to avoid duplicates for (theContext->InitDetected(); theContext->MoreDetected(); theContext->NextDetected()) { Handle(SelectMgr_EntityOwner) anOwner = theContext->DetectedOwner(); if (anOwner.IsNull()) continue; Standard_Transient* anOwnerPtr = anOwner.operator->(); if (aSelectedIds.contains ((size_t)anOwnerPtr)) continue; aSelectedIds.append ((size_t)anOwnerPtr); Handle(AIS_InteractiveObject) anIO = Handle(AIS_InteractiveObject)::DownCast (anOwner->Selectable()); if (anIO.IsNull()) continue; QList anIOInfo = VInspector_Tools::GetInfo (anIO); if (anIOInfo.size() == 3) { aSelectedNames.append (anIOInfo[0].toString()); aSelectedPointers.append (anIOInfo[1].toString()); aSelectedTypes.append (anIOInfo[2].toString()); } aSelectedOwners.append (VInspector_Tools::GetPointerInfo (anOwnerPtr, true).ToCString()); } aValues.append (aSelectedNames.join (", ")); aValues.append (aSelectedPointers.join (", ")); aValues.append (aSelectedTypes.join (", ")); aValues.append (aSelectedOwners.join (", ")); return aValues; } // ======================================================================= // function : GetSelectedInfo // purpose : // ======================================================================= QList VInspector_Tools::GetSelectedInfo (const Handle(AIS_InteractiveContext)& theContext) { QList aValues; if (theContext.IsNull()) return aValues; QStringList aSelectedNames; QStringList aSelectedPointers; QStringList aSelectedTypes; QStringList aSelectedOwners; QList aSelectedIds; // Remember of selected address in order to avoid duplicates for (theContext->InitSelected(); theContext->MoreSelected(); theContext->NextSelected()) { Handle(SelectMgr_EntityOwner) anOwner = theContext->SelectedOwner(); if (anOwner.IsNull()) continue; Standard_Transient* anOwnerPtr = anOwner.operator->(); if (aSelectedIds.contains ((size_t)anOwnerPtr)) continue; aSelectedIds.append ((size_t)anOwnerPtr); Handle(AIS_InteractiveObject) anIO = Handle(AIS_InteractiveObject)::DownCast (anOwner->Selectable()); if (anIO.IsNull()) continue; QList anIOInfo = VInspector_Tools::GetInfo (anIO); if (anIOInfo.size() == 3) { aSelectedNames.append (anIOInfo[0].toString()); aSelectedPointers.append (anIOInfo[1].toString()); aSelectedTypes.append (anIOInfo[2].toString()); } aSelectedOwners.append (VInspector_Tools::GetPointerInfo (anOwnerPtr, true).ToCString()); } aValues.append (aSelectedNames.join (", ")); aValues.append (aSelectedPointers.join (", ")); aValues.append (aSelectedTypes.join (", ")); aValues.append (aSelectedOwners.join (", ")); return aValues; } // ======================================================================= // function : GetSelectedInfoPointers // purpose : // ======================================================================= QString VInspector_Tools::GetSelectedInfoPointers (const Handle(AIS_InteractiveContext)& theContext) { QList aSelectedInfo = VInspector_Tools::GetSelectedInfo (theContext); return aSelectedInfo.size() > 2 ? aSelectedInfo[1].toString() : QString(); } // ======================================================================= // function : ToName // purpose : // ======================================================================= TCollection_AsciiString VInspector_Tools::ToName (const VInspector_SelectionType theType, const int theValue) { switch (theType) { case VInspector_SelectionType_TypeOfUpdate: { switch (theValue) { case SelectMgr_TOU_Full: return "Full"; case SelectMgr_TOU_Partial: return "Partial"; case SelectMgr_TOU_None: return "None"; default: break; } } break; case VInspector_SelectionType_StateOfSelection: { switch (theValue) { case SelectMgr_SOS_Activated: return "Activated"; case SelectMgr_SOS_Deactivated: return "Deactivated"; case SelectMgr_SOS_Sleeping: return "Sleeping"; case SelectMgr_SOS_Any: return "Any"; case SelectMgr_SOS_Unknown: return "Unknown"; default: break; } } break; case VInspector_SelectionType_TypeOfBVHUpdate: { switch (theValue) { case SelectMgr_TBU_Add: return "Add"; case SelectMgr_TBU_Remove: return "Remove"; case SelectMgr_TBU_Renew: return "Renew"; case SelectMgr_TBU_Invalidate: return "Invalidate"; case SelectMgr_TBU_None: return "None"; default: break; } } default: break; } return ""; } // ======================================================================= // function : SelectionModeToName // purpose : // ======================================================================= TCollection_AsciiString VInspector_Tools::SelectionModeToName (int theMode, const Handle(AIS_InteractiveObject)& thePresentation) { // types are obtained by comment of SelectMgr_Selection class; Handle(AIS_Shape) aShapePresentation = Handle(AIS_Shape)::DownCast (thePresentation); if (!aShapePresentation.IsNull()) return VInspector_Tools::GetShapeTypeInfo (AIS_Shape::SelectionType (theMode)).ToCString(); else { Handle(AIS_Trihedron) aTrihedronPresentation = Handle(AIS_Trihedron)::DownCast (thePresentation); if (!aTrihedronPresentation.IsNull()) { switch (theMode) { case 0: return "Trihedron"; case 1: return "Trihedron Origin"; case 2: return "Trihedron Axes"; case 3: return "Trihedron Planes"; default: break; } } } return TCollection_AsciiString (theMode); } // ======================================================================= // function : OrientationToName // purpose : // ======================================================================= TCollection_AsciiString VInspector_Tools::OrientationToName (const TopAbs_Orientation& theOrientation) { Standard_SStream aSStream; TopAbs::Print(theOrientation, aSStream); return aSStream.str().c_str(); } // ======================================================================= // function : LocationToName // purpose : // ======================================================================= TCollection_AsciiString VInspector_Tools::LocationToName (const TopLoc_Location& theLocation) { gp_Trsf aTrsf = theLocation.Transformation(); TCollection_AsciiString aValues; for (int aRowId = 1; aRowId <= 3; aRowId++) { for (int aColId = 1; aColId <= 4; aColId++) { aValues += TCollection_AsciiString (aTrsf.Value(aRowId, aColId)); if (aColId != 4) aValues += ","; } if (aRowId != 3) aValues += " "; } return aValues; } // ======================================================================= // function : ReadShape // purpose : // ======================================================================= TopoDS_Shape VInspector_Tools::ReadShape (const TCollection_AsciiString& theFileName) { TopoDS_Shape aShape; BRep_Builder aBuilder; BRepTools::Read (aShape, theFileName.ToCString(), aBuilder); return aShape; }