Sketcher: Vincolo Perpendicolare

From FreeCAD Documentation
Revision as of 21:49, 18 January 2015 by Renatorivo (talk | contribs) (Created page with "===Tra una curva e un punto finale (perpendicolarità punto con curva)=== 600px")

Perpendicolare

Posizione nel menu
PartDesign → Schizzo → Perpendicolare
Ambiente
Schizzo, PartDesign
Avvio veloce
N
Introdotto nella versione
-
Vedere anche
Angolo

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 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.

Uso

Ci sono quattro modi diversi per applicare il vincolo:

  1. tra due curve (non disponibile per tutte le curve)
  2. tra due punti finali di curve
  3. tra una curva e il punto finale di un'altra curva
  4. tra due curve in un punto definito dall'utente

Per applicare il vincolo perpendicolare, si dovrebbe usare la seguente procedura:

  • Selezionare due o tre entità nello schizzo.
  • Invocare il vincolo facendo clic sull'icona nella barra degli strumenti, oppure selezionando la voce del menu, oppure usando la scorciatoia da tastiera.

Tra due curve (perpendicolarità diretta)

Due curve vengono rese perpendicolari nel punto della loro intersezione (sia reale, che sull'estensione delle curve). Il punto di intersezione è implicito. Questa modalità si applica se sono state selezionate due curve.

Selezioni accettate:

  • linea + linea, cerchio, arco
  • cerchio, arco + cerchio, arco

Se tra le curve selezionate la "perpendicolarità diretta" non è supportata (ad esempio, tra una linea e un'ellisse), nello schizzo viene automaticamente aggiunto un punto di supporto e viene applicata la "perpendicolarità nel punto".

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).

Tra due punti finali (perpendicolarità punto con punto)

In questo modo, i punti finali sono coincidenti, e la congiunzione avviene ad angolo retto. Questa modalità viene applicata quando sono stati selezionati due punti finali di due curve.

Selezioni accettate:

  • punto finale di linea/arco/arco-di-ellisse + punto finale di linea/arco/arco-di-ellisse, cioè due punti finali di qualsiasi due curve

Tra una curva e un punto finale (perpendicolarità punto con curva)

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)

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.

Scripting

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

# direct perpendicularity
Sketch.addConstraint(Sketcher.Constraint('Perpendicular',icurve1,icurve2))

# point-to-point perpendicularity
Sketch.addConstraint(Sketcher.Constraint('Perpendicular',icurve1,pointpos1,icurve2,pointpos2))

# point-to-curve perpendicularity
Sketch.addConstraint(Sketcher.Constraint('Perpendicular',icurve1,pointpos1,icurve2))

# perpendicular-via-point (plain constraint, helpers are not added automatically)
Sketch.addConstraint(Sketcher.Constraint('PerpendicularViaPoint',icurve1,icurve2,geoidpoint,pointpos))

where:

  • 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.