165 lines
27 KiB
HTML
165 lines
27 KiB
HTML
<html><head><title>Part Module/tr</title><meta http-equiv="Content-Type" content="text/html; charset=utf-8"><link type='text/css' href='wiki.css' rel='stylesheet'></head><body><h1>Part Module/tr</h1></div>
|
|
|
|
<div id="mw-content-text" lang="tr" dir="ltr" class="mw-content-ltr"><hr/>
|
|
<div class="mw-parser-output"></div>
|
|
<p>The CAD capabilities of FreeCAD are based on the <a rel="nofollow" class="external text" href="http://en.wikipedia.org/wiki/Open_CASCADE">OpenCasCade</a> kernel. The Part module allows FreeCAD to access and use the OpenCasCade objects and functions. OpenCascade is a professional-level CAD kernel, that features advanced 3D geometry manipulation and objects. The Part objects, unlike <a href="Mesh_Module.html" class="mw-redirect" title="Mesh Module">Mesh Module</a> objects, are much more complex, and therefore permit much more advanced operations, like coherent boolean operations, modifications history and parametric behaviour.
|
|
</p><p><a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_example.jpg" class="image"><img alt="Part example.jpg" src="Part_example.jpg" width="634" height="406" /></a>
|
|
</p><p>Example of Part shapes in FreeCAD
|
|
</p>
|
|
<div id="toc" class="toc"><div class="toctitle"><h2>Contents</h2></div>
|
|
<ul>
|
|
<li class="toclevel-1 tocsection-1"><a href="#The_tools"><span class="tocnumber">1</span> <span class="toctext">The tools</span></a></li>
|
|
<li class="toclevel-1"><a href="#Primitives"><span class="tocnumber">2</span> <span class="toctext">Primitives</span></a></li>
|
|
<li class="toclevel-1"><a href="#Modifying_objects"><span class="tocnumber">3</span> <span class="toctext">Modifying objects</span></a></li>
|
|
<li class="toclevel-1"><a href="#Other_tools"><span class="tocnumber">4</span> <span class="toctext">Other tools</span></a></li>
|
|
<li class="toclevel-1 tocsection-2"><a href="#Boolean_Operations"><span class="tocnumber">5</span> <span class="toctext">Boolean Operations</span></a></li>
|
|
<li class="toclevel-1 tocsection-3"><a href="#Explaining_the_concepts"><span class="tocnumber">6</span> <span class="toctext">Explaining the concepts</span></a></li>
|
|
<li class="toclevel-1 tocsection-4"><a href="#Scripting"><span class="tocnumber">7</span> <span class="toctext">Scripting</span></a></li>
|
|
<li class="toclevel-1 tocsection-5"><a href="#Examples"><span class="tocnumber">8</span> <span class="toctext">Examples</span></a></li>
|
|
<li class="toclevel-1 tocsection-6"><a href="#Tutorials"><span class="tocnumber">9</span> <span class="toctext">Tutorials</span></a></li>
|
|
</ul>
|
|
</div>
|
|
|
|
<h3><span class="mw-headline" id="The_tools">The tools</span></h3>
|
|
<p>The Part module tools are all located in the <b>Part</b> menu that appears when you load the Part module.
|
|
</p>
|
|
<h3><span class="mw-headline" id="Primitives">Primitives</span></h3>
|
|
<p>These are tools for creating primitive objects.
|
|
</p>
|
|
<ul><li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_Box.png" class="image"><img alt="Part Box.png" src="32px-Part_Box.png" width="32" height="32" srcset="/wiki/images/thumb/a/a5/Part_Box.png/48px-Part_Box.png 1.5x, /wiki/images/a/a5/Part_Box.png 2x" /></a> <a href="Part_Box.html" title="Part Box">Box</a>: Draws a box by specifying its dimensions</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_Cone.png" class="image"><img alt="Part Cone.png" src="32px-Part_Cone.png" width="32" height="32" srcset="/wiki/images/thumb/1/13/Part_Cone.png/48px-Part_Cone.png 1.5x, /wiki/images/1/13/Part_Cone.png 2x" /></a> <a href="Part_Cone.html" title="Part Cone">Cone</a>: Draws a cone by specifying its dimensions</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_Cylinder.png" class="image"><img alt="Part Cylinder.png" src="32px-Part_Cylinder.png" width="32" height="32" srcset="/wiki/images/thumb/d/d4/Part_Cylinder.png/48px-Part_Cylinder.png 1.5x, /wiki/images/d/d4/Part_Cylinder.png 2x" /></a> <a href="Part_Cylinder.html" title="Part Cylinder">Cylinder</a>: Draws a cylinder by specifying its dimensions</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_Sphere.png" class="image"><img alt="Part Sphere.png" src="32px-Part_Sphere.png" width="32" height="32" srcset="/wiki/images/thumb/4/4b/Part_Sphere.png/48px-Part_Sphere.png 1.5x, /wiki/images/4/4b/Part_Sphere.png 2x" /></a> <a href="Part_Sphere.html" title="Part Sphere">Sphere</a>: Draws a sphere by specifying its dimensions</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_Torus.png" class="image"><img alt="Part Torus.png" src="32px-Part_Torus.png" width="32" height="32" srcset="/wiki/images/thumb/8/8b/Part_Torus.png/48px-Part_Torus.png 1.5x, /wiki/images/8/8b/Part_Torus.png 2x" /></a> <a href="Part_Torus.html" title="Part Torus">Torus</a>: Draws a torus (ring) by specifying its dimensions</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_CreatePrimitives.png" class="image"><img alt="Part CreatePrimitives.png" src="32px-Part_CreatePrimitives.png" width="32" height="32" srcset="/wiki/images/thumb/8/8a/Part_CreatePrimitives.png/48px-Part_CreatePrimitives.png 1.5x, /wiki/images/8/8a/Part_CreatePrimitives.png 2x" /></a> <a href="Part_CreatePrimitives.html" title="Part CreatePrimitives">CreatePrimitives</a>: A tool to create various parametric geometric primitives</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_Shapebuilder.png" class="image"><img alt="Part Shapebuilder.png" src="32px-Part_Shapebuilder.png" width="32" height="32" srcset="/wiki/images/thumb/a/a6/Part_Shapebuilder.png/48px-Part_Shapebuilder.png 1.5x, /wiki/images/a/a6/Part_Shapebuilder.png 2x" /></a> <a href="Part_Shapebuilder.html" title="Part Shapebuilder">Shapebuilder</a>: A tool to create more complex shapes from various parametric geometric primitives</li></ul>
|
|
<h3><span class="mw-headline" id="Modifying_objects">Modifying objects</span></h3>
|
|
<p>These are tools for modifying existing objects. They will allow you to choose which object to modify.
|
|
</p>
|
|
<ul><li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_Booleans.png" class="image"><img alt="Part Booleans.png" src="32px-Part_Booleans.png" width="32" height="32" srcset="/wiki/images/thumb/8/89/Part_Booleans.png/48px-Part_Booleans.png 1.5x, /wiki/images/8/89/Part_Booleans.png 2x" /></a> <a href="Part_Booleans.html" title="Part Booleans">Booleans</a>: Performs boolean operations on objects</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_Union.png" class="image"><img alt="Part Union.png" src="32px-Part_Union.png" width="32" height="32" srcset="/wiki/images/thumb/4/45/Part_Union.png/48px-Part_Union.png 1.5x, /wiki/images/4/45/Part_Union.png 2x" /></a> <a href="Part_Union.html" title="Part Union">Union</a>: Fuses (unions) two objects</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_Common.png" class="image"><img alt="Part Common.png" src="32px-Part_Common.png" width="32" height="32" srcset="/wiki/images/thumb/9/9a/Part_Common.png/48px-Part_Common.png 1.5x, /wiki/images/9/9a/Part_Common.png 2x" /></a> <a href="Part_Common.html" title="Part Common">Common</a>: Extracts the common (intersection) part of two objects</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_Cut.png" class="image"><img alt="Part Cut.png" src="32px-Part_Cut.png" width="32" height="32" srcset="/wiki/images/thumb/4/4a/Part_Cut.png/48px-Part_Cut.png 1.5x, /wiki/images/4/4a/Part_Cut.png 2x" /></a> <a href="Part_Cut.html" title="Part Cut">Cut</a>: Cuts (subtracts) one object from another</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_JoinConnect.png" class="image"><img alt="Part JoinConnect.png" src="32px-Part_JoinConnect.png" width="32" height="32" srcset="/wiki/images/thumb/9/95/Part_JoinConnect.png/48px-Part_JoinConnect.png 1.5x, /wiki/images/9/95/Part_JoinConnect.png 2x" /></a> <a href="Part_CompJoinFeatures.html" title="Part CompJoinFeatures">Join features</a>: smart booleans for walled objects (e.g., pipes) (v0.16)
|
|
<ul><li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_JoinConnect.png" class="image"><img alt="Part JoinConnect.png" src="32px-Part_JoinConnect.png" width="32" height="32" srcset="/wiki/images/thumb/9/95/Part_JoinConnect.png/48px-Part_JoinConnect.png 1.5x, /wiki/images/9/95/Part_JoinConnect.png 2x" /></a> <a href="Part_JoinConnect.html" title="Part JoinConnect">Connect</a>: Connects interiors of objects (v0.16)</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_JoinEmbed.png" class="image"><img alt="Part JoinEmbed.png" src="32px-Part_JoinEmbed.png" width="32" height="32" srcset="/wiki/images/thumb/b/bc/Part_JoinEmbed.png/48px-Part_JoinEmbed.png 1.5x, /wiki/images/b/bc/Part_JoinEmbed.png 2x" /></a> <a href="Part_JoinEmbed.html" title="Part JoinEmbed">Embed</a>: Embeds a walled object into another walled object (v0.16)</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_JoinCutout.png" class="image"><img alt="Part JoinCutout.png" src="32px-Part_JoinCutout.png" width="32" height="32" srcset="/wiki/images/thumb/c/c4/Part_JoinCutout.png/48px-Part_JoinCutout.png 1.5x, /wiki/images/c/c4/Part_JoinCutout.png 2x" /></a> <a href="Part_JoinCutout.html" title="Part JoinCutout">Cutout</a>: Creates a cutout in a wall of an object for another walled object (v0.16)</li></ul></li>
|
|
<li> Splitting tools: (v0.17)
|
|
<ul><li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_BooleanFragments.png" class="image"><img alt="Part BooleanFragments.png" src="32px-Part_BooleanFragments.png" width="32" height="32" srcset="/wiki/images/thumb/f/fc/Part_BooleanFragments.png/48px-Part_BooleanFragments.png 1.5x, /wiki/images/f/fc/Part_BooleanFragments.png 2x" /></a> <a href="Part_BooleanFragments.html" title="Part BooleanFragments">Boolean fragments</a>: makes all the pieces that can be obtained by Boolean operations between objects (v0.17)</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_Slice.png" class="image"><img alt="Part Slice.png" src="32px-Part_Slice.png" width="32" height="32" srcset="/wiki/images/thumb/f/f7/Part_Slice.png/48px-Part_Slice.png 1.5x, /wiki/images/f/f7/Part_Slice.png 2x" /></a> <a href="Part_Slice.html" title="Part Slice">Slice</a>: Splits an object into pieces by intersections with another object (v0.17)</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_XOR.png" class="image"><img alt="Part XOR.png" src="32px-Part_XOR.png" width="32" height="32" srcset="/wiki/images/thumb/e/e7/Part_XOR.png/48px-Part_XOR.png 1.5x, /wiki/images/e/e7/Part_XOR.png 2x" /></a> <a href="https://www.freecadweb.org/wiki/index.php?title=Part_XOR&action=edit&redlink=1" class="new" title="Part XOR (page does not exist)">XOR</a>: removes space shared by even number of objects (symmetric version of <a href="Part_Cut.html" title="Part Cut">Cut</a>) (v0.17)</li></ul></li>
|
|
<li> Compound
|
|
<ul><li> <a href="Part_MakeCompound.html" title="Part MakeCompound">Make compound</a>: Creates a compound from the selected objects.</li>
|
|
<li> <a href="Part_CompoundFilter.html" title="Part CompoundFilter">Compound Filter</a>:</li></ul></li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_Extrude.png" class="image"><img alt="Part Extrude.png" src="32px-Part_Extrude.png" width="32" height="32" srcset="/wiki/images/thumb/d/df/Part_Extrude.png/48px-Part_Extrude.png 1.5x, /wiki/images/d/df/Part_Extrude.png 2x" /></a> <a href="Part_Extrude.html" title="Part Extrude">Extrude</a>: Extrudes planar faces of an object</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_Fillet.png" class="image"><img alt="Part Fillet.png" src="32px-Part_Fillet.png" width="32" height="32" srcset="/wiki/images/thumb/4/4a/Part_Fillet.png/48px-Part_Fillet.png 1.5x, /wiki/images/4/4a/Part_Fillet.png 2x" /></a> <a href="Part_Fillet.html" title="Part Fillet">Fillet</a>: Fillets (rounds) edges of an object</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_Revolve.png" class="image"><img alt="Part Revolve.png" src="32px-Part_Revolve.png" width="32" height="32" srcset="/wiki/images/thumb/1/12/Part_Revolve.png/48px-Part_Revolve.png 1.5x, /wiki/images/1/12/Part_Revolve.png 2x" /></a> <a href="Part_Revolve.html" title="Part Revolve">Revolve</a>: Creates a solid by revolving another object (not solid) around an axis</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_Section.png" class="image"><img alt="Part Section.png" src="32px-Part_Section.png" width="32" height="32" srcset="/wiki/images/thumb/a/ab/Part_Section.png/48px-Part_Section.png 1.5x, /wiki/images/a/ab/Part_Section.png 2x" /></a> <a href="Part_Section.html" title="Part Section">Section</a>: Creates a section by intersecting an object with a section plane</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_SectionCross.png" class="image"><img alt="Part SectionCross.png" src="32px-Part_SectionCross.png" width="32" height="32" srcset="/wiki/images/thumb/8/8b/Part_SectionCross.png/48px-Part_SectionCross.png 1.5x, /wiki/images/8/8b/Part_SectionCross.png 2x" /></a> <a href="Part_SectionCross.html" title="Part SectionCross">Cross sections...</a>:</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_Chamfer.png" class="image"><img alt="Part Chamfer.png" src="32px-Part_Chamfer.png" width="32" height="32" srcset="/wiki/images/thumb/8/87/Part_Chamfer.png/48px-Part_Chamfer.png 1.5x, /wiki/images/8/87/Part_Chamfer.png 2x" /></a> <a href="Part_Chamfer.html" title="Part Chamfer">Chamfer</a>: Chamfers edges of an object</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_Mirror.png" class="image"><img alt="Part Mirror.png" src="32px-Part_Mirror.png" width="32" height="32" srcset="/wiki/images/thumb/9/93/Part_Mirror.png/48px-Part_Mirror.png 1.5x, /wiki/images/9/93/Part_Mirror.png 2x" /></a> <a href="Part_Mirror.html" title="Part Mirror">Mirror</a>: Mirrors the selected object on a given mirror plane</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_RuledSurface.png" class="image"><img alt="Part RuledSurface.png" src="32px-Part_RuledSurface.png" width="32" height="32" srcset="/wiki/images/thumb/2/26/Part_RuledSurface.png/48px-Part_RuledSurface.png 1.5x, /wiki/images/2/26/Part_RuledSurface.png 2x" /></a> <a href="Part_RuledSurface.html" title="Part RuledSurface">Ruled Surface</a>:</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_Sweep.png" class="image"><img alt="Part Sweep.png" src="32px-Part_Sweep.png" width="32" height="32" srcset="/wiki/images/thumb/7/79/Part_Sweep.png/48px-Part_Sweep.png 1.5x, /wiki/images/7/79/Part_Sweep.png 2x" /></a> <a href="Part_Sweep.html" title="Part Sweep">Sweep</a>: Sweeps one or more profiles along a path</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_Loft.png" class="image"><img alt="Part Loft.png" src="32px-Part_Loft.png" width="32" height="32" srcset="/wiki/images/thumb/e/ef/Part_Loft.png/48px-Part_Loft.png 1.5x, /wiki/images/e/ef/Part_Loft.png 2x" /></a> <a href="Part_Loft.html" title="Part Loft">Loft</a>: Lofts from one profile to another</li>
|
|
<li> Offset tools:
|
|
<ul><li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_Offset.png" class="image"><img alt="Part Offset.png" src="32px-Part_Offset.png" width="32" height="32" srcset="/wiki/images/thumb/9/9f/Part_Offset.png/48px-Part_Offset.png 1.5x, /wiki/images/9/9f/Part_Offset.png 2x" /></a> <a href="Part_Offset.html" title="Part Offset">3D Offset</a>: Constructs a parallel shape at a certain distance from original.</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_Offset2D.png" class="image"><img alt="Part Offset2D.png" src="32px-Part_Offset2D.png" width="32" height="32" srcset="/wiki/images/thumb/8/8e/Part_Offset2D.png/48px-Part_Offset2D.png 1.5x, /wiki/images/thumb/8/8e/Part_Offset2D.png/64px-Part_Offset2D.png 2x" /></a> <a href="Part_Offset2D.html" title="Part Offset2D">2D Offset</a>: Constructs a parallel wire at certain distance from original, or enlarges/shrinks a planar face. (v0.17)</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_Thickness.png" class="image"><img alt="Part Thickness.png" src="32px-Part_Thickness.png" width="32" height="32" srcset="/wiki/images/thumb/e/e7/Part_Thickness.png/48px-Part_Thickness.png 1.5x, /wiki/images/e/e7/Part_Thickness.png 2x" /></a> <a href="Part_Thickness.html" title="Part Thickness">Thickness</a>: Hollows out a solid, leaving openings next to select faces.</li></ul></li></ul>
|
|
<h3><span class="mw-headline" id="Other_tools">Other tools</span></h3>
|
|
<ul><li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_ImportCAD.png" class="image"><img alt="Part ImportCAD.png" src="32px-Part_ImportCAD.png" width="32" height="32" srcset="/wiki/images/thumb/d/d6/Part_ImportCAD.png/48px-Part_ImportCAD.png 1.5x, /wiki/images/d/d6/Part_ImportCAD.png 2x" /></a> <a href="Part_ImportCAD.html" title="Part ImportCAD">Import CAD</a>: This tool allows you to add a file *.IGES, *.STEP, *.BREP to the current document.</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_ExportCAD.png" class="image"><img alt="Part ExportCAD.png" src="32px-Part_ExportCAD.png" width="32" height="32" srcset="/wiki/images/thumb/b/bd/Part_ExportCAD.png/48px-Part_ExportCAD.png 1.5x, /wiki/images/b/bd/Part_ExportCAD.png 2x" /></a> <a href="Part_ExportCAD.html" title="Part ExportCAD">Export CAD</a>: This tool allows you to export a part object in a *.IGES, *.STEP, *.BREP file.</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_ShapeFromMesh.png" class="image"><img alt="Part ShapeFromMesh.png" src="32px-Part_ShapeFromMesh.png" width="32" height="32" srcset="/wiki/images/thumb/5/50/Part_ShapeFromMesh.png/48px-Part_ShapeFromMesh.png 1.5x, /wiki/images/5/50/Part_ShapeFromMesh.png 2x" /></a> <a href="Part_ShapeFromMesh.html" title="Part ShapeFromMesh">Shape from Mesh</a>: Creates a shape object from a mesh object.</li>
|
|
<li> <a href="Part_ConvertToSolid.html" title="Part ConvertToSolid">Convert to solid</a>: Converts a shape object to a solid object.</li>
|
|
<li> <a href="Part_ReverseShapes.html" title="Part ReverseShapes">Reverse shapes</a>: Flips the normals of all faces of the selected object.</li>
|
|
<li> <a href="Part_CreateSimpleCopy.html" title="Part CreateSimpleCopy">Create simple copy</a>: Creates a simple copy of the selected object.</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_RefineShape.png" class="image"><img alt="Part RefineShape.png" src="32px-Part_RefineShape.png" width="32" height="32" srcset="/wiki/images/thumb/6/68/Part_RefineShape.png/48px-Part_RefineShape.png 1.5x, /wiki/images/6/68/Part_RefineShape.png 2x" /></a> <a href="Part_RefineShape.html" title="Part RefineShape">Refine shape</a>: Cleans faces by removing unnecessary lines.</li>
|
|
<li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_CheckGeometry.png" class="image"><img alt="Part CheckGeometry.png" src="32px-Part_CheckGeometry.png" width="32" height="32" srcset="/wiki/images/thumb/5/5f/Part_CheckGeometry.png/48px-Part_CheckGeometry.png 1.5x, /wiki/images/5/5f/Part_CheckGeometry.png 2x" /></a> <a href="Part_CheckGeometry.html" title="Part CheckGeometry">Check geometry</a>: Checks the geometry of selected objects for errors.</li>
|
|
<li> <a href="Std_Measure_Menu.html" title="Std Measure Menu">Measure</a>: Allows linear and angular measurement between points/edges/faces.</li></ul>
|
|
<p><br />
|
|
</p>
|
|
<ul><li> <a href="https://www.freecadweb.org/wiki/index.php?title=File:Preferences-import-export.svg" class="image"><img alt="Preferences-import-export.svg" src="Preferences-import-export.svg" width="32" height="32" /></a> <a href="Import_Export_Preference.html" title="Import Export Preference">Preference ...</a> Import Export</li></ul>
|
|
<p><br />
|
|
</p>
|
|
<h3><span class="mw-headline" id="Boolean_Operations">Boolean Operations</span></h3>
|
|
<div class="floatleft"><a href="https://www.freecadweb.org/wiki/index.php?title=File:Part_BooleanOperations.png" class="image" title="An example of union (Fuse), intersection (Common) and difference (Cut)"><img alt="An example of union (Fuse), intersection (Common) and difference (Cut)" src="500px-Part_BooleanOperations.png" width="500" height="384" srcset="/wiki/images/thumb/d/df/Part_BooleanOperations.png/750px-Part_BooleanOperations.png 1.5x, /wiki/images/thumb/d/df/Part_BooleanOperations.png/1000px-Part_BooleanOperations.png 2x" /></a></div>
|
|
<div style="clear:both"></div>
|
|
<p><br />
|
|
An example of union (Fuse), intersection (Common) and difference (Cut)
|
|
</p>
|
|
<h3><span class="mw-headline" id="Explaining_the_concepts">Explaining the concepts</span></h3>
|
|
<p>In OpenCasCade terminology, we distinguish between geometric primitives and (topological) shapes. A geometric primitive can be a point, a line, a circle, a plane, etc. or even some more complex types like a B-Spline curve or surface. A shape can be a vertex, an edge, a wire, a face, a solid or a compound of other shapes. The geometric primitives are not made to be directly displayed on the 3D scene, but rather to be used as building geometry for shapes. For example, an edge can be constructed from a line or from a portion of a circle.
|
|
</p><p>We could say, to resume, that geometry primitive are "shapeless" building blocks, and shapes are the real spatial geometry built on it.
|
|
</p><p>To get a complete list of all of them refer to the <a rel="nofollow" class="external text" href="http://www.opencascade.org/org/doc/">OCC documentation</a> (Alternative: <a rel="nofollow" class="external text" href="http://opencascade.sourcearchive.com/documentation/6.3.0.dfsg.1-1/classes.html">sourcearchive.com</a>) and search for <b>Geom_*</b> (for geometry) and <b>TopoDS_*</b> (for shapes). There you can also read more about the differences between geometric objects and shapes. Please note that unfortunately the official OCC documentation is not available online (you must download an archive) and is mostly aimed at programmers, not at end-users. But hopefully you'll find enough information to get started here.
|
|
</p><p>The geometric types actually can be divided into two major groups: curves and surfaces. Out of the curves (line, circle, ...) you can directly build an edge, out of the surfaces (plane, cylinder, ...) a face can be built. For example, the geometric primitive line is unlimited, i.e. it is defined by a base vector and a direction vector while its shape representation must be something limited by a start and end point. And a box -- a solid -- can be created by six limited planes.
|
|
</p><p>From an edge or face you can also go back to its geometric primitive counterpart.
|
|
</p><p>Thus, out of shapes you can build very complex parts or, the other way round, extract all sub-shapes a more complex shape is made of.
|
|
</p>
|
|
<h3><span class="mw-headline" id="Scripting">Scripting</span></h3>
|
|
<p>The main data structure used in the Part module is the <a rel="nofollow" class="external text" href="http://en.wikipedia.org/wiki/Boundary_representation">BRep</a> data type from OpenCascade.
|
|
Almost all contents and object types of the Part module are now available to python scripting. This includes geometric primitives, such as Line and Circle (or Arc), and the whole range of TopoShapes, like Vertexes, Edges, Wires, Faces, Solids and Compounds. For each of those objects, several creation methods exist, and for some of them, especially the TopoShapes, advanced operations like boolean union/difference/intersection are also available. Explore the contents of the Part module, as described in the <a href="FreeCAD_Scripting_Basics.html" title="FreeCAD Scripting Basics">FreeCAD Scripting Basics</a> page, to know more.
|
|
</p>
|
|
<h3><span class="mw-headline" id="Examples">Examples</span></h3>
|
|
<p>To create a line element switch to the Python console and type in:
|
|
</p>
|
|
<pre>import Part,PartGui
|
|
doc=App.newDocument()
|
|
l=Part.LineSegment()
|
|
l.StartPoint=(0.0,0.0,0.0)
|
|
l.EndPoint=(1.0,1.0,1.0)
|
|
doc.addObject("Part::Feature","Line").Shape=l.toShape()
|
|
doc.recompute() </pre>
|
|
<p>Let's go through the above python example step by step:
|
|
</p>
|
|
<pre>import Part,PartGui
|
|
doc=App.newDocument() </pre>
|
|
<p>loads the Part module and creates a new document
|
|
</p>
|
|
<pre>l=Part.LineSegment()
|
|
l.StartPoint=(0.0,0.0,0.0)
|
|
l.EndPoint=(1.0,1.0,1.0) </pre>
|
|
<p>Line is actually a line segment, hence the start and endpoint.
|
|
</p>
|
|
<pre>doc.addObject("Part::Feature","Line").Shape=l.toShape() </pre>
|
|
<p>This adds a Part object type to the document and assigns the shape representation of the line segment to the 'Shape' property of the added object. It is important to understand here that we used a geometric primitive (the Part.LineSegment) to create a TopoShape out of it (the toShape() method). Only Shapes can be added to the document. In FreeCAD, geometry primitives are used as "building structures" for Shapes.
|
|
</p>
|
|
<pre>doc.recompute() </pre>
|
|
<p>Updates the document. This also prepares the visual representation of the new part object.
|
|
</p><p>Note that a Line Segment can be created by specifying its start and endpoint directly in the constructor, for example Part.LineSegment(point1,point2), or we can create a default line and set its properties afterwards, as we did here.
|
|
</p><p>A circle can be created in a similar way:
|
|
</p>
|
|
<pre>import Part
|
|
doc = App.activeDocument()
|
|
c = Part.Circle()
|
|
c.Radius=10.0
|
|
f = doc.addObject("Part::Feature", "Circle")
|
|
f.Shape = c.toShape()
|
|
doc.recompute() </pre>
|
|
<p>Note again, we used the circle (geometry primitive) to construct a shape out of it. We can of course still access our construction geometry afterwards, by doing:
|
|
</p>
|
|
<pre>s = f.Shape
|
|
e = s.Edges[0]
|
|
c = e.Curve </pre>
|
|
<p>Here we take the shape of our object f, then we take its list of edges. In this case there will be only one because we made the whole shape out of a single circle, so we take only the first item of the Edges list, and we takes its curve. Every Edge has a Curve, which is the geometry primitive it is based on.
|
|
</p><p>Head to the <a href="Topological_data_scripting.html" title="Topological data scripting">Topological data scripting</a> page if you would like to know more.
|
|
</p>
|
|
<h3><span class="mw-headline" id="Tutorials">Tutorials</span></h3>
|
|
<ul><li> <a href="Import_from_STL_or_OBJ.html" title="Import from STL or OBJ">Import from STL or OBJ</a> : How to import STL/OBJ files in FreeCAD</li>
|
|
<li> <a href="Export_to_STL_or_OBJ.html" title="Export to STL or OBJ">Export to STL or OBJ</a> : How to export STL/OBJ files from FreeCAD</li>
|
|
<li> <a href="Whiffle_Ball_tutorial.html" title="Whiffle Ball tutorial">Whiffle Ball tutorial</a> : How to use the Part Module</li></ul>
|
|
<div class="mw-translate-fuzzy">
|
|
|
|
</div>
|
|
|
|
|
|
|
|
</div>
|
|
|
|
</div><div class="printfooter">
|
|
Online version: "<a dir="ltr" href="https://www.freecadweb.org/wiki/index.php?title=Part_Module/tr&oldid=290016">http://www.freecadweb.org/wiki/index.php?title=Part_Module/tr&oldid=290016</a>"</div>
|
|
<div id="catlinks" class="catlinks" data-mw="interface"></div><div class="visualClear"></div>
|
|
</div>
|
|
</div>
|
|
<div id="mw-navigation">
|
|
<h2>Navigation menu</h2>
|
|
|
|
</body></html> |