Sketcher: Vincolo Perpendicolare

From FreeCAD Documentation
Revision as of 21:31, 18 January 2015 by Renatorivo (talk | contribs) (Created page with "==Descrizione== Il vincolo Perpendicolare fa sì che due linee siano perpendicolari tra loro, o che due curve siano perpendicolari al loro incrocio. Le linee sono considerate ...")
Jump to navigation Jump to search

Constraint Perpendicular.svg Perpendicolare

Nome nel codice
Constraint Perpendicular
Posizione nel menu
PartDesign → Schizzo → Perpendicolare
Schizzo, PartDesign
Avvio veloce
Introdotto nella versione
Vedere anche


Il vincolo Perpendicolare fa sì che due linee siano perpendicolari tra loro, o che due curve siano perpendicolari al loro incrocio. Le linee sono considerate infinite, e gli archi sono considerati cerchi completi o ellissi complete. Il vincolo è anche in grado di collegare due curve, costringendole perpendicolari nel punto di unione, in modo simile al vincolo Tangente.

How to use

There are four different ways the constraint can be applied:

  1. between two curves (available not for all curves)
  2. between two endpoints of a curve
  3. between a curve and an endpoint of another curve
  4. between two curves at user-defined point

To apply perpendicular constraint, one should the follow the steps:

  • Select two or three entities in the sketch.
  • Invoke the constraint by clicking its icon on the toolbar, or selecting the menu item, or using keyboard shortcut.

Between two curves (direct perpendicularity)

Sketcher ConsraintPerpendicular mode1.png

Two curves will be made perpendicular at point of their intersection (either real, or of curves' extensions), and the point of intersection will be implicit. This mode is applied if two curves were selected.

Accepted selection:

  • line + line, circle, arc
  • circle, arc + circle, arc

If direct perpendicularity between selected curves is not supported (e.g. between a line and an ellipse), a helper point will be added to sketch automatically, and perpendicular-via-point will be applied.

Unlike for tangency, it is perfectly fine to reconstruct the point of perpendicularity by creating a point and constraining it to lie on both curves (thus constraining the point to the intersection).

Between two endpoints (point-to-point perpendicularity)

Sketcher ConsraintPerpendicular mode2.png

In this mode, the endpoints are made coincident, and the joint is made to be right angle. This mode is applied when two endpoints of two curves were selected.

Accepted selection:

  • endpoint of line/arc/arc-of-ellipse + endpoint of line/arc/arc-of-ellipse (i.e., two endpoints of any two curves)

Between curve and endpoint (point-to-curve perpendicularity)

Sketcher ConsraintPerpendicular mode3.png

In this mode, an endpoint of one curve is constrained to lie on the other curve, and the curves are forced perpendicular at the point. This mode is applied when a curve and an endpoint of another curve were selected.

Accepted selection:

  • line, circle, arc, ellipse, arc-of-ellipse + endpoint of line/arc/arc-of-ellipse (i.e., any curve + endpoint of any curve)

Between two curves at point (perpendicular-via-point) (v0.15)

Sketcher ConsraintPerpendicular mode4.png

In this mode, two curves are made perpendicular, and the point of perpendicularity is tracked. This mode is applied when two curves and a point were selected.

Accepted selection:

  • any line/curve + any line/curve + any point

"Any point" can be a lone point, or a point of something, e.g. a center of a circle, an endpoint of an arc, or the origin.

For the constraint to work correctly, the point must be on both curves. So, as the constraint is invoked, the point will be automatically constrained onto both curves (helper constraints will be added, if necessary), and the curves will be forced perpendicular at the point. These helper constraints are plain regular constraints. They can be added manually, or deleted.

Compared to direct perpendicular, this constraint is slower, because there are mode degrees of freedom involved, but it supports ellipses.

The placement of the point before the constraint is applied is a hint for the solver for where the perpendicularity should be.


Perpendicular Constraint can be created from macros and from the python console by using the following:

# direct perpendicularity

# point-to-point perpendicularity

# point-to-curve perpendicularity

# perpendicular-via-point (plain constraint, helpers are not added automatically)


  • Sketch is a sketch object
  • icurve1, icurve2 are two integers identifying the curves to be made perpendicular. The integers are indexes in the sketch (the value, returned by Sketch.addGeometry).
  • pointpos1, pointpos2 should be 1 for start point and 2 for end point.
  • geoidpoint and pointpos in PerpendicularViaPoint are the indexes specifying the point of perpendicularity.
Other languages:
Deutsch • ‎English • ‎español • ‎français • ‎italiano • ‎polski • ‎português • ‎português do Brasil • ‎svenska • ‎čeština • ‎русский