Sketcher Workbench
Introduction
The FreeCAD Sketcher Workbench is used to create 2D Sketches intended for use in the PartDesign Workbench, Arch Workbench, and other workbenches. Generally, a 2D drawing is considered the starting point for most CAD models, as a 2D sketch can be "extruded" to create a 3D shape; further 2D sketches can be used to create other features like pockets, ridges, or extrusions on top of the previously built 3D shapes. Together with boolean operations defined in the Part Workbench, the Sketcher forms the basis of the constructive solid geometry (CSG) method of building solids. Moreover, together with the PartDesign Workbench operations, the Sketcher also forms the basis of the feature editing methodology of creating solids.
The Sketcher workbench features "constraints", allowing 2D shapes to follow precise geometrical definitions in terms of length, angles, and relationships (horizontality, verticality, perpendicularity, etc.). A constraint solver calculates the constrained extent of 2D geometry and allows interactive exploration of the degrees-of-freedom of the sketch.
Sketcher workbench icon
A fully constrained sketch
Basics of constraint sketching
To explain how the Sketcher works, it may be useful to compare it to the "traditional" way of drafting.
Traditional Drafting
The traditional way of CAD drafting inherits from the old drawing board. Orthogonal (2D) views are drawn manually and intended for producing technical drawings (also known as blueprints). Objects are drawn precisely to the intended size or dimension. If you want to draw an horizontal line 100mm in length starting at (0,0), you activate the line tool, either click on the screen or input the (0,0) coordinates for the first point, then make a second click or input the second point coordinates at (100,0). Or you will draw your line without regard to its position, and move it afterwards. When you've finished drawing your geometries, you add dimensions to them.
Constraint Sketching
The Sketcher moves away from this logic. Objects do not need to be drawn exactly as you intend to, because they will be defined later on by constraints. Objects can be drawn loosely, and as long as they are unconstrained, can be modified. They are in effect "floating" and can be moved, stretched, rotated, scaled, and so on. This gives great flexibility in the design process.
What are constraints?
Instead of dimensions, Constraints are used to limit the degrees of freedom of an object. For example, a line without constraints has 4 Degrees Of Freedom (abbreviated as "DOF"): it can be moved horizontally or vertically, it can be stretched, and it can be rotated.
Applying a horizontal or vertical constraint, or an angle constraint (relative to another line or to one of the axes), will limit its capacity to rotate, thus leaving it with 3 degrees of freedom. Locking one of its points in relation to the origin will remove another 2 degrees of freedom. And applying a dimension constraint will remove the last degree of freedom. The line is then considered fully-constrained.
Multiple objects can be constrained between one another. Two lines can be joined through one of their points with the coincident point constraint. An angle can be set between them, or they can be set perpendicular. A line can be tangent to an arc or a circle, and so on. A complex Sketch with multiple objects will have a number of different solutions, and making it fully-constrained means that just one of these possible solutions has been reached based on the applied constraints.
There are two kinds of constraints: geometric and dimensional. They are detailed in the 'Tools' section below.
What the Sketcher is not good for
The Sketcher is not intended for producing 2D blueprints. Once sketches are used to generate a solid feature, they are automatically hidden. Constraints are only visible in Sketch edit mode.
If you only need to produce 2D views for print, and don't want to create 3D models, check out the Draft workbench. Unlike Sketcher elements, Draft objects don't use constraints; they are simple shapes defined at the moment of creation. Both Draft and Sketcher can be used for 2D geometry drawing, and 3D solid creation, although their preferred use is different:
- The Sketcher Workbench is normally used together with the Part and PartDesign workbenches to create solids.
- The Draft Workbench is normally used for simple planar drawings over a grid, as when drawing an architectural floor plan. In these situations Draft is mostly used together with the Arch Workbench.
The tool Draft2Sketch converts a Draft object to a Sketch object, and vice versa. Many tools that require a 2D element as input work with either type of object as an internal conversion is done automatically.
Sketching Workflow
A Sketch is always 2-dimensional (2D). To create a solid, a 2D Sketch of a single enclosed area is created and then either Padded or Revolved to add the 3rd dimension, creating a 3D solid from the 2D Sketch.
If a Sketch has segments that cross one another, places where a Point is not directly on a segment, or places where there are gaps between endpoints of adjacent segments, Pad or Revolve won't create a solid. Sometimes a Sketch which contains lines which cross one another will work for a simple operation such as Pad, but later operations such as Linear Pattern will fail. It is best to avoid crossing lines. The exception to this rule is that it doesn't apply to Construction (blue) Geometry.
Inside the enclosed area we can have smaller non-overlapping areas. These will become voids when the 3D solid is created.
Once a Sketch is fully constrained, the Sketch features will turn green; Construction Geometry will remain blue. It is usually "finished" at this point and suitable for use in creating a 3D solid. However, once the Sketch dialog is closed it may be worthwhile going to Part Workbench and running Check geometry to ensure there are no features in the Sketch which may cause later problems.
Tools
The Sketcher Workbench tools are located in the Sketch menu and/or several toolbars. introduced in version 0.21: Almost all Sketcher toolbars are only displayed while a sketch is in edit mode. The only exception is the Sketcher toolbar which is only displayed if no sketch is in edit mode.
introduced in version 0.21: If a sketch is in edit mode, the Structure toolbar is hidden as none of its tools can then be used.
General
Sketcher toolbar
- Create sketch: Creates a new sketch on a selected face or plane. If no face is selected while this tool is executed the user is prompted to select a plane from a pop-up window.
- Edit sketch: Edit the selected Sketch. This will open the Sketcher Dialog.
- Map sketch to face: Maps a sketch to the previously selected face of a solid.
- Reorient sketch: Allows you to attach the sketch to one of the main planes.
- Validate sketch: Verify the tolerance of different points and adjust them.
- Merge sketches: Merge two or more sketches.
- Mirror sketch: Mirror a sketch along the x-axis, the y-axis or the origin.
Sketcher Edit Mode toolbar
- Leave sketch: Leave the Sketch editing mode.
- View sketch: Sets the model view perpendicular to the sketch plane.
- View section: Creates a section plane that temporarily hides any matter in front of the sketch plane.
Sketcher edit tools toolbar (introduced in version 0.21)
- Toggle grid: Toggles the grid in the sketch currently being edited. Settings can be changed in the related menu.
- Toggle snap: Toggles snapping in all sketches. Settings can be changed in the related menu.
- Configure rendering order: The rendering order of all sketches can be changed in the related menu.
Other
- Stop operation: When in edit mode, stop the current operation, whether that is drawing, setting constraints, etc.
Sketcher geometries
These are tools for creating objects.
- Point: Draws a point.
- Line: Draws a line segment between 2 points. Lines are infinite regarding certain constraints.
- Create arc: This is an icon menu in the Sketcher toolbar that holds the following commands:
- Arc: Draws an arc segment from center, radius, start angle and end angle.
- Arc by 3 points: Draws an arc segment from two endpoints and another point on the circumference.
- Create circle: This is an icon menu in the Sketcher toolbar that holds the following commands:
- Circle: Draws a circle from center and radius.
- Circle by 3 points: Draws a circle from three points on the circumference.
- Create conic: The sketcher provides the following conical sections. Unlike B-splines they can be used with all sorts of constraints such as Tangent, Point On Object, or Perpendicular.
- Ellipse by center: Draws an ellipse by center point, major radius point and minor radius point.
- Ellipse by 3 points: Draws an ellipse by major diameter (2 points) and minor radius point.
- Arc of ellipse: Draws an arc of ellipse by center point, major radius point, starting point and ending point.
- Arc of hyperbola: Draws an arc of hyperbola.
- Arc of parabola: Draws an arc of parabola.
- Create B-spline: This is an icon menu in the Sketcher toolbar that holds the following commands:
- B-spline by control points: Draws a B-spline curve by its control points.
- Periodic B-spline by control points: Draws a periodic (closed) B-spline curve by its control points.
- B-spline by knots: Draws a B-spline curve by its knots. introduced in version 0.21
- Periodic B-spline by knots: Draws a periodic (closed) B-spline curve by its knots. introduced in version 0.21
- Polyline (multiple-point line): Draws a line made of multiple line segments. Pressing the M key while drawing a Polyline toggles between the different polyline modes.
- Create rectangle: This is an icon menu in the Sketcher toolbar that holds the following commands: introduced in version 0.20
- Rectangle: Draws a rectangle from 2 opposite points.
- Centered rectangle: Draws a rectangle from a central point and an edge point.
- Rounded rectangle: Draws a rounded rectangle from 2 opposite points.
- Create regular polygon: This is an icon menu in the Sketcher toolbar that holds the following commands:
- Triangle: Draws a regular triangle inscribed in a construction geometry circle.
- Square: Draws a regular square inscribed in a construction geometry circle.
- Pentagon: Draws a regular pentagon inscribed in a construction geometry circle.
- Hexagon: Draws a regular hexagon inscribed in a construction geometry circle.
- Heptagon: Draws a regular heptagon inscribed in a construction geometry circle.
- Octagon: Draws a regular octagon inscribed in a construction geometry circle.
- Regular polygon: Draws a regular polygon by selecting the number of sides and picking two points: the center and one corner.
- Slot: Draws an oval by selecting the center of one semicircle and an endpoint of the other semicircle.
- Create fillet: This is an icon menu in the Sketcher toolbar that holds the following commands:
- Fillet: Creates a fillet between two non-parallel lines.
- Corner-preserving fillet: Creates a fillet between two non-parallel lines while preserving their (virtual) intersection.
- Trim: Trims a line, circle or arc with respect to the clicked point.
- Extend: Extends a line or an arc to a boundary line, arc, ellipse, arc of ellipse or a point in space.
- Split: Splits an edge into two while keeping most of the constraints. introduced in version 0.20
- External geometry: Creates an edge linked to external geometry.
- Carbon copy: Copies the geometry of another sketch.
- Toggle construction geometry: Toggles sketch geometry from/to construction mode. Construction geometry is shown in blue and is discarded outside of Sketch editing mode.
Sketcher constraints
Constraints are used to define lengths, set rules between sketch elements, and to lock the sketch along the vertical and horizontal axes. Some constraints require use of Helper constraints.
Geometric constraints
These constraints are not associated with numeric data.
- Coincident: Affixes a point onto (coincident with) one or more other points. It acts as a concentric constraint if two or more circles, arcs, ellipses or arcs of ellipses are selected.
- Point on object: Affixes a point onto another object such as a line, arc, or axis.
- Vertical: Constrains the selected lines or polyline elements to a true vertical orientation. More than one object can be selected before applying this constraint.
- Horizontal: Constrains the selected lines or polyline elements to a true horizontal orientation. More than one object can be selected before applying this constraint.
- Parallel: Constrains two or more lines parallel to one another.
- Perpendicular: Constrains two lines perpendicular to one another, or constrains a line perpendicular to an arc endpoint.
- Tangent: Creates a tangent constraint between two selected entities, or a co-linear constraint between two line segments. A line segment does not have to lie directly on an arc or circle to be constrained tangent to that arc or circle.
- Equal: Constrains two selected entities equal to one another. If used on circles or arcs their radii will be set equal.
- Symmetric: Constrains two points symmetrically about a line, or constrains the first two selected points symmetrically about a third selected point.
- Block: it blocks an edge from moving, that is, it prevents its vertices from changing their current positions. It should be particularly useful to fix the position of B-Splines. See the Block Constraint forum topic.
Dimensional constraints
These are constraints associated with numeric data, for which you can use the expressions. The data may be taken from a spreadsheet.
- Lock: Constrains the selected item by setting vertical and horizontal distances relative to the origin, thereby locking the location of that item. These constraint distances can be edited later.
- Horizontal distance: Fixes the horizontal distance between two points or line endpoints. If only one item is selected, the distance is set to the origin.
- Vertical distance: Fixes the vertical distance between 2 points or line endpoints. If only one item is selected, the distance is set to the origin.
- Distance: Defines the length of a line, the perpendicular distance between a point and a line, the distance between two points, or, introduced in version 0.21, the distance between the edges of two circles.
- Constrain radius or diameter: This is an icon menu in the Sketcher constraints toolbar that holds the following commands:
- Radius or weight: Defines the radius of an arc or circle or the weight of a B-spline pole.
- Diameter: Defines the diameter of an arc or circle.
- Auto radius/diameter: Defines the radius of an arc, the diameter of a circle or the weight of a B-spline pole. introduced in version 0.20
- Angle: Defines the internal angle between two selected lines.
Special constraints
- Refraction (Snell's law): Constrains two lines to obey a refraction law to simulate the light going through an interface.
Constraint tools
The following tools can be used the change the effect of constraints:
- Toggle driving/reference constraint: Toggles the toolbar or the selected constraints to/from reference mode.
- Activate/deactivate constraint: Enable or disable an already placed constraint.
Sketcher tools
- Select unconstrained DoF: Highlights in green the geometry with degrees of freedom (DOFs), i.e. not fully constrained.
- Select associated constraints: Selects the constraints of a sketcher element.
- Select associated geometry: Select sketcher elements associated with constraints.
- Select redundant constraints: Selects redundant constraints of a sketch.
- Select conflicting constraints: Selects conflicting constraints of a sketch.
- Show/hide internal geometry: Recreates missing/deletes unneeded internal geometry of a selected ellipse, arc of ellipse/hyperbola/parabola or B-spline.
- Select origin: Selects the origin of a sketch.
- Select horizontal axis: Selects the horizontal axis of a sketch.
- Select vertical axis: Selects the vertical axis of a sketch.
- Symmetry: Copies a sketcher element symmetrical to a chosen line.
- Clone: Clones a sketcher element.
- Copy: Copies a sketcher element.
- Move: Moves the selected geometry taking as reference the last selected point.
- Rectangular array: Creates an array of selected sketcher elements.
- Remove axes alignment: Remove axes alignment while trying to preserve the constraint relationship of the selection. introduced in version 0.20
- Delete all geometry: Deletes all geometry from the sketch.
- Delete all constraints: Deletes all constraints from the sketch.
Sketcher B-spline tools
- Show/hide B-spline degree: Shows or hides the display of the degree of a B-spline.
- Show/hide B-spline control polygon: Shows or hides the display of the defining polygon of a B-spline.
- Show/hide B-spline curvature comb: Shows or hides the display of the curvature comb of a B-spline.
- Show/hide B-spline knot multiplicity: Shows or hides the display of the knot multiplicity of a B-spline.
- Show/hide B-spline control point weight: Shows or hides the display of the weights for the control points of a B-spline.
- Convert geometry to B-spline: Converts compatible geometry, edges and curves, into a B-spline.
- Increase B-spline degree: Increases the degree (order) of a B-spline.
- Decrease B-spline degree: Decreases the degree (order) of a B-spline.
- Increase knot multiplicity: Increases the multiplicity of a B-spline knot.
- Decrease knot multiplicity: Decreases the multiplicity of a B-spline knot.
- Insert knot: Inserts a knot into an existing B-spline. introduced in version 0.20
- Join curves: Joins two curves at selected end points. introduced in version 0.21
Sketcher virtual space
- Switch virtual space: Allows you to hide all constraints of a sketch and make them visible again.
Obsolete tools
- Close shape: Creates a closed shape by applying coincident constraints to endpoints. Not available in version 0.21 and above.
- Connect edges: Connect sketcher elements by applying coincident constraints to endpoints. Not available in version 0.21 and above.
Preferences
- Preferences: Preferences for the Sketcher workbench.
Best Practices
Every CAD user develops his own way of working over time, but there are some useful general principles to follow.
- A series of simple sketches is easier to manage than a single complex one. For example, a first sketch can be created for the base 3D feature (either a pad or a revolve), while a second one can contain holes or cutouts (pockets). Some details can be left out, to be realized later on as 3D features. You can choose to avoid fillets in your sketch if there are too many, and add them as a 3D feature.
- Always create a closed profile, or your sketch won't produce a solid, but rather a set of open faces. If you don't want some of the objects to be included in the solid creation, turn them to construction elements with the Construction Mode tool.
- Use the auto constraints feature to limit the number of constraints you'll have to add manually.
- As a general rule, apply geometric constraints first, then dimensional constraints, and lock your sketch last. But remember: rules are made to be broken. If you're having trouble manipulating your sketch, it may be useful to constrain a few objects first before completing your profile.
- If possible, center your sketch to the origin (0,0) with the lock constraint. If your sketch is not symmetric, locate one of its points to the origin, or choose nice round numbers for the lock distances.
- If you have the possibility to choose between the Length constraint and the Horizontal or Vertical Distance constraints, prefer the latter. Horizontal and Vertical Distance constraints are computationally cheaper.
- In general, the best constraints to use are: Horizontal and Vertical Constraints; Horizontal and Vertical Length Constraints; Point-to-Point Tangency. If possible, limit the use of these: the general Length Constraint; Edge-to-Edge Tangency; Fix Point Onto a Line Constraint; Symmetry Constraint.
- If in doubt about the validity of a sketch once it is complete (features turn green), close the Sketcher dialog, switch to the Part Workbench and run Check geometry.
Tutorials
- Sketcher tutorial by chrisb. This is a 70-page long PDF document that serves as a detailed manual for the sketcher. It explains the basics of Sketcher usage, and goes into a lot of detail about the creation of geometrical shapes, and each of the constraints.
- Basic Sketcher Tutorial for beginners
- Sketcher Micro Tutorial - Constraint Practices
- Sketcher requirement for a sketch Minimum requirement for a sketch and Complete determination of a sketch
Scripting
The Sketcher scripting page contains examples on how to create constraints from Python scripts.
Examples
For some ideas of what can be achieved with Sketcher tools, have a look at: Sketcher examples.