Sketcher ConstrainTangent/pl: Difference between revisions

From FreeCAD Documentation
No edit summary
(Updating to match new version of source page)
 
(55 intermediate revisions by 2 users not shown)
Line 1: Line 1:
<languages/>
<languages/>

{{Docnav/pl
{{Docnav/pl
|[[Sketcher_ConstrainPerpendicular/pl|Wiązanie prostopadłości]]
|[[Sketcher_ConstrainPerpendicular/pl|Wiązanie prostopadłości]]
|[[Sketcher_ConstrainEqual/pl|Wiązanie równości]]
|[[Sketcher_ConstrainEqual/pl|Wiązanie równości]]
|[[Sketcher_Workbench/pl|Sketcher]]
|[[Sketcher_Workbench/pl|środowisko pracy Szkicownik]]
|IconL=Sketcher_ConstrainPerpendicular.svg
|IconL=Constraint_Perpendicular.png
|IconR=Sketcher_ConstrainEqual.png
|IconC=Workbench_Sketcher.svg
|IconC=Workbench_Sketcher.svg
|IconR=Constraint_EqualLength.png
}}
}}


<div class="mw-translate-fuzzy">
{{GuiCommand/pl
{{GuiCommand/pl
|Name=Sketcher ConstrainTangent
|Name=Sketcher ConstrainTangent
|Name/pl=Szkicownik: Wiązanie styczności
|Name/pl=Szkicownik: Wiązanie styczności
|Workbenches=[[Sketcher Workbench/pl|Sketcher]]
|MenuLocation=Sketch → Wiązania szkicownika → Wiązanie styczności
|MenuLocation=Sketch → Wiązania szkicownika → Wiązanie styczności
|Workbenches=[[Sketcher_Workbench/pl|Szkicownik]]
|Shortcut={{KEY|T}}
|Shortcut={{KEY|T}}
|SeeAlso=[[Sketcher ConstrainPointOnObject/pl|Wiązanie punktu na obiekcie]]
|SeeAlso=[[Sketcher_ConstrainPointOnObject/pl|Wiązanie punktu na obiekcie]]
}}
}}
</div>


<span id="Description"></span>
==Opis==
==Opis==


<div class="mw-translate-fuzzy">
Tangent Constraint makes two curves to touch each other (be tangent). Lines are treated infinite, and arcs are treated as full circles/ellipses. The constraint is also capable of connecting two curves, forcing them tangent at the joint, thus making the joint smooth.
Wiązanie styczności tworzy dwie krzywe, które dotykają się wzajemnie ''(są styczne)''. Linie są traktowane jako nieskończone, a łuki są traktowane jako pełne koła/elipsy. Wiązanie jest również w stanie połączyć dwie krzywe, zmuszając je do zetknięcia się ze sobą po stycznej, co sprawia, że połączenie jest gładkie.
</div>


<span id="Usage"></span>
==Użycie==
==Użycie==


