Sketcher ConstrainAngle: Difference between revisions

From FreeCAD Documentation
mNo edit summary
No edit summary
 
(53 intermediate revisions by 9 users not shown)
Line 1: Line 1:
<languages/>
<languages/>
{{Page_in_progress}}
<translate>
<translate>

<!--T:25-->
<!--T:25-->
{{Docnav
{{Docnav|[[Sketcher_ConstrainRadius|Radius]]|[[Sketcher ConstrainSnellsLaw|Snell's Law]]|[[Sketcher_Workbench|Sketcher]]|IconL=Constraint_Radius.png|IconC=Workbench_Sketcher.svg|IconR=Constraint_SnellsLaw.png}}
|[[Sketcher_ConstrainDiameter|Diameter]]
|[[Sketcher_ConstrainLock|Lock]]
|[[Sketcher_Workbench|Sketcher]]
|IconL=Sketcher_ConstrainDiameter.svg
|IconR=Sketcher_ConstrainLock.svg
|IconC=Workbench_Sketcher.svg
}}


<!--T:1-->
<!--T:1-->
{{GuiCommand
{{GuiCommand
|Name=Constraint InternalAngle
|Name=Sketcher ConstrainAngle
|Workbenches=[[Sketcher Workbench|Sketcher]]
|Shortcut=A
|MenuLocation=Sketch → Sketcher constraints → Constrain angle
|MenuLocation=Sketch → Sketcher constraints → Constrain angle
|Workbenches=[[Sketcher_Workbench|Sketcher]]
|SeeAlso=[[Sketcher ConstrainDistance|Constrain distance]], [[Sketcher ConstrainPerpendicular|Constraint Perpendicular]]
|Shortcut={{KEY|K}} {{KEY|A}}
|SeeAlso=[[Sketcher_ConstrainDistance|Sketcher Constrain distance]], [[Sketcher_ConstrainPerpendicular|Sketcher Constraint Perpendicular]]
}}
}}


==Description== <!--T:4-->
==Description== <!--T:30-->

Angle constraint is a [[Sketcher_Workbench#Sketcher Constraints|datum constraint]] intended to fix angles in sketch. It is capable of setting slopes of individual lines, angles between lines, angles of intersections of curves, and angle spans of circular arcs.
<!--T:4-->
The [[Image:Sketcher_ConstrainAngle.svg|24px]] [[Sketcher_ConstrainAngle|Sketcher ConstrainAngle]] tool fixes the angle between two edges (lines are then treated as infinite, and open curves are virtually extended as well), the angle of a line with the X axis, or the aperture angle of a circular arc.


==Usage== <!--T:5-->
==Usage== <!--T:5-->
There are four different ways the constraint can be applied:
* to individual lines
* between lines
* to intersections of curves
* to arcs of circles


See also: [[Sketcher_Workbench#Drawing_aids|Drawing aids]].
<!--T:6-->
To apply angle constraint, one should the follow the steps:
# Select one, two or three entities in the sketch. The mode will be chosen depending on the selection.
# Invoke the constraint using several methods:
#* Pressing the {{Button|[[Image:Constraint_InternalAngle.svg|16px]]}} in the toolbar.
#* Using the {{KEY|A}} keyboard shortcut. ('''A''' is for '''A'''ngle)
#* Using the {{MenuCommand|Sketch → Sketcher constraints → Constrain angle}} form the top menu entry
# A datum edit dialog box pops up.
# Modify the angle if necessary. '''Note:''' The angle can be entered as an expression that will be evaluated and the result will be stored.
# Click {{KEY|OK}}


===[[Sketcher_Workbench#Continue_modes|Continue mode]]===
<!--T:7-->
As with any datum constraint, it is possible to change the angle value later by double-clicking the constraint in constraint list or 3d view. Entering a negative value will cause the angle direction to flip.


# Make sure there is no selection.
==Constraint modes== <!--T:8-->
# There are several ways to invoke the tool:
===line slope angle===
#* {{Version|0.22}}: If the {{MenuCommand|Dimensioning constraints}} [[Sketcher_Preferences#General|preference]] is set to {{Value|Single tool}} (default): press the down arrow to the right of the {{Button|[[Image:Sketcher_Dimension.svg||x16px]][[Image:Toolbar_flyout_arrow.svg|x16px]]}} button and select the {{MenuCommand|[[Image:Sketcher_ConstrainAngle.svg|16px]] Constrain angle}} option from the dropdown.
'''Accepted selection:''' line
#* If this preference has a different value (and in {{VersionMinus|0.21}}): press the {{Button|[[Image:Sketcher_ConstrainAngle.svg|16px]] [[Sketcher_ConstrainAngle|Constrain angle]]}} button.
#* Select the {{MenuCommand|Sketch → Sketcher constraints → [[Image:Sketcher_ConstrainAngle.svg|16px]] Constrain angle}} option from the menu.
#* {{Version|0.22}}: Right-click in the [[3D_view|3D view]] and select the {{MenuCommand|Dimension → [[Image:Sketcher_ConstrainAngle.svg|16px]] Constrain angle}} option from the context menu.
#* Use the keyboard shortcut: {{KEY|K}} then {{KEY|A}}.
# The cursor changes to a white cross with the tool icon.
# Do one of the following:
#* Select two lines.
#* Select a point and two edges (in that order).
#* Select an edge, a point and an edge (idem).
# If a [[Sketcher_ToggleDrivingConstraint|driving dimensional constraint]] is created, depending on the [[Sketcher_Preferences#Display|preferences]], a dialog opens to [[Sketcher_Workbench#Edit_constraints|edit its value]]. A negative value will reverse the angle direction.
# An Angle constraint is added. If a point and two edges have been selected, up to two [[Sketcher_ConstrainPointOnObject|Point onto object constraints]] can also be added. See [[#Between_two_edges_at_point|Examples]].
# Optionally keep creating constraints.
# To finish, right-click or press {{KEY|Esc}}, or start another geometry or constraint creation tool.


===Run-once mode===
<!--T:9-->

[[Image:Sketcher ConsraintAngle mode1.png|600px]]
# Do one of the following:
#* Select a single line.
#* Select a single circular arc.
#* Select two lines.
#* Select a point and two edges (in any order).
# Invoke the tool as explained above.
# Optionally [[Sketcher_Workbench#Edit_constraints|edit the constraint value]].
# An Angle constraint is added. If a point and two edges have been selected, up to two [[Sketcher_ConstrainPointOnObject|Point onto object constraints]] can also be added. See [[#Between_two_edges_at_point|Examples]].

==Examples==

===Single line=== <!--T:31-->

</translate>
[[Image:Sketcher_ConsraintAngle_mode1.png|400px]]
<translate>


<!--T:10-->
<!--T:10-->
The constraint sets the polar angle of line's direction. It is the angle between the line and X axis of the sketch.
The angle of the line with the positive X axis of the sketch is fixed.


===arc span (v0.15)=== <!--T:11-->
===Single circular arc=== <!--T:33-->
'''Accepted selection:''' arc of circle


</translate>
<!--T:12-->
[[Image:Sketcher ConsraintAngle mode2.png|600px]]
[[Image:Sketcher_ConsraintAngle_mode2.png|400px]]
<translate>


<!--T:13-->
<!--T:13-->
The aperture angle of the arc is fixed.
In this mode, the constraint fixes angular span of a circular arc.


===between lines=== <!--T:14-->
===Between two lines=== <!--T:34-->
'''Accepted selection:''' line + line


</translate>
<!--T:15-->
[[Image:Sketcher ConsraintAngle mode3.png|600px]]
[[Image:Sketcher_ConsraintAngle_mode3.png|400px]]
<translate>


<!--T:16-->
<!--T:16-->
In this mode, the constraint sets the angle between two lines. It is not required that the lines intersect.
The angle between the two lines is fixed. It is not required that the lines intersect.


===between curves at intersection (angle-via-point) (v0.15)=== <!--T:17-->
===Between two edges at point=== <!--T:35-->
'''Accepted selection:''' any line/curve + any line/curve + any point


</translate>
<!--T:18-->
[[Image:Sketcher ConsraintAngle mode4.png|600px]]
[[Image:Sketcher_ConsraintAngle_mode4.png|400px]]
<translate>


The angle between the two edges at a given point is fixed. The point can be any point, e.g. the center of a circle, the endpoint of an edge, or the origin, it can belong to either or both edges, and it can also be a [[Sketcher_CreatePoint|Point object]]. If required [[Sketcher_ConstrainPointOnObject|Point onto object constraint(s)]] are added to ensure the point lies on both (extended) edges. These additional constraints are called [[Sketcher_helper_constraint|helper constraints]].
<!--T:19-->
In this mode, angle between two curves is constrained at the point of their intersection. The intersection point can be on curves' extensions. The point should be specified explicitly, since curves typically intersect in more than one point.

<!--T:20-->
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 ([[Sketcher helper constraint|helper constraints]] will be added, if necessary), and the angle between curves will be constrained at the point. These [[Sketcher helper constraint|helper constraints]] are plain regular constraints. They can be added manually, or deleted. There are no helper constraints on the example picture above, because the point selected is already the intersection of curves.


==Scripting== <!--T:21-->
==Scripting== <!--T:21-->


<!--T:22-->
<!--T:22-->
Angle Constraint can be created from [[macros]] and from the python console by using the following:
Angle Constraint can be created from [[Macros|macros]] and from the [[Python|Python]] console by using the following:
</translate>
</translate>
{{Code|code=
{{Code|code=
Line 98: Line 119:
<!--T:23-->
<!--T:23-->
where:
where:
:* <tt>Sketch</tt> is a sketch object
:* {{incode|Sketch}} is a sketch object
:* <tt>iline, iline1, iline2</tt> are integers specifying the lines by their ordinal numbers in <tt>Sketch</tt>.
:* {{incode|iline, iline1, iline2}} are integers specifying the lines by their ordinal numbers in {{incode|Sketch}}.
:* <tt>pointpos1, pointpos2</tt> should be 1 for start point and 2 for end point. The choice of endpoints allows to set internal angle (or external), and it affects how the constraint is drawn on the screen.
:* {{incode|pointpos1, pointpos2}} should be 1 for start point and 2 for end point. The choice of endpoints allows to set internal angle (or external), and it affects how the constraint is drawn on the screen.
:* <tt>geoidpoint</tt> and <tt>pointpos</tt> in AngleViaPoint are the indexes specifying the point of intersection.
:* {{incode|geoidpoint}} and {{incode|pointpos}} in {{incode|AngleViaPoint}} are the indexes specifying the point of intersection.
:* <tt>angle</tt> is the angle value in radians. The angle is counted between tangent vectors in counterclockwise direction. Tangent vectors are pointing from start to end for the lines (or vice versa if ending point is supplied in angle between lines mode), and along counterclockwise direction for circles, arcs and ellipses. Quantity is also accepted as an angle (e.g. <tt>App.Units.Quantity('45 deg')</tt>)
:* {{incode|angle}} is the angle value in radians. The angle is counted between tangent vectors in counterclockwise direction. Tangent vectors are pointing from start to end for the lines (or vice versa if ending point is supplied in angle between lines mode), and along counterclockwise direction for circles, arcs and ellipses. Quantity is also accepted as an angle (e.g. {{incode|App.Units.Quantity('45 deg')}})


<!--T:36-->
The [[Sketcher_scripting|Sketcher scripting]] page explains the values which can be used for {{incode|iline}}, {{incode|iline1}}, {{incode|iline2}}, {{incode|pointpos1}}, {{incode|pointpos2}}, {{incode|geoidpoint}} and {{incode|pointpos}} and contains further examples on how to create constraints from Python scripts.




<!--T:26-->
<!--T:26-->
{{Docnav
{{Docnav|[[Sketcher_ConstrainRadius|Radius]]|[[Sketcher ConstrainSnellsLaw|Snell's Law]]|[[Sketcher_Workbench|Sketcher]]|IconL=Constraint_Radius.png|IconC=Workbench_Sketcher.svg|IconR=Constraint_SnellsLaw.png}}
|[[Sketcher_ConstrainDiameter|Diameter]]

|[[Sketcher_ConstrainLock|Lock]]
<!--T:27-->
|[[Sketcher_Workbench|Sketcher]]
{{Sketcher Tools navi}}
|IconL=Sketcher_ConstrainDiameter.svg

|IconR=Sketcher_ConstrainLock.svg
<!--T:28-->
|IconC=Workbench_Sketcher.svg
{{Userdocnavi}}
}}


</translate>
</translate>
{{Sketcher_Tools_navi{{#translation:}}}}
{{clear}}
{{Userdocnavi{{#translation:}}}}

Latest revision as of 17:38, 25 March 2024

This documentation is a work in progress. Please don't mark it as translatable since it will change in the next hours and days.

Sketcher ConstrainAngle

Menu location
Sketch → Sketcher constraints → Constrain angle
Workbenches
Sketcher
Default shortcut
K A
Introduced in version
-
See also
Sketcher Constrain distance, Sketcher Constraint Perpendicular

Description

The Sketcher ConstrainAngle tool fixes the angle between two edges (lines are then treated as infinite, and open curves are virtually extended as well), the angle of a line with the X axis, or the aperture angle of a circular arc.

Usage

See also: Drawing aids.

Continue mode

  1. Make sure there is no selection.
  2. There are several ways to invoke the tool:
    • introduced in version 0.22: If the Dimensioning constraints preference is set to Single tool (default): press the down arrow to the right of the button and select the Constrain angle option from the dropdown.
    • If this preference has a different value (and in version 0.21 and below): press the Constrain angle button.
    • Select the Sketch → Sketcher constraints → Constrain angle option from the menu.
    • introduced in version 0.22: Right-click in the 3D view and select the Dimension → Constrain angle option from the context menu.
    • Use the keyboard shortcut: K then A.
  3. The cursor changes to a white cross with the tool icon.
  4. Do one of the following:
    • Select two lines.
    • Select a point and two edges (in that order).
    • Select an edge, a point and an edge (idem).
  5. If a driving dimensional constraint is created, depending on the preferences, a dialog opens to edit its value. A negative value will reverse the angle direction.
  6. An Angle constraint is added. If a point and two edges have been selected, up to two Point onto object constraints can also be added. See Examples.
  7. Optionally keep creating constraints.
  8. To finish, right-click or press Esc, or start another geometry or constraint creation tool.

Run-once mode

  1. Do one of the following:
    • Select a single line.
    • Select a single circular arc.
    • Select two lines.
    • Select a point and two edges (in any order).
  2. Invoke the tool as explained above.
  3. Optionally edit the constraint value.
  4. An Angle constraint is added. If a point and two edges have been selected, up to two Point onto object constraints can also be added. See Examples.

Examples

Single line

The angle of the line with the positive X axis of the sketch is fixed.

Single circular arc

The aperture angle of the arc is fixed.

Between two lines

The angle between the two lines is fixed. It is not required that the lines intersect.

Between two edges at point

The angle between the two edges at a given point is fixed. The point can be any point, e.g. the center of a circle, the endpoint of an edge, or the origin, it can belong to either or both edges, and it can also be a Point object. If required Point onto object constraint(s) are added to ensure the point lies on both (extended) edges. These additional constraints are called helper constraints.

Scripting

Angle Constraint can be created from macros and from the Python console by using the following:

# line slope angle
Sketch.addConstraint(Sketcher.Constraint('Angle',iline,angle))

# angular span of arc
Sketch.addConstraint(Sketcher.Constraint('Angle',iarc,angle))

# angle between lines
Sketch.addConstraint(Sketcher.Constraint('Angle',iline1,pointpos1,iline2,pointpos2,angle))

# angle-via-point (no helper constraints are added automatically when from python)
Sketch.addConstraint(Sketcher.Constraint('AngleViaPoint',icurve1,icurve2,geoidpoint,pointpos,angle))

where:

  • Sketch is a sketch object
  • iline, iline1, iline2 are integers specifying the lines by their ordinal numbers in Sketch.
  • pointpos1, pointpos2 should be 1 for start point and 2 for end point. The choice of endpoints allows to set internal angle (or external), and it affects how the constraint is drawn on the screen.
  • geoidpoint and pointpos in AngleViaPoint are the indexes specifying the point of intersection.
  • angle is the angle value in radians. The angle is counted between tangent vectors in counterclockwise direction. Tangent vectors are pointing from start to end for the lines (or vice versa if ending point is supplied in angle between lines mode), and along counterclockwise direction for circles, arcs and ellipses. Quantity is also accepted as an angle (e.g. App.Units.Quantity('45 deg'))

The Sketcher scripting page explains the values which can be used for iline, iline1, iline2, pointpos1, pointpos2, geoidpoint and pointpos and contains further examples on how to create constraints from Python scripts.