From 3a8eaafe73b1aba7bdbfcbade4c92a11741f0567 Mon Sep 17 00:00:00 2001 From: mpv Date: Fri, 19 Oct 2018 16:24:26 +0300 Subject: [PATCH] Debug of the sketch faces selection --- src/Model/Model_AttributeSelection.cpp | 54 ++++++++++++++++++++++---- src/Model/Model_ResultConstruction.cpp | 9 +++-- 2 files changed, 52 insertions(+), 11 deletions(-) diff --git a/src/Model/Model_AttributeSelection.cpp b/src/Model/Model_AttributeSelection.cpp index 2bf60811d..eb527e696 100644 --- a/src/Model/Model_AttributeSelection.cpp +++ b/src/Model/Model_AttributeSelection.cpp @@ -92,6 +92,8 @@ Standard_GUID kELLIPSE_CENTER2("1395ae73-8e02-4cf8-b204-06ff35873a32"); Standard_GUID kWEAK_NAMING("9dcdd9be-a3a9-46eb-9b16-1c957ab20142"); // identifier of the weak naming sub-shape type Standard_GUID kWEAK_NAMING_SHAPETYPE("6b9cc709-e320-4a1f-9c42-df5622369ea7"); +// reference to the external sketch face +Standard_GUID kEXT_SKETCH_FACE("ba32aa31-bde7-422f-80b4-79c757c77b49"); // prefix for the whole feature context identification const static std::string kWHOLE_FEATURE = "all-in-"; @@ -140,6 +142,7 @@ bool Model_AttributeSelection::setValue(const ObjectPtr& theContext, aSelLab.ForgetAttribute(kELLIPSE_CENTER2); aSelLab.ForgetAttribute(kWEAK_NAMING); aSelLab.ForgetAttribute(kWEAK_NAMING_SHAPETYPE); + aSelLab.ForgetAttribute(kEXT_SKETCH_FACE); bool isDegeneratedEdge = false; // do not use the degenerated edge as a shape, a null context and shape is used in the case @@ -374,6 +377,11 @@ std::shared_ptr Model_AttributeSelection::internalValue(CenterTyp if (aConstr) { if (aConstr->isInfinite()) return aResult; // empty result + // external sketch face + Handle(TDataStd_Integer) aFaceIndex; + if (aSelLab.FindAttribute(kEXT_SKETCH_FACE, aFaceIndex)) { + return aConstr->face(aFaceIndex->Get()); + } } if (!aConstr.get()) { // for construction context, return empty result as usual even // the whole feature is selected @@ -653,6 +661,11 @@ bool Model_AttributeSelection::update() std::shared_ptr aConstructionContext = std::dynamic_pointer_cast(aContext); if (!aConstructionContext->isInfinite()) { + // external sketch face + Handle(TDataStd_Integer) anIndex; + if (aSelLab.FindAttribute(kEXT_SKETCH_FACE, anIndex)) { + return setInvalidIfFalse(aSelLab, anIndex->Get() < aConstructionContext->facesNum()); + } Selector_Selector aSelector(aSelLab); aResult = aSelector.restore(); TopoDS_Shape anOldShape = aSelector.value(); @@ -691,12 +704,25 @@ void Model_AttributeSelection::selectBody( } } - // with "recover" feature the selected context may be not up to date (issue 1710) - TDF_Label aSelLab = selectionLabel(); - TopoDS_Shape aNewSub = theSubShape ? theSubShape->impl() : aContext; - if (!aContext.IsNull()) { + TDF_Label aSelLab = selectionLabel(); + TopoDS_Shape aNewSub = theSubShape->impl(); FeaturePtr aFeatureOwner = std::dynamic_pointer_cast(owner()); + if (aFeatureOwner->document() != theContext->document()) { // reference to the sketch face + ResultConstructionPtr aConstr = + std::dynamic_pointer_cast(theContext); + int aFaceIndex = -1, aFacesNum = aConstr->facesNum(); + for(int a = 0; a < aFacesNum; a++) { + if (aConstr->face(a)->isEqual(theSubShape)) { + aFaceIndex = a; + break; + } + } + if (aFaceIndex >= 0) { + TDataStd_Integer::Set(aSelLab, kEXT_SKETCH_FACE, aFaceIndex); // store index of the face + return; + } + } bool aSelectorOk = true; Selector_Selector aSel(aSelLab); try { @@ -709,7 +735,6 @@ void Model_AttributeSelection::selectBody( aSelectorOk = false; } // check that selection is correct, otherwise use weak naming solution - TDF_Label aSelLab = selectionLabel(); aSelLab.ForgetAttribute(kWEAK_NAMING); Handle(TNaming_NamedShape) aSelectorShape; if (aSelectorOk && aSelLab.FindAttribute(TNaming_NamedShape::GetID(), aSelectorShape)) @@ -829,6 +854,21 @@ std::string Model_AttributeSelection::namingName(const std::string& theDefaultNa ResultConstructionPtr aConstr = std::dynamic_pointer_cast(aCont); if (aConstr->isInfinite()) { return contextName(aCont); + } else { + // external sketch face + Handle(TDataStd_Integer) aFaceIndex; + if (aSelLab.FindAttribute(kEXT_SKETCH_FACE, aFaceIndex)) { + std::shared_ptr anExtDoc = + std::dynamic_pointer_cast(aCont->document()); + Selector_Selector aSelector(anExtDoc->extConstructionsLabel()); + TopoDS_Shape aContShape = aConstr->shape()->impl(); + TopoDS_Shape aValShape = value()->impl(); + aSelector.select(aContShape, aValShape); + myRestoreDocument = anExtDoc; + std::string aName = anExtDoc->kind() + "/" + aSelector.name(this); + myRestoreDocument.reset(); + return aName; + } } } @@ -1490,8 +1530,8 @@ bool Model_AttributeSelection::isWeakNaming() std::string Model_AttributeSelection::contextName(const TDF_Label theSelectionLab) { - DocumentPtr aMyDoc = owner()->document(); - std::shared_ptr aDoc = std::dynamic_pointer_cast(aMyDoc); + std::shared_ptr aDoc = myRestoreDocument.get() ? myRestoreDocument : + std::dynamic_pointer_cast(owner()->document()); FeaturePtr aFeatureOwner = aDoc->featureByLab(theSelectionLab); if (aFeatureOwner.get()) { // if it is sub-element of the sketch, the context name is the name of the sketch diff --git a/src/Model/Model_ResultConstruction.cpp b/src/Model/Model_ResultConstruction.cpp index 87fe4c5ed..3e33cef2e 100644 --- a/src/Model/Model_ResultConstruction.cpp +++ b/src/Model/Model_ResultConstruction.cpp @@ -374,21 +374,22 @@ void Model_ResultConstruction::storeShape(std::shared_ptr theShap TNaming_Builder* anEdgesBuilder = 0; for(TColStd_ListOfInteger::Iterator anIter(aNewInd); anIter.More(); anIter.Next()) { int anIndex = anIter.Value(); + int aModIndex = anIndex > 0 ? anIndex : -anIndex; aNewMap->Add(anIndex); - aName<<"-"< 0 ? anIndex : -anIndex]; + aName<<"-"< 0) aName<<"f"; else aName<<"r"; // collect all edges of the face which are modified in sub-label of the face - if (anEdgeIndices.IsBound(anIndex) && - !aFaceEdges.Contains(anEdgeIndices.Find(anIndex))) { + if (anEdgeIndices.IsBound(aModIndex) && + !aFaceEdges.Contains(anEdgeIndices.Find(aModIndex))) { if (!anEdgesBuilder) { TDF_Label anEdgesLabel = aLab.FindChild(1); anEdgesBuilder = new TNaming_Builder(anEdgesLabel); TDataStd_Name::Set(anEdgesLabel, "SubEdge"); } - anEdgesBuilder->Modify(anEdgeIndices.Find(anIndex), aPutEdges.Current()); + anEdgesBuilder->Modify(anEdgeIndices.Find(aModIndex), aPutEdges.Current()); } aPutEdges.Next(); } -- 2.39.2