The Draft Workbench is primarily focused on the creation and modification of 2D objects in FreeCAD. But it is not restricted to the XY plane of the global coordinate system. Its objects can have any orientation and position in 3D space, and some Draft objects can either be planar or non-planar.
Draft objects can be used for general drafting, similar to what can be done with Inkscape or AutoCAD. But they can also form the base for the creation of 3D objects in other workbenches. A Draft Wire may define the path of an Arch Wall, a Draft Polygon can be extruded with Part Extrude, etc. Many of the Draft modifier tools can be applied to 2D and 3D objects created with other workbenches as well. You can, for example, move a Sketch or create a Draft OrthoArray from a Part object.
The Draft Workbench also provides tools to define a working plane, a grid, and a snapping system to precisely control the position of geometry.
If your primary goal is the production of complex 2D drawings and DXF files, and you don't need 3D modelling, FreeCAD may not be the right choice for you. You may wish to consider a dedicated software program for technical drafting instead, such as LibreCAD or QCad.
The image shows the grid aligned with the XY plane.
On the left, in white, several planar objects.
On the right a non-planar Draft Wire used as the Path Object of a Draft PathArray.
-
Line: creates a straight line.
-
Polyline: creates a polyline, a sequence of several connected line segments.
-
Fillet: creates a fillet, a rounded corner, or a chamfer, a straight edge, between two Draft Lines. (v0.19)
:* Arc: creates a circular arc from a center, a radius, a start angle and an aperture angle.
:* Arc by 3 points: creates a circular arc from three points that define its circumference. (v0.19)
-
Circle: creates a circle from a center and a radius.
-
Ellipse: creates an ellipse from two points defining a rectangle in which the ellipse will fit.
-
Rectangle: creates a rectangle from two points.
-
Polygon: creates a regular polygon from a center and a radius.
-
B-spline: creates a B-spline curve from several points.
:* Cubic Bézier curve: creates a Bézier curve of the third degree. (v0.19)
:* Bézier curve: creates a Bézier curve from several points.
-
Point: creates a simple point.
-
Facebinder: creates a surface object from selected faces.
-
ShapeString: creates a compound shape that represents a text string.
-
Text: creates a multi-line text at a given point.
-
Dimension: creates a linear dimension, a radial dimension or an angular dimension.
-
Label: creates a multi-line text with a 2-segment leader line and an arrow.
-
Annotation styles...: allows you to define styles that affect the visual properties of annotation-like objects. (v0.19)
-
Move: moves or copies selected objects from one point to another.
-
Rotate: rotates or copies selected objects around a center point by a given angle.
-
Scale: scales or copies selected objects around a base point.
-
Mirror: creates mirrored copies from selected objects.
-
Offset: offsets each segment of a selected object over a given distance, or creates an offset copy of the selected object.
-
Trimex: trims or extends a selected object.
-
Stretch: stretches objects by moving selected points.
-
Clone: creates linked copies, clones, of selected objects.
:* Array: creates an orthogonal array from a selected object. It can optionally create a Link array. (v0.19)
:* Polar array: creates an array from a selected object by placing copies along a circumference. It can optionally create a Link array. (v0.19)
:* Circular array: creates an array from a selected object by placing copies along concentric circumferences. It can optionally create a Link array. (v0.19)
:* Path array: creates an array from a selected object by placing copies along a path.
:* Path Link array: idem, but create a Link array instead of a regular array. (v0.19)
:* Point Array: creates an array from a selected object by placing copies at the points from a point compound.
:* Point Link array: idem, but create a Link array instead of a regular array. (v0.19)
-
Edit: puts selected objects in Draft Edit mode. In this mode the properties of objects can be edited graphically.
-
Subelement highlight: temporarily highlights selected objects, or the base objects of selected objects.
-
Join: joins Draft Lines and Draft Wires into a single wire.
-
Split: splits a Draft Line or Draft Wire at a specified point or edge.
-
Upgrade: upgrades selected objects.
-
Downgrade: downgrades selected objects.
-
Wire to B-spline: converts Draft Wires to Draft BSplines and vice versa.
-
Draft to Sketch: converts Draft objects to Sketcher Sketches and vice versa.
-
Set slope: slopes selected Draft Lines or Draft Wires by increasing, or decreasing, the Z coordinate of all points after the first one.
-
Flip dimension: rotates the dimension text of selected Draft Dimensions 180° around the dimension line.
-
Shape 2D view: creates 2D projections from selected objects.
The Draft Tray allows selecting the working plane, defining style settings, toggling construction mode, and specifying the active layer or group.
-
Select Plane: selects the current Draft working plane. Also available in the menu: Draft → Utilities → Select Plane.
-
Set style: sets the default style for new objects. Also available in the menu: Draft → Utilities → Set style. (v0.19)
-
Toggle construction mode: switches Draft construction mode on or off. Also available in the menu: Draft → Utilities → Toggle construction mode.
-
AutoGroup: changes the active Draft Layer or, optionally, the active Std Group or group-like Arch object.
With the Draft annotation scale widget the Draft annotation scale can be specified. (v0.19)
The Draft snap widget can be used as an alternative for the Draft Snap toolbar. (v0.19)
The Draft Snap toolbar allows selecting the active snap options. The buttons belonging to active options stay depressed. For general information about snapping see: Draft Snap.
-
Snap Lock: enables or disables snapping globally.
-
Snap Endpoint: snaps to the endpoints of edges.
-
Snap Midpoint: snaps to the midpoint of straight and circular edges.
-
Snap Center: snaps to the center point of faces and circular edges, and to the Placement point of Draft WorkingPlaneProxies and Arch BuildingParts.
-
Snap Angle: snaps to the special cardinal points on circular edges, at multiples of 30° and 45°.
-
Snap Intersection: snaps to the intersection of two edges.
-
Snap Perpendicular: snaps to the perpendicular point on edges.
-
Snap Extension: snaps to an imaginary line that extends beyond the endpoints of straight edges.
-
Snap Parallel: snaps to an imaginary line parallel to straight edges.
-
Snap Special: snaps to special points defined by the object.
-
Snap Near: snaps to the nearest point on faces or edges.
-
Snap Ortho: snaps to imaginary lines that cross the previous point at 0°, 45°, 90° and 135°.
-
Snap Grid: snaps to the intersections of grid lines.
-
Snap WorkingPlane: projects the snap point onto the current working plane.
-
Snap Dimensions: shows temporary X and Y dimensions.
-
Toggle Grid: switches the grid on or off.
-
Layer: creates a Draft Layer. (v0.19)
-
Create working plane proxy: creates a working plane proxy to save the current Draft working plane.
-
Toggle normal/wireframe display: switches the Display Mode property of selected objects between {{Value|Flat Lines}} and {{Value|Wireframe}}.
-
Move to group...: moves objects to a Std Group. It can also ungroup objects.
-
Select group: selects the content of Draft Layers, Std Groups or group-like Arch objects.
-
Add to Construction group: moves objects to the Draft construction group.
The Draft → Utilities menu contains several tools. Most of them can also be accessed from toolbars or the Draft Tray and have already been mentioned above. For the following tools this is not the case:
-
Heal: heals problematic Draft objects found in very old files.
-
Toggle continue mode: switches continue mode on or off.
-
Apply current style: applies the current style settings to selected objects.
-
Show snap toolbar: shows the Draft Snap toolbar.
- Working plane: the plane in the 3D view where new Draft objects are created.
- Snapping: select exact geometric points on, or defined by, existing objects or the grid.
- Constraining: for each subsequent point you can constrain the movement of the cursor to the X, Y, or Z direction.
- Construction mode: places new Draft objects in a dedicated group making it easier to hide or delete them.
- Pattern: Draft objects with a Make Face property can display a hatch pattern instead of a solid face color.
The following additional options are available in the Tree view context menu:
If there is a selection the context menu contains one additional sub-menu:
- Utilities: a subset of the tools available in the main Draft Utilities menu.
For a Draft Wire, Draft BSpline, Draft CubicBezCurve and Draft BezCurve this additional option is available:
- Flatten this wire: flattens the wire based on its internal geometry. This option currently does not work properly.
For a Draft LayerContainer these additional options are available:
-
Merge layer duplicates: this option currently does not work.
-
Add new layer: adds a new layer to the current document.
For a Draft Layer these additional options are available:
-
Activate this layer: activates the selected layer.
-
Select layer contents: selects the objects inside the selected layer.
For a Draft WorkingPlaneProxy these additional options are available:
-
Write camera position: updates the View Data property of the working plane proxy with the current 3D view camera settings.
-
Write objects state: updates the Visibility Map property of the working plane proxy with the current visibility state of objects in the document.
The following additional options are available in the 3D view context menu:
If there is no selection the context menu contains one additional sub-menu:
- Utilities: a subset of the tools available in the main Draft Utilities menu.
If there is a selection the context menu contains two additional sub-menus:
-
Draft: tools for drawing objects and modifying objects.
-
Utilities: a subset of the tools available in the main Draft Utilities menu.
These commands are obsolete but still available:
-
Array: creates an orthogonal array from a selected object. The created array can be turned into a polar array or a circular array by changing its Array Type property. {{Obsolete|0.19}}
-
Drawing: inserts views of selected objects into a drawing page. {{Obsolete|0.17}}
These 3D view context menu options are still available when the Draft Wire, Draft BSpline, Draft CubicBezCurve or Draft BezCurve command is active but will be removed in the near future:
-
Undo last segment: use the {{button| Undo}} button in the task panel of the command instead. {{Obsolete|0.20}}
-
Finish line: use the Finish button in the task panel of the command instead. {{Obsolete|0.20}}
-
Close line: use the Close button in the task panel of the command instead. {{Obsolete|0.20}}
-
Preferences: general preferences for the Draft Workbench.
-
Import Export Preferences: preferences available for importing from and exporting to different file formats.
The Draft Workbench provides FreeCAD with importers and exporters for several file formats. These are used by the Std Import and Std Export commands.
- Autodesk .DXF: imports and exports Drawing Exchange Format files. See also FreeCAD and DXF Import.
- Autodesk .DWG: imports and exports DWG files via the DXF importer, when the ODA Converter utility is installed. See also FreeCAD and DWG Import.
- Scalable Vector Graphics .SVG: imports and exports Scalable Vector Graphics files.
- Open Cad format .OCA: imports and exports OCA/GCAD files.
- Airfoil Data Format .DAT: imports DAT files describing Airfoil profiles.
See also: Test Workbench.
To run the unit tests of the workbench execute the following from the operating system terminal:
freecad -t TestDraft
See also: Autogenerated API documentation and FreeCAD Scripting Basics.
The workbench includes a module to create samples of all objects in a new document. (v0.19)
Use this to test that all objects are produced correctly:
import drafttests.draft_test_objects as dto
doc = dto.create_test_file()
Inspecting the code of this module can help to understand the programming interface.
*Test objects for the Draft Workbench.*Category:Workbenches
documentation index > Draft Workbench