X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FSketchPlugin%2FSketchPlugin_ConstraintRigid.cpp;h=418c0dd53a523e12590e40f59cc392df7b5b4b1f;hb=c5b71f05b19e8b0e3588b4b1778f0e9f256dcf17;hp=1b02335dffd69fe730f98ee3c8f62e476ecfb920;hpb=8c99e5e8dd74d99dfbf534bd66b32b70ca134aa7;p=modules%2Fshaper.git diff --git a/src/SketchPlugin/SketchPlugin_ConstraintRigid.cpp b/src/SketchPlugin/SketchPlugin_ConstraintRigid.cpp index 1b02335df..418c0dd53 100644 --- a/src/SketchPlugin/SketchPlugin_ConstraintRigid.cpp +++ b/src/SketchPlugin/SketchPlugin_ConstraintRigid.cpp @@ -1,10 +1,17 @@ +// Copyright (C) 2014-20xx CEA/DEN, EDF R&D --> + // File: SketchPlugin_ConstraintRigid.cpp // Created: 13 Oct 2014 // Author: Artem ZHIDKOV #include "SketchPlugin_ConstraintRigid.h" +#include "SketchPlugin_ConstraintParallel.h" +#include "SketchPlugin_Feature.h" + +#include #include +#include #include #include @@ -15,7 +22,7 @@ SketchPlugin_ConstraintRigid::SketchPlugin_ConstraintRigid() void SketchPlugin_ConstraintRigid::initAttributes() { - data()->addAttribute(SketchPlugin_Constraint::ENTITY_A(), ModelAPI_AttributeRefAttr::type()); + data()->addAttribute(SketchPlugin_Constraint::ENTITY_A(), ModelAPI_AttributeRefAttr::typeId()); } void SketchPlugin_ConstraintRigid::execute() @@ -27,42 +34,24 @@ AISObjectPtr SketchPlugin_ConstraintRigid::getAISObject(AISObjectPtr thePrevious if (!sketch()) return thePrevious; - boost::shared_ptr aData = data(); - boost::shared_ptr anAttr = boost::dynamic_pointer_cast< - ModelAPI_AttributeRefAttr>(aData->attribute(SketchPlugin_Constraint::ENTITY_A())); - if (!anAttr /*|| !anAttr->isObject()*/) - return thePrevious; - - boost::shared_ptr aShape; - - if (anAttr->isObject()) { - boost::shared_ptr aConst; - aConst = boost::dynamic_pointer_cast(anAttr->object()); - - if (!aConst) - return thePrevious; - aShape = aConst->shape(); - } - else { - boost::shared_ptr aPointAttr = - boost::dynamic_pointer_cast(anAttr->attr()); - if (!aPointAttr) - return thePrevious; - boost::shared_ptr aPoint(sketch()->to3D(aPointAttr->x(), aPointAttr->y())); - aShape = GeomAlgoAPI_PointBuilder::point(aPoint); - } - AISObjectPtr anAIS = thePrevious; - if (!anAIS) - anAIS = AISObjectPtr(new GeomAPI_AISObject); - boost::shared_ptr aPlane = sketch()->plane(); - anAIS->createFixed(aShape, aPlane); + bool isValidRigid = false; + std::shared_ptr aData = data(); + AttributeRefAttrPtr anAttr = aData->refattr(SketchPlugin_Constraint::ENTITY_A()); + ObjectPtr aObj = anAttr->object(); + if (aObj.get() != NULL) { + FeaturePtr aFeature = ModelAPI_Feature::feature(aObj); + std::shared_ptr aSkFea = + std::dynamic_pointer_cast(aFeature); + if (!aSkFea->isExternal()) + isValidRigid = true; + } - // Set color from preferences - //std::vector aRGB = Config_PropManager::color("Visualization", "perpendicular_color", - // PERPENDICULAR_COLOR); - //anAIS->setColor(aRGB[0], aRGB[1], aRGB[2]); + if (isValidRigid) + anAIS = SketcherPrs_Factory::rigidConstraint(this, sketch()->coordinatePlane(), thePrevious); + else + anAIS = AISObjectPtr(); return anAIS; } \ No newline at end of file