Mesh Scripting/es: Difference between revisions

From FreeCAD Documentation
(Updating to match new version of source page)
(Updating to match new version of source page)
Line 1: Line 1:
<languages/>
<languages/>
{{Docnav
{{Docnav|FreeCAD Scripting Basics|Topological data scripting}}
|[[FreeCAD_Scripting_Basics|FreeCAD Scripting Basics]]
|[[Topological_data_scripting|Topological data scripting]]
}}

{{TOCright}}


<div class="mw-translate-fuzzy">
<div class="mw-translate-fuzzy">
Line 8: Line 13:
</div>
</div>


{{TOCright}}
First of all you have to import the Mesh module:
First of all you have to import the Mesh module:

{{Code|code=
{{Code|code=
import Mesh
import Mesh
}}
}}

Después de eso, ya tendrás acceso al módulo Malla y la clase Malla, que ofrecen las funciones del nucleo FreeCAD C++ Mesh-Kernel.
Después de eso, ya tendrás acceso al módulo Malla y la clase Malla, que ofrecen las funciones del nucleo FreeCAD C++ Mesh-Kernel.


Line 57: Line 63:
Para crear geometrías regulares puedes utilizar el script de Python BuildRegularGeoms.py.
Para crear geometrías regulares puedes utilizar el script de Python BuildRegularGeoms.py.
</div>
</div>

To create regular geometries you can use the Python script BuildRegularGeoms.py.


{{Code|code=
{{Code|code=
Line 97: Line 105:
}}
}}


<div class="mw-translate-fuzzy">
=== Examen y pruebas ===
=== Examen y pruebas ===
</div>


<div class="mw-translate-fuzzy">
=== Escribe tus propios algoritmos ===
=== Escribe tus propios algoritmos ===
</div>


<div class="mw-translate-fuzzy">
<div class="mw-translate-fuzzy">
Line 113: Line 125:
}}
}}


<div class="mw-translate-fuzzy">
=== Interfaces gráficas de usuario relacionadas ===
=== Interfaces gráficas de usuario relacionadas ===
</div>


