#include <TNaming_Tool.hxx>
#include <TNaming_NamedShape.hxx>
-#include <TNaming_Iterator.hxx>
#include <TDataStd_Name.hxx>
#include <TopoDS_Compound.hxx>
#include <BRep_Builder.hxx>
#include <TopExp_Explorer.hxx>
-#define baseRef() std::dynamic_pointer_cast<Model_ResultPart>(data()->reference(BASE_REF_ID())->value())
+#define baseRef() \
+ std::dynamic_pointer_cast<Model_ResultPart>(data()->reference(BASE_REF_ID())->value())
void Model_ResultPart::initAttributes()
{
// activation may cause changes in current features in document, so it must be in transaction
bool isNewTransaction = false;
SessionPtr aMgr = ModelAPI_Session::get();
- if (!aMgr->isOperation()) { // open transaction even document is not created to set current docs in setActiveDocument
+ if (!aMgr->isOperation()) {
+ // open transaction even document is not created to set current docs in setActiveDocument
aMgr->startOperation("Activation");
isNewTransaction = true;
}
std::shared_ptr<GeomAPI_Shape> Model_ResultPart::shape()
{
std::shared_ptr<GeomAPI_Shape> aResult(new GeomAPI_Shape);
- if (myTrsf.get()) { // get shape of the base result and apply the transformation
- ResultPtr anOrigResult = baseRef();
- std::shared_ptr<GeomAPI_Shape> anOrigShape = anOrigResult->shape();
- if (anOrigShape.get()) {
- TopoDS_Shape aShape = anOrigShape->impl<TopoDS_Shape>();
- if (!aShape.IsNull()) {
- aShape.Move(*(myTrsf.get()));
- aResult->setImpl(new TopoDS_Shape(aShape));
- }
- }
- return aResult;
- }
if (myShape.IsNull()) { // shape is not produced yet, create it
- DocumentPtr aDoc = Model_ResultPart::partDoc();
- if (aDoc.get() && aDoc->isOpened()) {
- const std::string& aBodyGroup = ModelAPI_ResultBody::group();
- TopoDS_Compound aResultComp;
- BRep_Builder aBuilder;
- aBuilder.MakeCompound(aResultComp);
- int aNumSubs = 0;
- for(int a = aDoc->size(aBodyGroup) - 1; a >= 0; a--) {
- ResultPtr aBody = std::dynamic_pointer_cast<ModelAPI_Result>(aDoc->object(aBodyGroup, a));
- // "object" method filters out disabled and concealed anyway, so don't check
- if (aBody.get() && aBody->shape().get()) {
- TopoDS_Shape aShape = *(aBody->shape()->implPtr<TopoDS_Shape>());
- if (!aShape.IsNull()) {
- aBuilder.Add(aResultComp, aShape);
- aNumSubs++;
- }
+ if (myTrsf.get()) { // get shape of the base result and apply the transformation
+ ResultPtr anOrigResult = baseRef();
+ std::shared_ptr<GeomAPI_Shape> anOrigShape = anOrigResult->shape();
+ if (anOrigShape.get()) {
+ TopoDS_Shape aShape = anOrigShape->impl<TopoDS_Shape>();
+ if (!aShape.IsNull()) {
+ aShape.Move(*(myTrsf.get()));
+ myShape = aShape;
+ aResult->setImpl(new TopoDS_Shape(aShape));
}
}
- if (aNumSubs) {
- myShape = aResultComp;
+ return aResult;
+ } else {
+ DocumentPtr aDoc = Model_ResultPart::partDoc();
+ if (aDoc.get() && aDoc->isOpened()) {
+ const std::string& aBodyGroup = ModelAPI_ResultBody::group();
+ TopoDS_Compound aResultComp;
+ BRep_Builder aBuilder;
+ aBuilder.MakeCompound(aResultComp);
+ int aNumSubs = 0;
+ for(int a = aDoc->size(aBodyGroup) - 1; a >= 0; a--) {
+ ResultPtr aBody = std::dynamic_pointer_cast<ModelAPI_Result>(aDoc->object(aBodyGroup, a));
+ // "object" method filters out disabled and concealed anyway, so don't check
+ if (aBody.get() && aBody->shape().get()) {
+ TopoDS_Shape aShape = *(aBody->shape()->implPtr<TopoDS_Shape>());
+ if (!aShape.IsNull()) {
+ aBuilder.Add(aResultComp, aShape);
+ aNumSubs++;
+ }
+ }
+ }
+ if (aNumSubs) {
+ myShape = aResultComp;
+ }
}
}
}
if (!aDoc.get()) // the part document is not presented for the moment
return "";
TDF_Label anAccessLabel = aDoc->generalLabel();
- // make the selection attribute anyway: otherwise just by name it is not stable to search the result
+ // make the selection attribute anyway:
+ // otherwise just by name it is not stable to search the result
std::string aName;
// for this the context result is needed
ResultPtr aContext;
return false; // something is wrong
}
+gp_Trsf Model_ResultPart::sumTrsf() {
+ gp_Trsf aResult;
+ if (myTrsf) {
+ aResult = *myTrsf;
+ aResult = aResult * baseRef()->sumTrsf();
+ }
+ return aResult;
+}
+
std::shared_ptr<GeomAPI_Shape> Model_ResultPart::shapeInPart(
const std::string& theName, const std::string& theType, int& theIndex)
{
aSelAttr->append(theName, theType);
theIndex = aSelAttr->size();
aResult = aSelAttr->value(theIndex - 1)->value();
+ if (myTrsf.get() && aResult.get() && !aResult->isNull()) {
+ gp_Trsf aSumTrsf = sumTrsf();
+ TopoDS_Shape anOrigMoved = aResult->impl<TopoDS_Shape>().Moved(aSumTrsf);
+ aResult->setImpl(new TopoDS_Shape(anOrigMoved));
+ }
return aResult;
}
AttributeSelectionListPtr aSelAttr = aDoc->selectionInPartFeature();
aResult = aSelAttr->value(theIndex - 1)->value();
+ if (myTrsf.get() && aResult.get() && !aResult->isNull()) {
+ gp_Trsf aSumTrsf = sumTrsf();
+ TopoDS_Shape anOrigMoved = aResult->impl<TopoDS_Shape>().Moved(aSumTrsf);
+ aResult->setImpl(new TopoDS_Shape(anOrigMoved));
+ }
return aResult;
}