# Sketcher Workbench

## Introduction

The FreeCAD Sketcher Workbench is used to create 2D geometries 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 degrees-of-freedom of the sketch.

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 '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 is normally used together with Part and PartDesign to create solids; Draft 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.

## The tools

The Sketcher Workbench tools are all located in the Sketch menu that appears when you load the Sketcher Workbench.

### General

- New 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.

- 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.

- 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.

- 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 an 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 a 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 a 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 a B-spline: This is an icon menu in the Sketcher toolbar that holds the following commands:
- Create B-spline: Draws a B-spline curve by its control points.
- Create periodic B-spline: Draws a periodic (closed) B-spline curve by its control points.

- 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.

- Rectangle: Draws a 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.

- Create 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.

- Fillet: Makes a fillet between two lines joined at one point. Select both lines or click on the corner point, then activate the tool.

- Trimming: 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.

- External Geometry: Creates an edge linked to external geometry.

- CarbonCopy: Copies the geometry of another sketch.

- Construction Mode: 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.

- 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 distance of a selected line by constraining its length, or defines the distance between two points by constraining the distance between them.

- Radius: Defines the radius of a selected arc or circle by constraining the radius.
- Diameter: Defines the diameter of a selected arc or circle by constraining the radius.
- Angle: Defines the internal angle between two selected lines.

#### Special constraints

- Snell's Law: Constrains two lines to obey a refraction law to simulate the light going through an interface.

- Internal alignment: Aligns selected elements to selected shape (e.g. a line to become major axis of an ellipse).

#### 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. introduced in version 0.19

### Sketcher tools

- Select solver DOFs: Highlights in green the geometry with degrees of freedom (DOFs), i.e. not fully constrained.

- Close Shape: Creates a closed shape by applying coincident constraints to endpoints

- Connect Edges: Connect sketcher elements by applying coincident constraints to endpoints

- Select Constraints: Selects the constraints of a sketcher element

- Select Elements Associated with constraints: 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 Vertical Axis: Selects the vertical axis of a sketch

- Select Horizontal Axis: Selects the horizontal 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

- Delete All Geometry: Deletes all geometry from the sketch.

- Delete All Constraints: Deletes all constraints from the sketch.

### Sketcher B-spline tools

### Sketcher virtual space

- Switch Virtual Space: Allows you to hide all constraints of a sketch and make them visible again.

### 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. In v0.12, external constraints (constraining the sketch to existing 3D geometry like edges or to other sketches) are not implemented. This means that to locate following sketches geometry to your first sketch, you'll need to set distances relative to your first sketch manually. A lock constraint of (25,75) from the origin is more easily remembered than (23.47,73.02).
- 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.

**The tools:**New sketch, Edit sketch, Leave sketch, View sketch, View section, Map sketch to face, Reorient sketch, Validate sketch, Merge sketches, Mirror sketch

**Sketcher geometries:**Point, Line by 2 point,**Create an arc,**Arc, Arc by 3 Point,**Create a circle**, Circle, Circle by 3 Point,**Create a conic**, Ellipse by center, Ellipse by 3 points, Arc of ellipse, Arc of hyperbola, Arc of parabola,**Create a B-spline**, Create B-spline, Create periodic B-pline, Polyline (multiple-point line), Rectangle,**Create regular polygon**, Triangle, Square, Pentagon, Hexagon, Heptagon, Octagon, Create Regular Polygon, Slot, Fillet, Trimming, Extend, External Geometry, CarbonCopy, Construction Mode

**Sketcher constraints****Geometric constraints**Coincident, Point On Object, Vertical, Horizontal, Parallel, Perpendicular, Tangent, Equal Length, Symmetric, Constrain Block**Dimensional constraints**Lock, Horizontal Distance, Vertical Distance, Distance, Radius, Internal Angle, Snell's Law, Internal Alignment, Toggle reference/driving constraint,

**Sketcher tools**Select solver DOFs, Close Shape, Connect Edges, Select Constraints, Select Origin, Select Vertical Axis, Select Horizontal Axis, Select Redundant Constraints, Select Conflicting Constraints, Select Elements Associated with constraints, Show/Hide internal geometry, Symmetry, Clone, Copy, Move, Rectangular Array, Delete All Geometry, Delete All Constraints

**Sketcher B-spline tools**Show/Hide B-spline degree, Show/Hide B-spline control polygon, Show/Hide B-spline curvature comb, Show/Hide B-spline knot multiplicity, Convert Geometry to B-spline, Increase degree, Increase knot multiplicity, Decrease knot multiplicity

**Sketcher virtual space**Switch Virtual Space

**Installation:**Windows, Unix, Mac;**Getting started****Basics:**About FreeCAD, Workbenches, Preferences, Document structure, Interface Customization, Properties, Mouse Model; Tutorials**Workbenches**: Arch, Draft, FEM, Image, Inspection, Mesh, OpenSCAD, Part, PartDesign, Path, Plot, Points, Raytracing, Reverse Engineering, Robot, Ship, Sketcher, Spreadsheet, Start, Surface workbench, TechDraw, Test Framework, Web

**Scripting:**Introduction to Python, FreeCAD scripting tutorial, FreeCAD Scripting Basics, How to install macros, Gui Command, Units**Modules:**Builtin modules, Workbench creation, Installing more workbenches**Meshes:**Mesh Scripting, Mesh Module**Parts:**The Part Module, Topological data scripting, PythonOCC, Mesh to Part**Coin scenegraph:**The Coin/Inventor scenegraph, Pivy**Qt interface:**PySide, Using the FreeCAD GUI, Dialog creation**Parametric objects:**Scripted objects**Other:**Code snippets, Line drawing function, Embedding FreeCAD, FreeCAD vector math library, Power users hub, Python, Macros, FreeCAD Scripting Basics, Topological data scripting