<div class="mw-translate-fuzzy">
<div class="mw-translate-fuzzy">
Line 121: Line 135:
Así que si eres lo suficientemente audaz, echa un vistazo al [http://free-cad.svn.sourceforge.net/viewvc/free-cad/trunk/src/Mod/Mesh/App/MeshTestsApp.py?view=markup Módulo de prueba de unidades].
Así que si eres lo suficientemente audaz, echa un vistazo al [http://free-cad.svn.sourceforge.net/viewvc/free-cad/trunk/src/Mod/Mesh/App/MeshTestsApp.py?view=markup Módulo de prueba de unidades].
</div>
</div>

An extensive (though hard to use) source of Mesh related scripting are the unit test scripts of the Mesh-Module.
In this unit tests literally all methods are called and all properties/attributes are tweaked.
So if you are bold enough, take a look at the [https://github.com/FreeCAD/FreeCAD/blob/master/src/Mod/Mesh/App/MeshTestsApp.py Unit Test module].


See also [[Mesh_API|Mesh API]]
See also [[Mesh_API|Mesh API]]
Line 127: Line 145:
{{docnav/es|FreeCAD Scripting Basics/es|Topological data scripting/es}}
{{docnav/es|FreeCAD Scripting Basics/es|Topological data scripting/es}}
</div>
</div>


{{clear}}


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

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

[[Category:Poweruser Documentation{{#translation:}}]]

[[Category:Python Code{{#translation:}}]]
[[Category:Python Code{{#translation:}}]]
{{clear}}

Revision as of 11:49, 23 May 2020

Introducción

En primer lugar tienes que importar el módulo Malla:

First of all you have to import the Mesh module:

import Mesh

Después de eso, ya tendrás acceso al módulo Malla y la clase Malla, que ofrecen las funciones del nucleo FreeCAD C++ Mesh-Kernel.

Creación y Carga

Para crear un objeto malla vacío sólo tienes que utilizar el constructor estándar:

mesh = Mesh.Mesh()

También puedes crear un objeto desde un archivo

mesh = Mesh.Mesh('D:/temp/Something.stl')

(Una lista de formatos de archivo compatibles se puede encontrar bajo 'Mallas' aquí.)

O también puedes crear la malla a partir de un conjunto de triángulos descrito por sus vértices:

planarMesh = [
# triangle 1
[-0.5000,-0.5000,0.0000],[0.5000,0.5000,0.0000],[-0.5000,0.5000,0.0000],
#triangle 2
[-0.5000,-0.5000,0.0000],[0.5000,-0.5000,0.0000],[0.5000,0.5000,0.0000],
]
planarMeshObject = Mesh.Mesh(planarMesh)
Mesh.show(planarMeshObject)

El núcleo de mallas, Mesh-Kernel, se encarga de crear una estructura topológica de datos correcta, ordenando conjuntamente los puntos coincidentes y los bordes.

Más adelante podrás ver cómo examinar y revisar los datos de la malla.

Modelado

Para crear geometrías regulares puedes utilizar el script de Python BuildRegularGeoms.py.

To create regular geometries you can use the Python script BuildRegularGeoms.py.

import BuildRegularGeoms

Esta secuencia de comandos proporciona métodos para definir cuerpos de revolución sencillos, como esferas, elipsoides, cilindros, toroides y conos. Y también tiene un método para crear un cubo simple. Para crear un toroide, por ejemplo, se puede hacer de la siguiente manera:

t = BuildRegularGeoms.Toroid(8.0, 2.0, 50) # list with several thousands triangles
m = Mesh.Mesh(t)

Los dos primeros parámetros definen los radios del toroide y el tercer parámetro es un factor de submuestreo relacionado con el número de triángulos que se han de crear. Cuanto mayor sea este valor, más suave es la forma y mejor acabado tiene el cuerpo.

m1, m2              # are the input mesh objects
m3 = Mesh.Mesh(m1)  # create a copy of m1
m3.unite(m2)        # union of m1 and m2, the result is stored in m3
m4 = Mesh.Mesh(m1)
m4.intersect(m2)    # intersection of m1 and m2
m5 = Mesh.Mesh(m1)
m5.difference(m2)   # the difference of m1 and m2
m6 = Mesh.Mesh(m2)
m6.difference(m1)   # the difference of m2 and m1, usually the result is different to m5

Por último, un ejemplo completo que calcula la intersección entre una esfera y un cilindro que corta a la esfera.

import Mesh, BuildRegularGeoms
sphere = Mesh.Mesh( BuildRegularGeoms.Sphere(5.0, 50) )
cylinder = Mesh.Mesh( BuildRegularGeoms.Cylinder(2.0, 10.0, True, 1.0, 50) )
diff = sphere
diff = diff.difference(cylinder)
d = FreeCAD.newDocument()
d.addObject("Mesh::Feature","Diff_Sphere_Cylinder").Mesh=diff
d.recompute()

Examen y pruebas

Escribe tus propios algoritmos

Exportación

Puedes incluso escribir la malla en un módulo de Python:

m.write("D:/Develop/Projekte/FreeCAD/FreeCAD_0.7/Mod/Mesh/SavedMesh.py")
import SavedMesh
m2 = Mesh.Mesh(SavedMesh.faces)

Interfaces gráficas de usuario relacionadas

Ajustes y pruebas

Una extensa, aunque dificil de usar, librería de archivos de guión relacionados con mallas son los scripts de prueba del módulo Malla. En esta unidad, literalmente todos los métodos son invocados, y se ajustan todas las propiedades y atributos. Así que si eres lo suficientemente audaz, echa un vistazo al Módulo de prueba de unidades.

An extensive (though hard to use) source of Mesh related scripting are the unit test scripts of the Mesh-Module. In this unit tests literally all methods are called and all properties/attributes are tweaked. So if you are bold enough, take a look at the Unit Test module.

See also Mesh API

FreeCAD Scripting Basics/es
Topological data scripting/es