Mesh Workbench: Difference between revisions

From FreeCAD Documentation
No edit summary
mNo edit summary
 
(33 intermediate revisions by 6 users not shown)
Line 4: Line 4:
<!--T:25-->
<!--T:25-->
{{Docnav
{{Docnav
|[[Inspection Workbench|Inspection Workbench]]
|[[Inspection_Workbench|Inspection Workbench]]
|[[OpenSCAD Module|OpenSCAD Module]]
|[[OpenSCAD_Workbench|OpenSCAD Workbench]]
|IconL=Workbench_Inspection.svg
|IconL=Workbench_Inspection.svg
|IconR=Workbench_OpenSCAD.svg
|IconR=Workbench_OpenSCAD.svg
Line 20: Line 20:


<!--T:1-->
<!--T:1-->
The [[Image:Workbench_Mesh.svg|24px]] [[Mesh Workbench|Mesh Workbench]] handles [http://en.wikipedia.org/wiki/Triangle_mesh triangle meshes]. Meshes are a special type of 3D object, composed of triangular faces connected by their vertices and edges.
The [[Image:Workbench_Mesh.svg|24px]] [[Mesh_Workbench|Mesh Workbench]] handles [http://en.wikipedia.org/wiki/Triangle_mesh triangle meshes]. Meshes are a special type of 3D object, composed of triangular faces connected by their vertices and edges.


<!--T:4-->
<!--T:4-->
Line 26: Line 26:


<!--T:5-->
<!--T:5-->
'''However, in the field of engineering meshes present one big limitation:''' they are only made of surfaces, and have no mass information, so they don't behave as [[Glossary#Solid|solids]]. This means that all solid-based operations, such as addition or subtraction, are difficult to perform on meshes. The Mesh Workbench is useful to import 3D data in mesh format, to analyse it, detect errors, and finally convert it to a solid, for use with the [[Image:Workbench_Part.svg|24px]] [[Part Workbench|Part Workbench]].
However, in the field of engineering meshes present a big limitation: they cannot accurately define curved surfaces. This is why FreeCAD relies on [[wikipedia:Boundary representation|Brep]] instead. The Mesh Workbench offers some commands to directly manipulate meshes, but it is most often used to import 3D mesh data and convert it to a solid for use with the [[Image:Workbench_Part.svg|24px]] [[Part_Workbench|Part Workbench]] or [[Image:Workbench_PartDesign.svg|24px]] [[PartDesign_Workbench|PartDesign Workbench]].


</translate>
</translate>
Line 35: Line 35:


<!--T:8-->
<!--T:8-->
All Mesh Workbench tools can be accessed from the '''Meshes''' menu. Some tools are also available in the '''Mesh tools''' toolbar.
All Mesh Workbench tools can be accessed from the '''Meshes''' menu. Almost all are also available in one of the Mesh toolbars.


<!--T:28-->
<!--T:28-->
* [[Image:Mesh_Import.svg|32px]] [[Mesh_Import|Import mesh...]]: Imports a mesh object from file.
* [[Image:Mesh_Import.svg|32px]] [[Mesh_Import|Import mesh...]]: Imports a mesh object from a file.


<!--T:29-->
<!--T:29-->
* [[Image:Mesh_Export.svg|32px]] [[Mesh_Export|Export mesh...]]: Exports a mesh object to file.
* [[Image:Mesh_Export.svg|32px]] [[Mesh_Export|Export mesh...]]: Exports a mesh object to a file.


<!--T:30-->
<!--T:30-->
Line 47: Line 47:


<!--T:31-->
<!--T:31-->
* [[Mesh_RemeshGmsh|Refinement...]]: Remeshes a mesh object. {{Version|0.19}}
* [[Image:Mesh_RemeshGmsh.svg|32px]] [[Mesh_RemeshGmsh|Refinement...]]: Remeshes a mesh object.


<!--T:12-->
<!--T:12-->
* Analyze
* Analyze
** [[Mesh_Evaluation|Evaluate and repair mesh...]]: Evaluates and repairs a mesh object.
** [[Image:Mesh_Evaluation.svg|32px]] [[Mesh_Evaluation|Evaluate and repair mesh...]]: Evaluates and repairs a mesh object.
** [[Image:Mesh_EvaluateFacet.svg|32px]] [[Mesh_EvaluateFacet|Face info]]: Shows information about faces of mesh objects.
** [[Image:Mesh_EvaluateFacet.svg|32px]] [[Mesh_EvaluateFacet|Face info]]: Shows information about faces of mesh objects.
** [[Mesh_CurvatureInfo|Curvature info]]: Shows the absolute curvature of [[Mesh_VertexCurvature|curvature objects]] at selected points.
** [[Image:Mesh_CurvatureInfo.svg|32px]] [[Mesh_CurvatureInfo|Curvature info]]: Shows the absolute curvature of [[Mesh_VertexCurvature|curvature objects]] at selected points.
** [[Mesh_EvaluateSolid|Check solid mesh]]: Checks if a mesh object is solid.
** [[Image:Mesh_EvaluateSolid.svg|32px]] [[Mesh_EvaluateSolid|Check solid mesh]]: Checks if a mesh object is solid.
** [[Mesh_BoundingBox|Boundings info...]]: Shows the bounding box coordinates of a mesh object.
** [[Image:Mesh_BoundingBox.svg|32px]] [[Mesh_BoundingBox|Boundings info...]]: Shows the bounding box coordinates of a mesh object.


<!--T:32-->
<!--T:32-->
Line 67: Line 67:


<!--T:35-->
<!--T:35-->
* [[Mesh_FillupHoles|Fill holes...]]: Fills holes in mesh objects.
* [[Image:Mesh_FillupHoles.svg|32px]] [[Mesh_FillupHoles|Fill holes...]]: Fills holes in mesh objects.


<!--T:36-->
<!--T:36-->
Line 73: Line 73:


<!--T:37-->
<!--T:37-->
* [[Mesh_AddFacet|Add triangle]]: Adds faces along a boundary of an open mesh object.
* [[Image:Mesh_AddFacet.svg|32px]] [[Mesh_AddFacet|Add triangle]]: Adds faces along a boundary of an open mesh object.


<!--T:38-->
<!--T:38-->
Line 79: Line 79:


<!--T:39-->
<!--T:39-->
* [[Mesh_RemoveCompByHand|Remove components by hand...]]: Removes components from mesh objects.
* [[Image:Mesh_RemoveCompByHand.svg|32px]] [[Mesh_RemoveCompByHand|Remove components by hand...]]: Removes components from mesh objects.


<!--T:40-->
<!--T:40-->
* [[Mesh_Segmentation|Create mesh segments...]]: Creates separate mesh segments for the specified surface types of a mesh object.
* [[Image:Mesh_Segmentation.svg|32px]] [[Mesh_Segmentation|Create mesh segments...]]: Creates separate mesh segments for specified surface types of a mesh object.


<!--T:41-->
<!--T:41-->
* [[Mesh_SegmentationBestFit|Create mesh segments from best-fit surfaces...]]: Creates separate mesh segments for the specified surface types of a mesh object, and can identify their parameters.
* [[Image:Mesh_SegmentationBestFit.svg|32px]] [[Mesh_SegmentationBestFit|Create mesh segments from best-fit surfaces...]]: Creates separate mesh segments for specified surface types of a mesh object, and can identify their parameters.


<!--T:42-->
<!--T:42-->
* [[Mesh_Smoothing|Smooth...]]: Smooths mesh objects.
* [[Image:Mesh_Smoothing.svg|32px]] [[Mesh_Smoothing|Smooth...]]: Smooths mesh objects.


<!--T:43-->
<!--T:43-->
* [[Mesh_Decimating|Decimation...]]: Reduces the number of faces in mesh objects. {{Version|0.19}}
* [[Image:Mesh_Decimating.svg|32px]] [[Mesh_Decimating|Decimation...]]: Reduces the number of faces in mesh objects.


<!--T:44-->
<!--T:44-->
* [[Mesh_Scale|Scale...]]: Scales mesh objects.
* [[Image:Mesh_Scale.svg|32px]] [[Mesh_Scale|Scale...]]: Scales mesh objects.


<!--T:45-->
<!--T:45-->
* [[Image:Mesh_BuildRegularSolid.svg|32px]] [[Mesh_BuildRegularSolid|Regular solid...]] Creates a regular parametric solid mesh object.
* [[Image:Mesh_BuildRegularSolid.svg|32px]] [[Mesh_BuildRegularSolid|Regular solid...]]: Creates a regular parametric solid mesh object.


<!--T:14-->
<!--T:14-->
* Boolean
* Boolean
** [[Mesh_Union|Union]]: Creates a mesh object that is the union of two mesh objects.
** [[Image:Mesh_Union.svg|32px]] [[Mesh_Union|Union]]: Creates a mesh object that is the union of two mesh objects.
** [[Mesh_Intersection|Intersection]]: Creates a mesh object that is the intersection of two mesh objects.
** [[Image:Mesh_Intersection.svg|32px]] [[Mesh_Intersection|Intersection]]: Creates a mesh object that is the intersection of two mesh objects.
** [[Mesh_Difference|Difference]]: Creates a mesh object that is the difference of two mesh objects.
** [[Image:Mesh_Difference.svg|32px]] [[Mesh_Difference|Difference]]: Creates a mesh object that is the difference of two mesh objects.


<!--T:20-->
<!--T:20-->
* Cutting
* Cutting
** [[Image:Mesh_PolyCut.svg|32px]] [[Mesh_PolyCut|Cut mesh]]: Cuts whole faces from mesh objects.
** [[Image:Mesh_PolyCut.svg|32px]] [[Mesh_PolyCut|Cut mesh]]: Cuts whole faces from mesh objects.
** [[Mesh_PolyTrim|Trim mesh]]: Trims faces and parts of faces from mesh objects.
** [[Image:Mesh_PolyTrim.svg|32px]] [[Mesh_PolyTrim|Trim mesh]]: Trims faces and parts of faces from mesh objects.
** [[Mesh_TrimByPlane|Trim mesh with a plane]]: Trims faces and parts of faces on one side of a plane from a mesh object.
** [[Image:Mesh_TrimByPlane.svg|32px]] [[Mesh_TrimByPlane|Trim mesh with a plane]]: Trims faces and parts of faces on one side of a plane from a mesh object.
** [[Mesh_SectionByPlane|Create section from mesh and plane]]: Creates a cross section across a mesh object.
** [[Image:Mesh_SectionByPlane.svg|32px]] [[Mesh_SectionByPlane|Create section from mesh and plane]]: Creates a cross section across a mesh object.
** [[Mesh_CrossSections|Cross-sections...]]: Creates multiple cross sections across mesh objects. {{Version|0.19}}
** [[Image:Mesh_CrossSections.svg|32px]] [[Mesh_CrossSections|Cross-sections...]]: Creates multiple cross sections across mesh objects.


<!--T:46-->
<!--T:46-->
* [[Mesh_Merge|Merge]]: Creates a mesh object by combining the meshes of two or more mesh objects.
* [[Image:Mesh_Merge.svg|32px]] [[Mesh_Merge|Merge]]: Creates a mesh object by combining the meshes of two or more mesh objects.

<!--T:52-->
* [[Image:Mesh_SplitComponents.svg|32px]] [[Mesh_SplitComponents|Split by components]]: Splits a mesh object into its components.


<!--T:47-->
<!--T:47-->
* [[MeshPart_CreateFlatMesh|Unwrap Mesh]]: Creates a flat representation of a mesh object. {{Version|0.19}}
* [[Image:MeshPart_CreateFlatMesh.svg|32px]] [[MeshPart_CreateFlatMesh|Unwrap mesh]]: Creates a flat representation of a mesh object.


<!--T:48-->
<!--T:48-->
* [[MeshPart_CreateFlatFace|Unwrap Face]]: Creates a flat representation of a face of a shape object. {{Version|0.19}}
* [[Image:MeshPart_CreateFlatFace.svg|32px]] [[MeshPart_CreateFlatFace|Unwrap face]]: Creates a flat representation of a face of a shape object.


==Preferences== <!--T:18-->
==Preferences== <!--T:18-->


<!--T:50-->
There are some [[Import_Export_Preferences#Mesh_Formats|export preferences related to Mesh Formats]] but these are not used by commands belonging to this workbench. They are used by the [[Std_Export|Std Export]] command.
There are some [[Import_Export_Preferences#Mesh_Formats|export preferences related to Mesh Formats]] but these are not used by commands belonging to this workbench. They are used by the [[Std_Export|Std Export]] command.


<!--T:51-->
The following preferences apply to the Mesh Workbench:
Mesh Workbench preferences can be found in the following categories of the [[Preferences_Editor|Preferences Editor]]:
* [[Image:Preferences-display.svg|32px]] [[Preferences_Editor#Display_settings|'''Display''' preferences]]: On the [[Preferences_Editor#Mesh_view|'''Mesh view''']] tab several preferences can be set.
* [[Image:Preferences-openscad.svg|32px]] [[OpenSCAD_Preferences|'''OpenSCAD''' preferences]]: The [[Mesh_Union|Mesh Union]], [[Mesh_Intersection|Mesh Intersection]] and [[Mesh_Difference|Mesh Difference]] commands require OpenSCAD and use the '''OpenSCAD executable''' preference.
* [[Image:Preferences-display.svg|32px]] [[Preferences_Editor#Display|Display]]: On the [[Preferences_Editor#Mesh_view|Mesh view]] tab several preferences can be set.
* [[Image:Preferences-openscad.svg|32px]] [[OpenSCAD_Preferences|OpenSCAD]]: The [[Mesh_Union|Mesh Union]], [[Mesh_Intersection|Mesh Intersection]] and [[Mesh_Difference|Mesh Difference]] commands require [http://www.openscad.org/ OpenSCAD] and use the '''OpenSCAD executable''' preference to find its executable.


==Notes== <!--T:16-->
==Notes== <!--T:16-->


<!--T:17-->
<!--T:17-->
* More mesh tools are available in the [[Image:Workbench_OpenSCAD.svg|24px]] [[OpenSCAD Workbench|OpenSCAD Workbench]].
* More mesh tools are available in the [[Image:Workbench_OpenSCAD.svg|24px]] [[OpenSCAD_Workbench|OpenSCAD Workbench]].
* See [[Mesh_Scripting|Mesh Scripting]] to manipulate and create meshes using [[Python|Python]].
* Meshes can also be handled via [[Python]] using [[Mesh Scripting|Mesh Scripting]].
* See also: [[FreeCAD and Mesh Import|FreeCAD and Mesh Import]]
* See also [[FreeCAD_and_Mesh_Import|FreeCAD and Mesh Import]]
* See [[Asymptote|Asymptote]] to export meshes to the Asymptote format.




<!--T:10-->
<!--T:10-->
{{Docnav
{{Docnav
|[[Inspection Workbench|Inspection Workbench]]
|[[Inspection_Workbench|Inspection Workbench]]
|[[OpenSCAD Module|OpenSCAD Module]]
|[[OpenSCAD_Workbench|OpenSCAD Workbench]]
|IconL=Workbench_Inspection.svg
|IconL=Workbench_Inspection.svg
|IconR=Workbench_OpenSCAD.svg
|IconR=Workbench_OpenSCAD.svg
}}
}}



</translate>
</translate>

{{Mesh Tools navi{{#translation:}}}}
{{Mesh Tools navi{{#translation:}}}}

{{Userdocnavi{{#translation:}}}}
{{Userdocnavi{{#translation:}}}}

[[Category:Workbenches{{#translation:}}]]
[[Category:Workbenches{{#translation:}}]]

Latest revision as of 16:24, 25 November 2023

Mesh workbench icon

Introduction

The Mesh Workbench handles triangle meshes. Meshes are a special type of 3D object, composed of triangular faces connected by their vertices and edges.

Many 3D applications, like Sketchup, Blender, Maya and 3D Studio Max, use meshes as their primary type of 3D object. Since meshes are very simple objects, containing only vertices (points), edges and triangular faces, they are very easy to create, modify, subdivide, stretch, and can easily be passed from one application to another without any loss of details. In addition, since meshes contain very simple data, 3D applications can usually manage very large quantities of them without using a lot of resources. For these reasons, meshes are often the 3D object type of choice for applications dealing with movies, animation, and image creation.

However, in the field of engineering meshes present a big limitation: they cannot accurately define curved surfaces. This is why FreeCAD relies on Brep instead. The Mesh Workbench offers some commands to directly manipulate meshes, but it is most often used to import 3D mesh data and convert it to a solid for use with the Part Workbench or PartDesign Workbench.

Tools

All Mesh Workbench tools can be accessed from the Meshes menu. Almost all are also available in one of the Mesh toolbars.

  • Close hole: Fills selected holes in mesh objects.
  • Add triangle: Adds faces along a boundary of an open mesh object.
  • Boolean
    • Union: Creates a mesh object that is the union of two mesh objects.
    • Intersection: Creates a mesh object that is the intersection of two mesh objects.
    • Difference: Creates a mesh object that is the difference of two mesh objects.
  • Merge: Creates a mesh object by combining the meshes of two or more mesh objects.
  • Unwrap mesh: Creates a flat representation of a mesh object.
  • Unwrap face: Creates a flat representation of a face of a shape object.

Preferences

There are some export preferences related to Mesh Formats but these are not used by commands belonging to this workbench. They are used by the Std Export command.

Mesh Workbench preferences can be found in the following categories of the Preferences Editor:

Notes