Draft Workbench
Introduction
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, are several planar objects. On the right, a non-planar Draft Wire used as the Path Object of a Draft PathArray.
Drafting
- Line: creates a straight line.
- Polyline: creates a polyline (also called wire), a sequence of several connected line segments.
- Fillet: creates a fillet, a rounded corner, or a chamfer, a straight edge, between two Draft Lines.
- Arc tools:
- 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.
- 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.
- Bézier tools:
- Cubic Bézier curve: creates a Bézier curve of the third degree.
- 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](https://wiki.freecad.org/Draft_ShapeString): creates a compound shape that represents a text string.
- Hatch: creates hatches on the planar faces of a selected object. introduced in version 0.20
Annotation
- 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.
Modification
- 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 tools:
- Array: creates an orthogonal array from a selected object. It can optionally create a Link array.
- Polar array: creates an array from a selected object by placing copies along a circumference. It can optionally create a Link array.
- Circular array: creates an array from a selected object by placing copies along concentric circumferences. It can optionally create a Link array.
- 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.
- 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.
- 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 Wires 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.
Draft Tray
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.
- 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.
Draft annotation scale widget
With the Draft annotation scale widget the Draft annotation scale can be specified.
Draft snap widget
The Draft snap widget can be used as an alternative for the Draft snap toolbar.
Draft snap toolbar
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 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 points on faces (introduced in version 0.21) and 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 and edges.
- Snap Ortho: snaps to imaginary lines that cross the previous point at multiples of 45°.
- Snap Grid: snaps to the intersections of grid lines.
- Snap WorkingPlane: projects snap points onto the current working plane.
- Snap Dimensions: shows temporary X and Y dimensions.
- Toggle Grid: switches the grid on or off.
Draft utility tools toolbar
- Manage layers: allows to manage the layers in a document. introduced in version 0.21
- Add a new named group: creates a named Std Group and moves selected objects to that group. introduced in version 0.20
- Move to group: moves objects to a Std Group. It can also ungroup objects.
- Select group: selects the contents of Std Groups or group-like Arch objects.
- Add to Construction group: moves objects to the Draft construction group.
- Toggle normal/wireframe display: switches the Display Mode property of selected objects between
Flat Lines
andWireframe
. - Create working plane proxy: creates a working plane proxy to save the current Draft working plane.
Additional tools
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:
- Apply current style: applies the current style settings to selected objects.
- Layer: creates a Draft Layer. Available in the Draft utility tools toolbar in version 0.20 and below.
- Heal: heals problematic Draft objects found in very old files.
- Toggle continue mode: switches continue mode on or off.
- Show snap toolbar: shows the Draft snap toolbar.
Additional features
- 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 an SVG pattern instead of a solid face color.
Tree view context menu
The following additional options are available in the Tree view context menu:
Default options
For most Draft objects the following option is available:
- Edit: edits the object. Depending on the object type either Draft Edit or a dedicated edit solution is used. introduced in version 0.21 If there is an active document the context menu contains an additional sub-menu:
- Utilities: a subset of the tools available in the main Draft Utilities menu.
Wire options
For a Draft Line and a Draft Wire this additional option is available:
- Flatten: flattens the wire on the current Draft working plane. This option does not work properly in version 0.19 and below.
Layer container options
For a Draft LayerContainer these additional options are available:
- Merge layer duplicates: merges all layers with the same base label.
- Add new layer: adds a new layer to the current document.
Layer options
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.
Working plane proxy options
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.
3D view context menu
The following additional options are available in the 3D view context menu:
Default options
If there is an active document the context menu contains one additional sub-menu:
- Utilities: a subset of the tools available in the main Draft Utilities menu.
Obsolete tools
- 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 DataArray Type property. Not available in version 0.21 and above.
- Drawing: inserts views of selected objects into a drawing page. Not available in version 0.21 and above.
Preferences
- Preferences: general preferences for the Draft Workbench.
- Import Export Preferences: preferences available for importing from and exporting to different file formats.
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 an external DWG converter. 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.
Unit tests
See also: Test Workbench.
To run the unit tests of the workbench execute the following from the operating system terminal:
freecad -t TestDraft
Scripting
See also: Autogenerated API documentation and FreeCAD Scripting Basics.
The workbench includes a module to create samples of all objects in a new document.
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.