X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FSketchSolver%2FSketchSolver_ConstraintCoincidence.h;h=58b0d98dfdad486a6c53818215d2bf95fdce21c0;hb=4f565b2204d3fba046aa8c851abada2a5a17bf6c;hp=97c1c1250387e114bb5b72e95f9310f0eb1cd6d2;hpb=bc06873747d5ea9bc0e8d6bd56641eebe33ac08d;p=modules%2Fshaper.git diff --git a/src/SketchSolver/SketchSolver_ConstraintCoincidence.h b/src/SketchSolver/SketchSolver_ConstraintCoincidence.h index 97c1c1250..58b0d98df 100644 --- a/src/SketchSolver/SketchSolver_ConstraintCoincidence.h +++ b/src/SketchSolver/SketchSolver_ConstraintCoincidence.h @@ -9,7 +9,6 @@ #include "SketchSolver.h" #include -#include /** \class SketchSolver_ConstraintCoincidence * \ingroup Plugins @@ -18,38 +17,16 @@ class SketchSolver_ConstraintCoincidence : public SketchSolver_Constraint { public: - SketchSolver_ConstraintCoincidence(ConstraintPtr theConstraint) : + /// Constructor based on SketchPlugin constraint + SKETCHSOLVER_EXPORT SketchSolver_ConstraintCoincidence(ConstraintPtr theConstraint) : SketchSolver_Constraint(theConstraint) {} - virtual int getType() const - { return SLVS_C_POINTS_COINCIDENT; } - - /// \brief Tries to remove constraint - /// \return \c false, if current constraint contains another SketchPlugin constraints (like for multiple coincidence) - virtual bool remove(ConstraintPtr theConstraint = ConstraintPtr()); - - /// \brief Checks the constraint is used by current object - virtual bool hasConstraint(ConstraintPtr theConstraint) const; - - /// \brief Return list of SketchPlugin constraints attached to this object - virtual std::list constraints() const; - - /// \brief Verifies the two Coincidence constraints are intersects (have shared point) - bool isCoincide(std::shared_ptr theConstraint) const; - - /// \brief Append all data of coincidence constaint to the current - void attach(std::shared_ptr theConstraint); - -private: - /// \brief Creates new coincidence constraint - Slvs_hConstraint addConstraint(Slvs_hEntity thePoint1, Slvs_hEntity thePoint2); - - /// \brief Create full SolveSpace structure according to given constraint - void addConstraint(ConstraintPtr theConstraint); - -private: - std::map myExtraCoincidence; ///< multiple coincidence of points +protected: + /// \brief Generate list of attributes of constraint in order useful for constraints + /// \param[out] theValue numerical characteristic of constraint (e.g. distance) + /// \param[out] theAttributes list of attributes to be filled + virtual void getAttributes(double& theValue, std::vector& theAttributes); }; #endif