Sketcher::SketchObject is derived from Part Part2DObject, which means it is a Part Feature object specialized for 2D geometry. Like Part2DObject, the SketchObject can be attached to planes and faces. In addition, the SketchObject can handle geometrical constraints of the lines and curves that are drawn within it.
Simplified diagram of the relationships between the core objects in FreeCAD. The
Sketcher::SketchObject class is specialized for 2D shapes, and additionally it includes an extension to handle geometrical constraints of its elements.
- Switch to the Sketcher Workbench.
- Press .
- Select a Sketch orientation: XY-plane, XZ-plane, or YZ-plane. Optionally also choose Reverse direction, and give an Offset value.
- Press .
Although the SketchObject can be used by itself to draw on a plane, it is most commonly used in conjunction with the PartDesign Workbench to create extruded solids.
- Switch to the PartDesign Workbench.
- Press .
- Press .
- Select feature: XY_Plane (Base plane), XZ_Plane (Base plane), or YZ_Plane (Base plane).
- Press .
See Property for all property types that scripted objects can have.
In addition to the properties described in Part Part2DObject, the basic Sketcher SketchObject has the following properties in the property editor. Hidden properties can be shown by using the Show all command in the context menu of the property editor.
- DataMap Mode, DataMap Reversed, DataAttachment Offset: same as Part Part2DObject. See Part Attachment for more information on all attachment mapping modes.
- DataConstraints: named constraints, if they exist; otherwise it is an empty list
Hidden properties Data
See Part Part2DObject for the rest of the hidden properties.
- DataProxy (
PythonObject): a custom class associated with this object. This only exists for the Python version. See Scripting.
- DataGeometry (
GeometryList): a list of Part geometries that exist inside the sketch.
- DataExternal Geometry (
LinkSubList): a list of Part geometries outside this Sketch that are used for reference.
- ViewAutoconstraints (
Bool): if it will try setting constraints when the geometry is drawn.
- ViewEditing Workbench (
String): name of the workbench to activate when editing the sketch; it defaults to
- ViewHide Dependent (
Bool): if all objects that depend on the sketch are hidden when opening the sketch.
- ViewRestore Camera (
Bool): if the camera position is saved before opening the sketch, and is restored after closing it.
- ViewShow Links (
Bool): if all objects used in links to external geometry are shown when opening the sketch.
- ViewShow Support (
Bool): if all objects this sketch is attached to are shown when opening the sketch.
Hidden properties View
- ViewProxy (
PythonObject): a custom view provider class associated with this object. This only exists for the Python version. See Scripting.
- ViewTempo Vis (
PythonObject): a custom class associated with this object, that handles hiding and showing other objects when opening and closing the sketch.
All other view properties, including hidden properties, are those of the base Part Feature object.
See Part Feature for the general information on adding objects to the document.
A SketchObject is created with the
addObject() method of the document.
import FreeCAD as App doc = App.newDocument() obj = App.ActiveDocument.addObject("Sketcher::SketchObject", "Sketch") obj.Label = "Custom label"
Sketcher::SketchObject doesn't have a Proxy object so it can't be fully used for sub-classing.
Therefore, for Python subclassing, you should create the
import FreeCAD as App doc = App.newDocument() obj = App.ActiveDocument.addObject("Sketcher::SketchObjectPython", "CustomSketch") obj.Label = "Custom label"