Draft BezCurve: Difference between revisions
(More details) |
(More information for the properties) |
||
Line 50: | Line 50: | ||
<!--T:7--> |
<!--T:7--> |
||
* {{PropertyData| |
* {{PropertyData|Degree}}: specifies the degree of the Bezier curve or the individual segments. |
||
* {{PropertyData|Closed}}: specifies if the curve is closed or not. If the curve is initially open, this value is {{FALSE}}; setting it to {{TRUE}} will draw a segment to close the curve. If the curve is initially closed, this value is {{TRUE}}; setting it to {{FALSE}} will remove the last segment, and make the curve open. |
|||
* {{PropertyData|Degree}}: Specifies the degree of the Bezier Curve (or segments) |
|||
* {{PropertyData|Make Face}}: specifies if the curve makes a face or not. If it is {{TRUE}} a face is created, otherwise only the perimeter is considered part of the object. This property only works if {{PropertyData|Closed}} is {{TRUE}}. |
|||
* {{PropertyData|Continuity}}: (read-only) when the curve is closed, indicates the continuity of the curve {{incode|[0]}}, or {{incode|[0,0]}}. Otherwise it's {{incode|[]}}. |
|||
==Scripting== <!--T:8--> |
==Scripting== <!--T:8--> |
Revision as of 16:09, 9 November 2018
Draft BezCurve |
Menu location |
---|
Draft → BezCurve |
Workbenches |
Draft, Arch |
Default shortcut |
B Z |
Introduced in version |
0.14 |
See also |
None |
Description
The BezCurve tool creates a Bezier Curve, or a piecewise Bezier curve, from several points in the current work plane. It uses the Draft Linestyle set on the Draft Tray.
How to use
- Press the Draft BezCurve button, or press B then Z keys.
- Click a first point on the 3D view, or type a coordinate and press the add point button.
- Click additional points on the 3D view, or type a coordinate and press the add point button.
- Press Esc or the Close button, or double-click the last point to complete the edition.
The object is created as a single Bezier curve of degree number_of_points - 1
.
The curve can be transformed to a piecewise wire made of curves of a specified degree by changing its properties.
The control points of the Bezier curve can be edited by double clicking on the element in the tree view, or by pressing the Draft Edit button.
Options
- Press A or the Finish button to finish the curve, leaving it open.
- Press O or the Close button to close the curve, that is, a segment will be added from the last point to the first one to form a face. At least four points, a curve of degree three, are required to form a face.
- Press W or the Wipe button to remove the curve segments already placed, but keep editing the curve from the last point.
- Press U or the Set WP button to adjust the current working plane in the orientation of the last point.
- Press X, Y or Z after a point to constrain the next point on the given axis.
- To enter coordinates manually, simply enter the numbers, then press Enter between each X, Y and Z component.
- Press R or click the checkbox to toggle relative mode. If relative mode is on, the coordinates of the next point are relative to the last one; if not, they are absolute, taken from the origin (0,0,0).
- Press T or click the checkbox to toggle continue mode. If continue mode is on, the BezCurve tool will restart after you finish the curve, allowing you to draw another one without pressing the tool button again.
- Press L or click the checkbox to toggle filled mode. If filled mode is on, a closed wire will create a filled face (DataMake Face
true
); if not, the closed wire will not make a face (DataMake Facefalse
). - Press Ctrl while drawing to force snapping your point to the nearest snap location, independently of the distance.
- Press Shift while drawing to constrain your next point horizontally or vertically in relation to the last one.
- Press Ctrl+Z or press the Undo button to undo the last point.
- Press Esc or the Close button to abort the current command; curve segments already placed will remain.
Properties
- DataDegree: specifies the degree of the Bezier curve or the individual segments.
- DataClosed: specifies if the curve is closed or not. If the curve is initially open, this value is
false
; setting it totrue
will draw a segment to close the curve. If the curve is initially closed, this value istrue
; setting it tofalse
will remove the last segment, and make the curve open. - DataMake Face: specifies if the curve makes a face or not. If it is
true
a face is created, otherwise only the perimeter is considered part of the object. This property only works if DataClosed istrue
. - DataContinuity: (read-only) when the curve is closed, indicates the continuity of the curve
[0]
, or[0,0]
. Otherwise it's[]
.
Scripting
The BezCurve tool can by used in macros and from the python console by using the following function:
makeBezCurve(pointslist,[closed],[placement],[support],[degree])
- Create a Bezier Curve object from the given list of vectors. Instead of a pointslist, you can also pass a Part Wire.
Example:
import FreeCAD,Draft
myFeature = Draft.makeBezCurve(Draft.makeBezCurve(points,False)
Contraining Nodes
The segment endpoints in a piecewise Bezier Curve can be constrained such that adjacent control points are tangent or symmetric to the segments at the endpoint. This is done after object creation using Draft Edit.
- Sharp - remove constraints
- Tangent - force adjacent control points to be tangent
- Symmetric - force adjacent control points to be tangent and equi-distant
Limitations
- This tool is not available before FreeCAD version 0.14
- The Points Property does not yet appear in the properties list.
- OpenCascade does not support Bezier Curve with degree > 25. This should not be a problem in practice.
- Drafting: Line, Polyline, Fillet, Arc, Arc by 3 points, Circle, Ellipse, Rectangle, Polygon, B-spline, Cubic Bézier curve, Bézier curve, Point, Facebinder, ShapeString, Hatch
- Annotation: Text, Dimension, Label, Annotation styles, Annotation scale
- Modification: Move, Rotate, Scale, Mirror, Offset, Trimex, Stretch, Clone, Array, Polar array, Circular array, Path array, Path link array, Point array, Point link array, Edit, Subelement highlight, Join, Split, Upgrade, Downgrade, Wire to B-spline, Draft to sketch, Set slope, Flip dimension, Shape 2D view
- Draft Tray: Select plane, Set style, Toggle construction mode, AutoGroup
- Snapping: Snap lock, Snap endpoint, Snap midpoint, Snap center, Snap angle, Snap intersection, Snap perpendicular, Snap extension, Snap parallel, Snap special, Snap near, Snap ortho, Snap grid, Snap working plane, Snap dimensions, Toggle grid
- Miscellaneous: Apply current style, Layer, Manage layers, Add a new named group, Move to group, Select group, Add to construction group, Toggle normal/wireframe display, Create working plane proxy, Heal, Show snap toolbar
- Additional: Constraining, Pattern, Preferences, Import Export Preferences, DXF/DWG, SVG, OCA, DAT
- Context menu:
- Layer container: Merge layer duplicates, Add new layer
- Layer: Activate this layer, Select layer contents
- Text: Open hyperlinks
- Wire: Flatten
- Working plane proxy: Write camera position, Write objects state
- Getting started
- Installation: Download, Windows, Linux, Mac, Additional components, Docker, AppImage, Ubuntu Snap
- Basics: About FreeCAD, Interface, Mouse navigation, Selection methods, Object name, Preferences, Workbenches, Document structure, Properties, Help FreeCAD, Donate
- Help: Tutorials, Video tutorials
- Workbenches: Std Base, Arch, Assembly, CAM, Draft, FEM, Inspection, Mesh, OpenSCAD, Part, PartDesign, Points, Reverse Engineering, Robot, Sketcher, Spreadsheet, Start, Surface, TechDraw, Test Framework, Web
- Hubs: User hub, Power users hub, Developer hub