1 // Copyright (C) 2014-20xx CEA/DEN, EDF R&D
3 // File: SketchSolver_ConstraintMirror.h
5 // Author: Artem ZHIDKOV
7 #ifndef SketchSolver_ConstraintMirror_H_
8 #define SketchSolver_ConstraintMirror_H_
10 #include <SketchSolver_Constraint.h>
12 /** \class SketchSolver_ConstraintMirror
14 * \brief Convert fillet constraint to SolveSpace structure
16 class SketchSolver_ConstraintMirror : public SketchSolver_Constraint
19 /// Constructor based on SketchPlugin constraint
20 SketchSolver_ConstraintMirror(ConstraintPtr theConstraint) :
21 SketchSolver_Constraint(theConstraint),
25 /// \brief Update constraint
26 virtual void update();
28 /// \brief Notify this object about the feature is changed somewhere
29 virtual void notify(const FeaturePtr& theFeature, PlaneGCSSolver_Update*);
31 /// \brief Block or unblock events from this constraint
32 virtual void blockEvents(bool isBlocked);
35 /// \brief Converts SketchPlugin constraint to a list of SolveSpace constraints
36 virtual void process();
38 /// \brief Generate list of entities of mirror constraint
39 virtual void getAttributes(EntityWrapperPtr&, std::vector<EntityWrapperPtr>&);
41 /// \brief This method is used in derived objects to check consistence of constraint.
42 /// E.g. the distance between line and point may be signed.
43 virtual void adjustConstraint();
46 size_t myNumberOfObjects; ///< number of previously mirrored objects
47 std::set<FeaturePtr> myFeatures; ///< mirror line, original and mirrored features