Sketcher ConstrainTangent/ru

Описание
Ограничение касательности делает две кривые касающимися друг друга. Линии полагаются бесконечными, а дуги как полные окружности или эллипсы. Ограничение так же может соединять две кривые, заставляя их идти по касательной в точке соединения, делая переход гладким.

Использование
Возможно четыре варианта назначения ограничения:
 * 1) между двумя кривыми (доступно не для всех кривых)
 * 2) между двумя конечными точками кривой, делая гладкое соединение
 * 3) между кривой и конечной точкой другой кривой
 * 4) между двумя кривыми в точке, определённой пользователем

Для назначения ограничения касательности следует:
 * Выделить две или три элемента эскиза.
 * Вызвать ограничение, кликнув его иконку на панели инструментов или выделив в меню, или использовав клавиатурное сокращение.

Между двумя кривыми (прямое касание)


Две прямые станут касательными, но точка касания будет неопределённой. Этот режим назначается, когда выделены две кривые.

Допустимые выделения: Если прямое касание между выделенными кривыми не поддерживается (например, между оуружностью и эллипсом), автоматически будет добавлена вспомогательная точка, и будет применено tangency-via-point.
 * линия +  линия, окружность, дуга, эллипс, дуга эллипса
 * окружность, дуга +  окружность, дуга

Не рекомендуется реконструировать точку касания созданием точки и установкой принадлежности её обоим кривым. Это будет работать, но конвергенция будет значительно медленнее, сложнее, и потребует вдвое больше итераций чем в норме. Используйте другие режимы этого ограничения, если нужна точка касания.

Между двумя конечными точками (касание точка-к-точке)


В этом режиме конечные точки делаются совпадающими, и соединение делается касательным (C1-smooth, или "sharp", в зависимости от расположения кривых перед применением ограничения). Этот режим применяется, когда выделены две конечные точки двух кривых.

Допустимые выделения:
 * конечная точка линии/дуги/дуги-эллипса +  конечная точка линии/дуги/дуги-эллипса (т.е. две конечные точки любых двух кривых)

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


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.

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 (tangent-via-point) (v0.15)


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.

Accepted selection: "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.
 * any line/curve +  any line/curve  +  any point

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 tangent at the point. These helper constraints are plain regular constraints. They can be added manually, or deleted.

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.

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.

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

where:
 * is a sketch object
 * , are two integers identifying the curves to be made tangent. The integers are indexes in the sketch (the value, returned by ).
 * , should be 1 for start point and 2 for end point.
 * and in  are the indexes specifying the point of tangency.