See also: [[Sketcher_Workbench#Drawing_aids|Drawing aids]].
There are four different ways the constraint can be applied:
# between two curves (available not for all curves)
# between two endpoints of a curve, making a smooth joint
# between a curve and an endpoint of another curve
# between two curves at user-defined point


===[[Sketcher_Workbench#Continue_modes|Continue mode]]===
To apply tangent 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.


# Make sure there is no selection.
===Between two curves (direct tangency)===
# There are several ways to invoke the tool:
#* Press the {{Button|[[Image:Sketcher_ConstrainTangent.svg|16px]] [[Sketcher_ConstrainTangent|Constrain tangent or collinear]]}} button.
#* Select the {{MenuCommand|Sketch → Sketcher constraints → [[Image:Sketcher_ConstrainTangent.svg|16px]] Constrain tangent or collinear}} option from the menu.
#* {{Version|1.0}}: Right-click in the [[3D_view|3D view]] and select the {{MenuCommand|Constrain → [[Image:Sketcher_ConstrainTangent.svg|16px]] Constrain tangent or collinear}} option from the context menu.
#* Use the keyboard shortcut: {{KEY|T}}.
# The cursor changes to a cross with the tool icon.
# Do one of the following:
#* Select two edges. The edges can be any edge except a B-spline.
#* Select a point and two edges (in that order).
#* Select an edge, a point and another edge (idem).
# A Tangent constraint is added. If a point and two edges have been selected, up to two [[Sketcher_ConstrainPointOnObject|Point on 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===

# Do one of the following:
#* Select two edges (see above).
#* Select two endpoints belonging to different edges.
#* Select an edge and the endpoint of another edge (in any order).
#* Select a point and two edges (idem).
# Invoke the tool as explained above, or with the following additional option:
#* {{Version|1.0}}: Right-click in the [[3D_view|3D view]] and select the {{MenuCommand|[[Image:Sketcher_ConstrainTangent.svg|16px]] Constrain tangent or collinear}} option from the context menu.
# A Tangent constraint is added. If a point and two edges have been selected, up to two [[Sketcher_ConstrainPointOnObject|Point on object constraints]] can also be added. See [[#Between_two_edges_at_point|Examples]].

==Examples==

<span id="Between_two_edges"></span>
<div class="mw-translate-fuzzy">
===Pomiędzy dwoma krzywymi ''(bezpośrednia styczność)''===
[[Image:Sketcher ConsraintTangent mode1.png|600px]]
[[Image:Sketcher ConsraintTangent mode1.png|600px]]
</div>


[[Image:Sketcher_ConsraintTangent_mode1.png|400px]]
Two curves will be made tangent, and the point of tangency will be implicit. This mode is applied if two curves were selected.


The two edges are made tangent. If one of the edges is a [[Sketcher_Workbench#Sketcher_CompCreateConic|conic]], a [[Sketcher_CreatePoint|Point object]] that has a [[Sketcher_ConstrainPointOnObject|Point on object constraint]] with both (extended) edges is added.
'''Accepted selection:'''
* line + line, circle, arc, ellipse, arc-of-ellipse
* circle, arc + circle, arc
If direct tangency between selected curves is not supported (e.g. between a circle and an ellipse), a helper point will be added to sketch automatically, and tangency-via-point will be applied.


<div class="mw-translate-fuzzy">
It is not recommended to reconstruct the point of tangency by creating a point and constraining it to lie on both curves. It will work, but the convergence will be seriously slower, jumpier, and will require about twice as many iterations to converge than normal. Use other modes of this constraint if the point of tangency is needed.
Nie zaleca się rekonstrukcji punktu styczności poprzez tworzenie punktu i wiązanie go z ułożeniem na obu krzywych. Będzie to działać, ale zbieżność będzie znacznie wolniejsza, bardziej skokowa i będzie wymagała około dwa razy więcej iteracji do zbieżności niż normalnie. Użyj innych trybów tego wiązania, jeśli punkt styczności jest potrzebny.
</div>


<span id="Between_two_endpoints"></span>
===Between two endpoints (point-to-point tangency)===
<div class="mw-translate-fuzzy">
===Między dwoma punktami końcowymi (styczność punkt-punkt)===
[[Image:Sketcher ConsraintTangent mode2.png|600px]]
[[Image:Sketcher ConsraintTangent mode2.png|600px]]
</div>


[[Image:Sketcher_ConsraintTangent_mode2.png|400px]]
In this mode, the endpoints are made coincident, and the joint is made tangent (C1-smooth, or "sharp", depending on the placement of curves before the constraint is applied). This mode is applied when two endpoints of two curves were selected.


The endpoints are made coincident, and the angle between the edges at that point is set to 180° (smooth joint) or 0° (sharp joint), depending on the placement of the edges before the constraint is applied.
'''Accepted selection:'''
* endpoint of line/arc/arc-of-ellipse + endpoint of line/arc/arc-of-ellipse (i.e., two endpoints of any two curves)


<span id="Between_edge_and_endpoint"></span>
===Between curve and endpoint (point-to-curve tangency)===
<div class="mw-translate-fuzzy">
===Pomiędzy krzywą a punktem końcowym (styczność punkt - krzywa)===
[[Image:Sketcher ConsraintTangent mode3.png|600px]]
[[Image:Sketcher ConsraintTangent mode3.png|600px]]
</div>


[[Image:Sketcher_ConsraintTangent_mode3.png|400px]]
In this mode, an endpoint of one curve is constrained to lie on the other curve, and the curves are forced tangent at the point. This mode is applied when a curve and an endpoint of another curve were selected.


<div class="mw-translate-fuzzy">
'''Accepted selection:'''
W tym trybie, punkt końcowy jednej krzywej jest związany z położeniem na drugiej krzywej, a krzywe stają się w tym punkcie stycznymi. Tryb ten jest stosowany, gdy krzywa i punkt końcowy innej krzywej zostały wybrane.
* line, circle, arc, ellipse, arc-of-ellipse + endpoint of line/arc/arc-of-ellipse (i.e., any curve + endpoint of any curve)
</div>


<span id="Between_two_edges_at_point"></span>

<div class="mw-translate-fuzzy">
===Between two curves at point (tangent-via-point) (v0.15)===
===Między dwiema krzywymi w punkcie ''(styczna do punktu) (v0.15)''===
[[Image:Sketcher ConsraintTangent mode4.png|600px]]
[[Image:Sketcher ConsraintTangent mode4.png|600px]]
</div>


[[Image:Sketcher_ConsraintTangent_mode4.png|400px]]
In this mode, two curves are made tangent, and the point of tangency is tracked. This mode is applied when two curves and a point were selected.


<div class="mw-translate-fuzzy">
'''Accepted selection:'''
W tym trybie dwie krzywe są styczne, a punkt styczności jest śledzony. Ten tryb jest stosowany, gdy wybrano dwie krzywe i punkt.
* any line/curve + any line/curve + any point
</div>
"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.


<div class="mw-translate-fuzzy">
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 curves will be forced tangent at the point. These [[Sketcher helper constraint|helper constraints]] are plain regular constraints. They can be added manually, or deleted.
W porównaniu z bezpośrednią stycznością, wiązanie to jest wolniejsze, ponieważ istnieje więcej stopni swobody, ale jeśli punkt styczności jest potrzebny, jest to tryb zalecany, ponieważ oferuje lepszą zbieżność w porównaniu z bezpośrednią stycznością + punkt na dwóch krzywych.
</div>


<span id="Between_two_lines"></span>
Compared to direct tangency, this constraint is slower, because there are more degrees of freedom involved, but if the point of tangency is needed, it is the recommended mode because it offers better convergence compared to direct tangency + point on two curves.
<div class="mw-translate-fuzzy">
===Pomiędzy dwoma liniami ''(współliniowe)''===
</div>


[[Image:Sketcher_ConstraintTangent_mode5.png|400px]]
The placement of the point before the constraint is applied is a hint for the solver for where the tangency should be. With this constraint, one can constrain two ellipses to touch each other in two places.


The two lines are made collinear.

<span id="Scripting"></span>
==Tworzenie skryptów==
==Tworzenie skryptów==


Wiązanie styczności może być utworzone przez [[Macros/pl|makropolecenie]] i z konsoli [[Python/pl|Python]] za pomocą następującej funkcji:
Tangent Constraint can be created from [[macros]] and from the python console by using the following:
{{Code|code=
{{Code|code=
# direct tangency
# direct tangency
Line 94: Line 141:
Sketch.addConstraint(Sketcher.Constraint('TangentViaPoint',icurve1,icurve2,geoidpoint,pointpos))
Sketch.addConstraint(Sketcher.Constraint('TangentViaPoint',icurve1,icurve2,geoidpoint,pointpos))
}}
}}
gdzie:
where:
:* {{incode|Sketch}} is a sketch object
:* {{incode|Sketch}} jest obiektem typu szkic
:* {{incode|icurve1}}, {{incode|icurve2}} are two integers identifying the curves to be made tangent. The integers are indexes in the sketch (the value, returned by {{incode|Sketch.addGeometry}}).
:* {{incode|icurve1}}, {{incode|icurve2}} dwiema liczbami całkowitymi określającymi krzywe, które mają być styczne. Liczby całkowite to indeksy w szkicu ''(wartość zwracana przez{{incode|Sketch.addGeometry}})''.
:* {{incode|pointpos1}}, {{incode|pointpos2}} should be 1 for start point and 2 for end point.
:* {{incode|pointpos1}}, {{incode|pointpos2}} powinny wynosić 1 dla punktu początkowego i 2 dla punktu końcowego.
:* {{incode|geoidpoint}} and {{incode|pointpos}} in {{incode|TangentViaPoint}} are the indexes specifying the point of tangency.
:* {{incode|geoidpoint}} oraz {{incode|pointpos}} w {{incode|TangentViaPoint}} indeksami określającymi punkt styczności.

Strona [[Sketcher_scripting/pl|Skrypty szkicownika]] wyjaśnia wartości, które mogą być używane dla {{incode|incurve1}}, {{incode|incurve2}}, {{incode|pointpos1}}, {{incode|pointpos2}}, {{incode|geoidpoint}} i {{incode|pointpos}}, a także zawiera kolejne przykłady tworzenia wiązań za pomocą skryptów języka Python.



{{Docnav/pl
{{Docnav/pl
|[[Sketcher_ConstrainPerpendicular/pl|Wiązanie prostopadłości]]
|[[Sketcher_ConstrainPerpendicular/pl|Wiązanie prostopadłości]]
|[[Sketcher_ConstrainEqual/pl|Wiązanie równości]]
|[[Sketcher_ConstrainEqual/pl|Wiązanie równości]]
|[[Sketcher_Workbench/pl|Sketcher]]
|[[Sketcher_Workbench/pl|środowisko pracy Szkicownik]]
|IconL=Sketcher_ConstrainPerpendicular.svg
|IconL=Constraint_Perpendicular.png
|IconR=Sketcher_ConstrainEqual.png
|IconC=Workbench_Sketcher.svg
|IconC=Workbench_Sketcher.svg
|IconR=Constraint_EqualLength.png
}}
}}

{{Sketcher Tools navi{{#translation:}}}}
{{Sketcher_Tools_navi{{#translation:}}}}
{{Userdocnavi{{#translation:}}}}
{{Userdocnavi{{#translation:}}}}
{{clear}}

Latest revision as of 15:01, 23 April 2024

Szkicownik: Wiązanie styczności

Lokalizacja w menu
Sketch → Wiązania szkicownika → Wiązanie styczności
Środowisko pracy
Szkicownik
Domyślny skrót
T
Wprowadzono w wersji
-
Zobacz także
Wiązanie punktu na obiekcie

Opis

Wiązanie styczności tworzy dwie krzywe, które dotykają się wzajemnie (są styczne). Linie są traktowane jako nieskończone, a łuki są traktowane jako pełne koła/elipsy. Wiązanie jest również w stanie połączyć dwie krzywe, zmuszając je do zetknięcia się ze sobą po stycznej, co sprawia, że połączenie jest gładkie.

Użycie

See also: Drawing aids.

Continue mode

  1. Make sure there is no selection.
  2. There are several ways to invoke the tool:
    • Press the Constrain tangent or collinear button.
    • Select the Sketch → Sketcher constraints → Constrain tangent or collinear option from the menu.
    • introduced in version 1.0: Right-click in the 3D view and select the Constrain → Constrain tangent or collinear option from the context menu.
    • Use the keyboard shortcut: T.
  3. The cursor changes to a cross with the tool icon.
  4. Do one of the following:
    • Select two edges. The edges can be any edge except a B-spline.
    • Select a point and two edges (in that order).
    • Select an edge, a point and another edge (idem).
  5. A Tangent constraint is added. If a point and two edges have been selected, up to two Point on object constraints can also be added. See Examples.
  6. Optionally keep creating constraints.
  7. 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 two edges (see above).
    • Select two endpoints belonging to different edges.
    • Select an edge and the endpoint of another edge (in any order).
    • Select a point and two edges (idem).
  2. Invoke the tool as explained above, or with the following additional option:
  3. A Tangent constraint is added. If a point and two edges have been selected, up to two Point on object constraints can also be added. See Examples.

Examples

Pomiędzy dwoma krzywymi (bezpośrednia styczność)

The two edges are made tangent. If one of the edges is a conic, a Point object that has a Point on object constraint with both (extended) edges is added.

Nie zaleca się rekonstrukcji punktu styczności poprzez tworzenie punktu i wiązanie go z ułożeniem na obu krzywych. Będzie to działać, ale zbieżność będzie znacznie wolniejsza, bardziej skokowa i będzie wymagała około dwa razy więcej iteracji do zbieżności niż normalnie. Użyj innych trybów tego wiązania, jeśli punkt styczności jest potrzebny.

Między dwoma punktami końcowymi (styczność punkt-punkt)

The endpoints are made coincident, and the angle between the edges at that point is set to 180° (smooth joint) or 0° (sharp joint), depending on the placement of the edges before the constraint is applied.

Pomiędzy krzywą a punktem końcowym (styczność punkt - krzywa)

W tym trybie, punkt końcowy jednej krzywej jest związany z położeniem na drugiej krzywej, a krzywe stają się w tym punkcie stycznymi. Tryb ten jest stosowany, gdy krzywa i punkt końcowy innej krzywej zostały wybrane.

Między dwiema krzywymi w punkcie (styczna do punktu) (v0.15)

W tym trybie dwie krzywe są styczne, a punkt styczności jest śledzony. Ten tryb jest stosowany, gdy wybrano dwie krzywe i punkt.

W porównaniu z bezpośrednią stycznością, wiązanie to jest wolniejsze, ponieważ istnieje więcej stopni swobody, ale jeśli punkt styczności jest potrzebny, jest to tryb zalecany, ponieważ oferuje lepszą zbieżność w porównaniu z bezpośrednią stycznością + punkt na dwóch krzywych.

Pomiędzy dwoma liniami (współliniowe)

The two lines are made collinear.

Tworzenie skryptów

Wiązanie styczności może być utworzone przez makropolecenie i z konsoli Python za pomocą następującej funkcji:

# direct tangency
Sketch.addConstraint(Sketcher.Constraint('Tangent',icurve1,icurve2))

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

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

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

gdzie:

  • Sketch jest obiektem typu szkic
  • icurve1, icurve2 są dwiema liczbami całkowitymi określającymi krzywe, które mają być styczne. Liczby całkowite to indeksy w szkicu (wartość zwracana przezSketch.addGeometry).
  • pointpos1, pointpos2 powinny wynosić 1 dla punktu początkowego i 2 dla punktu końcowego.
  • geoidpoint oraz pointpos w TangentViaPoint są indeksami określającymi punkt styczności.

Strona Skrypty szkicownika wyjaśnia wartości, które mogą być używane dla incurve1, incurve2, pointpos1, pointpos2, geoidpoint i pointpos, a także zawiera kolejne przykłady tworzenia wiązań za pomocą skryptów języka Python.