X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModel%2FModel_ResultGroup.cpp;h=c40c90738ed8feac8e7c1d91c34d6a1476fb4d77;hb=c57d2a7f1a57af01656e47e2e510990492404fce;hp=5c90173934e13f62952db75a5b60d0a05d6fd271;hpb=0fcae5b2e143e67306603d26f0b5e01cbe33d2bb;p=modules%2Fshaper.git diff --git a/src/Model/Model_ResultGroup.cpp b/src/Model/Model_ResultGroup.cpp index 5c9017393..c40c90738 100644 --- a/src/Model/Model_ResultGroup.cpp +++ b/src/Model/Model_ResultGroup.cpp @@ -1,28 +1,101 @@ -// File: Model_ResultGroup.cpp -// Created: 08 Jul 2014 -// Author: Mikhail PONIKAROV +// Copyright (C) 2014-2019 CEA/DEN, EDF R&D +// +// This library is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 2.1 of the License, or (at your option) any later version. +// +// This library is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public +// License along with this library; if not, write to the Free Software +// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA +// +// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com +// #include +#include #include + #include +#include + +#include -Model_ResultGroup::Model_ResultGroup(boost::shared_ptr theOwnerData) +#include +#include +#include +#include +#include + +Model_ResultGroup::Model_ResultGroup(std::shared_ptr theOwnerData) { - setIsConcealed(false); myOwnerData = theOwnerData; } -boost::shared_ptr Model_ResultGroup::shape() +void Model_ResultGroup::colorConfigInfo(std::string& theSection, std::string& theName, + std::string& theDefault) +{ + theSection = "Visualization"; + theName = "result_group_color"; + theDefault = DEFAULT_COLOR(); +} + +std::shared_ptr Model_ResultGroup::shape() { - boost::shared_ptr aResult; - if (myOwnerData) { + std::shared_ptr aResult; + // obtain stored shape + std::shared_ptr aData = std::dynamic_pointer_cast(data()); + if (aData && aData->isValid()) { + TDF_Label aShapeLab = aData->shapeLab(); + Handle(TDF_Reference) aRef; + if (aShapeLab.FindAttribute(TDF_Reference::GetID(), aRef)) { + aShapeLab = aRef->Get(); + } + Handle(TNaming_NamedShape) aName; + if (aShapeLab.FindAttribute(TNaming_NamedShape::GetID(), aName)) { + TopoDS_Shape aShape = aName->Get(); + if (!aShape.IsNull()) { + aResult.reset(new GeomAPI_Shape); + aResult->setImpl(new TopoDS_Shape(aShape)); + } + } + } + // collect shapes selected in group + if (!aResult && myOwnerData) { AttributeSelectionListPtr aList = myOwnerData->selectionList("group_list"); if (aList) { - std::list > aSubs; + GeomAPI_DataMapOfShapeShape aShapesMap; // to avoid shapes duplication + std::list > aSubs; for(int a = aList->size() - 1; a >= 0; a--) { - boost::shared_ptr aSelection = aList->value(a)->value(); - if (aSelection && !aSelection->isNull()) { - aSubs.push_back(aSelection); + std::shared_ptr aSelection = aList->value(a)->value(); + if (aList->isWholeResultAllowed()) { // whole result selection, explode to sub-shapes + if (!aSelection.get() || aSelection->isNull()) { + ResultPtr aContext = aList->value(a)->context(); + if (aContext) + aSelection = aContext->shape(); + } + if (aSelection && !aSelection->isNull()) { + GeomAPI_Shape::ShapeType aType = GeomAPI_Shape::shapeTypeByStr(aList->selectionType()); + if (aType == aSelection->shapeType()) { + if (aShapesMap.bind(aSelection, aSelection)) + aSubs.push_back(aSelection); + } else { + for(GeomAPI_ShapeExplorer anExp(aSelection, aType); anExp.more(); anExp.next()) { + if (aShapesMap.bind(anExp.current(), anExp.current())) + aSubs.push_back(anExp.current()); + } + } + } + } else { // take selection as it is + if (aSelection && !aSelection->isNull()) { + if (aShapesMap.bind(aSelection, aSelection)) + aSubs.push_back(aSelection); + } } } if (!aSubs.empty()) { @@ -32,3 +105,23 @@ boost::shared_ptr Model_ResultGroup::shape() } return aResult; } + +void Model_ResultGroup::store(const GeomShapePtr& theShape) +{ + std::shared_ptr aData = std::dynamic_pointer_cast(data()); + if (aData) { + TDF_Label aShapeLab = aData->shapeLab(); + aShapeLab.ForgetAttribute(TDF_Reference::GetID()); + aShapeLab.ForgetAttribute(TNaming_NamedShape::GetID()); + + if (!theShape) + return; // bad shape + TopoDS_Shape aShape = theShape->impl(); + if (aShape.IsNull()) + return; // null shape inside + + // store the new shape as primitive + TNaming_Builder aBuilder(aShapeLab); + aBuilder.Generated(aShape); + } +}