Python scripting tutorial/es: Difference between revisions

From FreeCAD Documentation
No edit summary
(Updating to match new version of source page)
 
(55 intermediate revisions by 4 users not shown)
Line 8: Line 8:
{{TOCright}}
{{TOCright}}


<span id="Introduction"></span>
==Introducción==
==Introducción==


[http://es.wikipedia.org/wiki/Python Python] es un lenguaje de programación, muy simple de utilizar y muy rápido de aprender. Es de código libre, multi plataforma, y puede utilizarse para una gran variedad de cosas, desde la programación de archivos de guión simples a programas muy complejos. Pero uno de sus usos más extendidos es como lenguaje de archivos de guión, ya que es sencillo de embeber en otras aplicaciones. Así es exactamente como se utiliza dentro de FreeCAD. Desde la consola de Python, o desde tus archivos de guión personalizados, puedes pilotar FreeCAD, y hacer que ejecute acciones muy complejas para las cuales aún no exista herramientas en la interfaz gráfica de usuario.
[http://es.wikipedia.org/wiki/Python Python] es un lenguaje de programación relativamente fácil de aprender y comprender. Es de código abierto y multiplataforma, y puede utilizarse para muchos fines: desde simples scripts de shell hasta programas muy complejos. Pero su uso más extendido es como lenguaje de scripting incrustado en otras aplicaciones. Así es como se utiliza dentro de FreeCAD. Desde la [[Python_console/es|Consola de Python]], o desde scripts personalizados, puedes controlar FreeCAD y hacer que realice operaciones muy complejas.


Por ejemplo, desde un archivo de guión de Python, puedes:
Por ejemplo, desde un archivo de guión de Python, puedes:
Line 23: Line 24:
* Desde archivos de guión externos, que pueden utilizarse para programar cosas mucho más complejas. Como [[Workbenches/es|Ambientes de trabajo]] completos.
* Desde archivos de guión externos, que pueden utilizarse para programar cosas mucho más complejas. Como [[Workbenches/es|Ambientes de trabajo]] completos.


En este tutorial, trabajaremos en varios ejemplos básicos para que puedas iniciarte, pero existe mucha más documentación sobre los [[Power users hub/es|documentación sobre el guión en Python]] disponible en esta wiki. Si eres totalmente nuevo en Python y quieres comprender cómo funciona, también tenemos una básica [[introduction to Python/es|Introducción a Python]].
En este tutorial, trabajaremos en varios ejemplos básicos para que puedas iniciarte, pero existe mucha más documentación sobre los [[Power users hub/es|documentación sobre guionización en Python]] disponible en esta wiki. Si eres totalmente nuevo en Python y quieres comprender cómo funciona, también tenemos una básica [[introduction to Python/es|Introducción a Python]].


<div class="mw-translate-fuzzy">
Antes de proceder con la escritura en Python, vaya a {{MenuCommand|Editar → Preferencias → General → Ventana de salida}} y marque dos casillas:
Antes de proceder con la escritura en Python, vaya a {{MenuCommand|Editar → Preferencias → General → Ventana de salida}} y marque dos casillas:
* {{MenuCommand|Redirigir salida Python interna a la vista de informe}}.
* {{MenuCommand|Redirigir salida Python interna a la vista de informe}}.
Line 30: Line 32:
Luego vaya a {{MenuCommand|Vista → Paneles}} y compruebe:
Luego vaya a {{MenuCommand|Vista → Paneles}} y compruebe:
* {{MenuCommand|Vista de informe}}.
* {{MenuCommand|Vista de informe}}.
</div>


<span id="Writing_Python_code"></span>
== Escribiendo código en Python ==
== Escribiendo código en Python ==


Line 39: Line 43:


En este tutorial se pueden utilizar ambos métodos. Puede copiar-pegar cada línea en la consola Python y luego presionar {{KEY|Enter}}, o copiar-pegar todo el código en una nueva ventana de Macro.
En este tutorial se pueden utilizar ambos métodos. Puede copiar-pegar cada línea en la consola Python y luego presionar {{KEY|Enter}}, o copiar-pegar todo el código en una nueva ventana de Macro.
{{Top}}

<span id="Exploring_FreeCAD"></span>
[[#top|inicio]]

== Explorando FreeCAD ==
== Explorando FreeCAD ==


Line 51: Line 54:


<div class="mw-translate-fuzzy">
<div class="mw-translate-fuzzy">
Si escribes esto en la consola de Python de FreeCAD, notaras que en cuanto escribas "FreeCAD.", una ventana aparece, permitiendo rápidamente autocompletar el resto de la línea. Aún mejor, cada entrada en la lista de autocompletar tiene una ayuda explicando lo que hace. Esto hace muy sencillo explorar las funcionalidades disponibles. Antes de seleccionar "newDocument", mira las otras opciones disponibles.
Si escribe esto en la consola de FreeCAD Python, notará que en cuanto teclee {{incode|FreeCAD.}} aparece una ventana que le permite autocompletar rápidamente el resto de su línea. Mejor aún, cada entrada de la lista de autocompletar tiene un tooltip que explica lo que hace. Esto facilita la exploración de la funcionalidad disponible. Antes de elegir {{incode|newDocument}}, eche un vistazo a las otras opciones.
</div>
</div>


[[Image:Screenshot_classbrowser.jpg]]
[[Image:Screenshot_classbrowser.jpg]]
{{Caption|El mecanismo de autocompletar de la consola Python de FreeCAD}}
<div class="mw-translate-fuzzy">
[[Image:Screenshot_classbrowser.jpg|center|frame|El mecanismo de autocompletar de la consola de Python de FreeCAD]]
</div>


<div class="mw-translate-fuzzy">
<div class="mw-translate-fuzzy">
Line 63: Line 64:
</div>
</div>


Ahora volvamos a nuestro documento y veamos qué podemos hacer con él:
<div class="mw-translate-fuzzy">
Volvamos ahora a nuestro documento. Vamos a ver que podemos hacer con él:
</div>


{{Code|code=
{{Code|code=
Line 71: Line 70:
}}
}}


Explore las opciones disponibles. Normalmente los nombres que empiezan con mayúscula son atributos, contienen un valor, mientras que los nombres que empiezan con minúscula son funciones (también llamadas métodos), "hacen algo". Los nombres que comienzan con un guión bajo suelen estar ahí para el funcionamiento interno del módulo, y no deberías preocuparte por ellos. Vamos a utilizar uno de los métodos para añadir un nuevo objeto a nuestro documento:
<div class="mw-translate-fuzzy">
Explora las opciones disponibles. Normalmente los nombres que comienzan con una letra mayúscula son atributos, que contienen un valor, mientras que los nombres que empiezan con una letra minúscula son funciones (también llamados métodos), que hacen "algo". Los nombres que comienzan con un guión bajo están ahí normalmente para el funcionamiento interno del módulo, y no deberías preocuparte de ellos. Vamos a utilizar uno de los métodos para añadir un nuevo objeto a nuestro documento:
</div>


{{Code|code=
{{Code|code=
Line 80: Line 77:


<div class="mw-translate-fuzzy">
<div class="mw-translate-fuzzy">
No pasa nada. Por qué? Es debido a que FreeCAD está pensado para realizar trabajos complejos. Un día, trabajará con cientos de objetos complejos, todos dependiendo unos de otros. Hacer un pequeño cambio en cualquier parte podría tener un gran impacto,necesitaras recalcular el documento completo, que puede llevar bastante tiempo... Por ese motivo, casi ningún comando actualiza la escena automáticamente. Debes hacerlo manualmente:
No pasa nada. ¿Por qué? Porque FreeCAD está hecho para la gran imagen. Un día, trabajará con cientos de objetos complejos, todos dependiendo unos de otros. Hacer un pequeño cambio en algún lugar puede tener un gran impacto, puede necesitar recalcular todo el documento, lo que puede llevar mucho tiempo. Por esa razón casi ningún comando actualiza la escena automáticamente. Debes hacerlo manualmente:
</div>
</div>


Line 88: Line 85:


<div class="mw-translate-fuzzy">
<div class="mw-translate-fuzzy">
Ves? Ahora aparece nuestro cubo! Muchos de los botones que añaden objetos en FreeCAD en realidad hacen dos cosas: Añadir el objeto, y recalcular. Si activas la opción "mostrar los comandos de los archivos de guión en la consola de Python", prueba a añadir una esfera con el botón de la interfaz, verás las dos líneas de código de Python siendo ejecutadas una tras la otra.
Ahora nuestra caja apareció. Muchos de los botones que añaden objetos en FreeCAD en realidad hacen dos cosas: añadir el objeto, y volver a calcular. Si activaste la opción {{MenuCommand|Mostrar comandos de script en la consola de python}} de arriba, intenta añadir una esfera con el botón de la GUI, verás las dos líneas de código Python ejecutándose una tras otra.
</div>
</div>


Line 110: Line 107:


<div class="mw-translate-fuzzy">
<div class="mw-translate-fuzzy">
Si seleccionas tu cubo con el ratón, verás que en el panel de propiedades, en la pestaña de "Datos", nuestra propiedad "Height" aparece. Todas las propiedades de un objeto de FreeCAD que aparecen aquí (y también en la pestaña "Vista", de la que hablaremos más adelante), son directamente accesibles también desde Python, por sus nombres, como hicimos con la propiedad "Height". Prueba cambiando las otras dimensiones del cubo.
Si seleccionas tu caja con el ratón, verás que en el [[Property_editor/es|Editor de propiedades]], en la pestaña {{MenuCommand|Datos}}, aparece nuestra propiedad {{PropertyData|Altura}}. Todas las propiedades de un objeto de FreeCAD que aparecen ahí (y también en la pestaña {{MenuCommand|Vista}}, más adelante), son directamente accesibles por Python también, por sus nombres, como hicimos con la propiedad {{PropertyData|Altura}}. Prueba a cambiar las otras dimensiones de la caja.

Traducción realizada con la versión gratuita del traductor www.DeepL.com/Translator
</div>
</div>
{{Top}}

<span id="Vectors_and_placements"></span>
[[#top|inicio]]

== Vectores y ubicaciones ==
== Vectores y ubicaciones ==


Line 127: Line 125:
}}
}}


Otra característica común de los objetos de FreeCAD es su [[Placement/es|Ubicación]]. Cada objeto tiene una propiedad {{PropertyData|Ubicación}}, que contiene la {{PropertyData|Base}} (posición) y {{PropertyData|Rotación}} (orientación) del objeto. Es fácil de manipular, por ejemplo para mover nuestro objeto:
<div class="mw-translate-fuzzy">
Otra característica de los objetos de FreeCAD es su ubicación. Cada objeto tiene atributos de Ubicación, que contienen la posición (Base) y orientación (Rotación) del objeto. Son sencillos de manejar, por ejemplo para mover nuestro objeto:
</div>


{{Code|code=
{{Code|code=
Line 141: Line 137:


Ahora deberías comprender varios conceptos importantes antes de continuar avanzando.
Ahora deberías comprender varios conceptos importantes antes de continuar avanzando.
{{Top}}

<span id="App_and_Gui"></span>
[[#top|inicio]]

== App y Gui ==
== App y Gui ==


FreeCAD está creado desde el principio para ser una aplicación de línea de comando, sin su interfaz de usuario. Como resultado, prácticamente todo está separado entre una componente "geométrica" y una componente "visual". Cuando trabajas en modo línea de comando, la parte geométrica está presente, pero todas las partes visuales están sencillamente desactivadas. Prácticamente cualquier objeto en FreeCAD por lo tanto está formado por dos partes, un Object y un ViewObject.
FreeCAD ha sido diseñado para que también pueda ser utilizado sin su interfaz de usuario, como una aplicación de línea de comandos. Por lo tanto, casi todos los objetos de FreeCAD constan de dos partes: un {{incode|Object}}, su componente de "geometría", y un {{incode|ViewObject}}, su componente "visual". Cuando trabajas en modo línea de comandos, la parte de geometría está presente, pero la parte visual está desactivada.


Para ilustrar el concepto, veamos nuestro objeto cubo. Las propiedades geométricas del cubo, como sus dimensiones, posición, etc. se almacenan en el {{incode|Objeto}}. Mientras que sus propiedades visuales, como su color, grosor de línea, etc. se almacenan en el {{incode|VistaObjeto}}. Esto se corresponde con las pestañas '''Datos''' y '''Vista'''' del [[Property_editor/es|Editor de propiedades]]. El objeto vista de un objeto se accede así:
<div class="mw-translate-fuzzy">
Para ilustrar el concepto, mira nuestro objeto cubo, las propiedades geométricas del cubo, como sus dimensiones, posición, etc. son almacenadas en el Objeto, mientras que sus propiedades visuales, como su color, espesor de línea, etc. se almacenan en el viewobject. Esto se corresponde con las pestañas "Datos" y "Vista" en la ventana de propiedades. El viewobject de un objeto es accesible así:
</div>


{{Code|code=
{{Code|code=
vo = box.ViewObject
vo = box.ViewObject
}}
}}
Ahora también puedes cambiar las propiedades en la pestaña '''Vista'''':
<div class="mw-translate-fuzzy">
Ahora también puedes cambiar las propiedades de la pestaña "Vista":
</div>


{{Code|code=
{{Code|code=
Line 165: Line 156:
}}
}}


Cuando se inicia FreeCAD, la consola de Python ya carga dos módulos base: {{incode|FreeCAD}} y {{incode|FreeCADGui}} (a los que también se puede acceder por sus accesos directos {{incode|App}} y {{incode|Gui}}). Contienen todo tipo de funcionalidades genéricas para trabajar con documentos y sus objetos. Para ilustrar nuestro concepto, veamos que tanto {{incode|FreeCAD}} como {{incode|FreeCADGui}} contienen un atributo {{incode|ActiveDocument}}, que es el documento actualmente abierto. {{incode|FreeCAD.ActiveDocument}} y {{incode|FreeCADGui.ActiveDocument}} no son el mismo objeto. Son los dos componentes de un documento de FreeCAD, y contienen diferentes atributos y métodos. Por ejemplo, {{incode|FreeCADGui.ActiveDocument}} contiene {{incode|ActiveView}}, que es la [[3D_view/es|Vista 3D]] actualmente abierta.
<div class="mw-translate-fuzzy">
{{Top}}
Cuando inicias FreeCAD, la consola de Python carga 2 módulos base: FreeCAD y FreeCADGui (que también son accesibles por sus diminutivos App y Gui). Ellos contienen toda clase de funcionalidades genéricas para trabajar con documentos y sus objetos. Para ilustrar nuestro concepto, observa que ambos FreeCAD y FreeCADGui contienen un atributo ActiveDocument, el cual es el documento abierto actualmente. FreeCAD.ActiveDocument y FreeCADGui.ActiveDocument no son el mismo objeto. Son los dos componentes de un documento de FreeCAD, y contienen diferentes atributos y métodos. Por ejemplo, FreeCADGui.ActiveDocument contiene ActiveView, que es la vista 3D abierta actualmente.
<span id="Modules"></span>
</div>

[[#top|inicio]]

== Módulos ==
== Módulos ==


Seguramente te debes estar preguntando, Qué más que puedo hacer además del "Part::Box"? La aplicación base de FreeCAD es más o menos un contenedor vacío. Sin sus módulos, puede hacer poco más que crear nuevos documentos vacíos. La verdadera potencia de FreeCAD está en sus fieles módulos. Cada uno de ellos añade no sólo nuevos entornos a su interfaz, sino también nuevos comandos de Python y nuevos tipos de objetos. Como resultado, varios tipos de objetos diferentes o incluso totalmente incompatibles pueden coexistir en el mismo documento. Los módulos más importantes en FreeCAD, que veremos en este tutorial, son [[Part Module/es|Piezas]], [[Mesh Module/es|Mallas]], [[Sketcher Workbench/es|Croquizador]] o [[Draft Module/es|Boceto]].
El verdadero poder de FreeCAD reside en sus fieles módulos, con sus respectivos bancos de trabajo. La aplicación base de FreeCAD es más o menos un contenedor vacío. Sin sus módulos no puede hacer mucho más que crear nuevos documentos vacíos. Cada módulo no sólo añade nuevos ambientes de trabajo a la interfaz, sino también nuevos comandos de Python y nuevos tipos de objetos. Como resultado, varios tipos de objetos diferentes, e incluso totalmente incompatibles, pueden coexistir en el mismo documento. Los módulos más importantes de FreeCAD que veremos en este tutorial son:[[Part_Workbench/es|Piezas]], [[Mesh_Workbench/es|Mallas]], [[Sketcher_Workbench/es|Croquizador]] o [[Draft_Workbench/es|Borrador]].


[[Sketcher_Workbench/es|Croquizador]] y [[Draft_Workbench/es|Borrador]] ambos utilizan el módulo [[Part_Workbench/es|Piezas]] para crear y manejar sus geometrías. Mientras que [[Mesh_Workbench|Malla]] es totalmente independiente, y maneja sus propios objetos. Más sobre esto a continuación.
<div class="mw-translate-fuzzy">
Los módulos [[Sketcher Workbench/es|Croquizador]] y [[Draft Module/es|Boceto]] ambos utilizan el módulo [[Part Module/es|Piezas]] para crear y manejar sus geometrías, las cuales son mientras que el módulo [[Mesh Module/es|Mallas]] es totalmente independiente, y maneja sus propios objetos. Comentaremos algo más en adelante.
</div>


Puedes comprobar todos los tipos de objeto base disponibles para el documento actual así:
Puedes comprobar todos los tipos de objeto base disponibles para el documento actual así:
Line 185: Line 171:
}}
}}


Los diferentes módulos de FreeCAD no se cargan automáticamente en la consola de Python. Esto es para evitar tener un arranque muy lento. Los módulos se cargan sólo cuando los necesitas. Así, por ejemplo, para explorar lo que hay dentro del módulo Pieza:
<div class="mw-translate-fuzzy">
Los diferentes módulos de FreeCAD, aunque añaden sus propios tipos de objeto a FreeCAD, no se cargan automáticamente en la consola de Python. Esto se hace para evitar un inicio demasiado lento. Los módulos son cargados sólo cuando los necesitas. Así, por ejemplo, para explorar que es lo que hay en el módulo de Piezas:
</div>


{{Code|code=
{{Code|code=
Line 195: Line 179:


Pero ya hablaremos más adelante del módulo de Piezas.
Pero ya hablaremos más adelante del módulo de Piezas.
{{Top}}

<span id="Mesh_module"></span>
[[#top|inicio]]

<div class="mw-translate-fuzzy">
<div class="mw-translate-fuzzy">
== Mallas ==
==Malla==
</div>
</div>


Las [https://en.wikipedia.org/wiki/Polygon_mesh Mallas] son un tipo de objeto 3D muy simple, utilizado por ejemplo por [https://en.wikipedia.org/wiki/SketchUp Sketchup], [https://en.wikipedia.org/wiki/Blender_(software) Blender] y [https://en.wikipedia.org/wiki/Autodesk_3ds_Max 3D Studio Max]. Están compuestos por 3 elementos: puntos (también llamados vértices), líneas (también llamadas aristas) y caras. En muchas aplicaciones, incluido FreeCAD, las caras sólo pueden tener 3 vértices. Por supuesto, nada te impide tener una cara más grande formada por varios triángulos coplanares.
<div class="mw-translate-fuzzy">
Las [http://es.wikipedia.org/wiki/Malla_poligonal Mallas] son un tipo de objeto 3D muy simple, utilizados por ejemplo por [http://es.wikipedia.org/wiki/Google_SketchUp Sketchup], [http://es.wikipedia.org/wiki/Blender Blender] o [http://es.wikipedia.org/wiki/Autodesk_3ds_Max 3D studio Max]. Están compuestos por 3 elementos: puntos (también denominados vértices), líneas (también denominadas aristas) y caras. En numerosas aplicaciones, FreeCAD incluida, las caras sólo pueden tener 3 vértices. Pero por supuesto nada impide que tengas una cara plana mayor formada por diversas caras triangulares coplanares.
</div>


Las mallas son simples, pero como son simples puedes tener fácilmente millones de ellas en un solo documento. Sin embargo, en FreeCAD tienen menos uso y están principalmente ahí para que puedas importar objetos en formatos de malla ({{FileName|.stl}}, {{FileName|.obj}}) desde otras aplicaciones. El módulo de malla también se utilizó ampliamente como el principal módulo de prueba en el primer mes de vida de FreeCAD.
<div class="mw-translate-fuzzy">
Las mallas son simple, esto puede ser un mal asunto, pero para muchas aplicaciones como las citadas antes, se vuelve en una ventaja, porque son tan simples que puedes fácilmente tener millones de ellas en un único documento. Aunque en FreeCAD tienen poca utilidad, y se utilizan principalmente para que puedas importar objetos en formato de malla (.stl, .obj) de otras aplicaciones. También fue utilizado extensamente como el módulo de test principal en el primer mes de vida de FreeCAD.
</div>


Los objetos de malla y los objetos de FreeCAD son cosas diferentes. Puedes ver el objeto FreeCAD como un contenedor para un objeto Malla (y como veremos más adelante, para los objetos Pieza también). Así que para añadir un objeto malla a FreeCAD, primero debemos crear un objeto FreeCAD y un objeto Malla, y luego añadir el objeto Malla al objeto FreeCAD:
<div class="mw-translate-fuzzy">
Los objetos de malla y los objetos de FreeCAD son cosas diferentes. Puedes ver el objeto de FreeCAD como un contenedor para un objeto de malla (como, veremos más adelante, también para objetos de pieza). Así que para añadir un objeto de malla a FreeCAD, debemos primero crear un objeto de FreeCAD y un objeto de malla, después añadir el objeto de malla al objeto de FreeCAD:
</div>


{{Code|code=
{{Code|code=
Line 225: Line 202:
}}
}}


Este es un ejemplo estándar que utiliza el método {{incode|createSphere()}} para crear una esfera, pero también puedes crear mallas personalizadas desde cero definiendo sus vértices y caras.

[[Mesh Scripting/es|Leer más sobre guionización de malla...]]
{{Top}}
<span id="Part_module"></span>
<div class="mw-translate-fuzzy">
<div class="mw-translate-fuzzy">
== Piezas ==
Este es un ejemplo estándar, que utiliza el método createSphere() para automáticamente crear una esfera, pero podrías perfectamente crear objetos de malla personalizados desde cero, definiendo sus vértices y caras.
</div>
</div>


El [[Part_Workbench/es|Pieza]] módulo es el módulo más potente de todo FreeCAD. Te permite crear y manipular objetos [http://en.wikipedia.org/wiki/Boundary_representation BREP]. BREP significa "Representación de Límites". Un objeto BREP está definido por superficies que encierran y definen un volumen interior. A diferencia de las mallas, los objetos BREP pueden tener una gran variedad de componentes, desde caras planas hasta superficies NURBS muy complejas.
[[Mesh Scripting/es|Lee más sobre utilizar código con las mallas...]]


El módulo de Piezas está basado en la potente librería [https://en.wikipedia.org/wiki/Open_CASCADE_Technology OpenCasCade], que permite realizar una amplia gama de operaciones complejas sobre estos objetos, como operaciones booleanas, fileteado, lofts, etc.
[[#top|inicio]]

== Piezas ==

El [[Part Module/es|Módulo de Piezas]] es el módulo más potente de todo FreeCAD. Permite crear y manejar objetos [http://en.wikipedia.org/wiki/Boundary_representation BRep]. Este tipo de objetos, a diferencia de las mallas, pueden tener una amplia variedad de componentes. Para resumir un poco, Brep significa Boundary Representation, que quiere decir que están definidos por sus superficies, que comprenden y definen un volumen interior. Dichas superficies pueden ser varias cosas, como caras planas o superficies NURBS complejas. También incorporan el concepto de volumen.

<div class="mw-translate-fuzzy">
El módulo de Piezas está basado en la potente tecnología de la librería [http://en.wikipedia.org/wiki/Open_CASCADE_Technology OpenCasCade], que permite que un amplio rango de operaciones complejas sean aplicadas de forma sencilla en dichos objetos, como las operaciones booleanas, redondeos, barridos...
</div>


El módulo de Piezas funciona del mismo modo que el módulo de mallas: Se crea un objeto de FreeCAD, un objeto de Pieza, luego añadir el objeto de pieza al objeto de FreeCAD:
El módulo de Piezas funciona del mismo modo que el módulo de mallas: Se crea un objeto de FreeCAD, un objeto de Pieza, luego añadir el objeto de pieza al objeto de FreeCAD:
Line 254: Line 228:
}}
}}


El módulo Pieza (como el módulo de Mallas) también tiene un atajo que automáticamente crea un objeto de FreeCAD y le añade una forma, por lo que puede acortar las tres últimas líneas a:
<div class="mw-translate-fuzzy">
El módulo de Piezas (como el módulo de mallas) también tiene un atajo que automáticamente crea un objeto de FreeCAD y le añade una forma, así puedes evitar las tres líneas anteriores:
</div>


{{Code|code=
{{Code|code=
Line 262: Line 234:
}}
}}


Al explorar el contenido de myshape, notarás muchos subcomponentes interesantes como {{incode|Faces}}, {{incode|Edges}}, {{incode|Vertexes}}, {{incode|Solids}} y {{incode|Shells}}, y una amplia gama de operaciones de geometría como {{incode|cut}} (sustracción), {{incode|common}} (intersección) o {{incode|fuse}} (unión). En la página [[Topological_data_scripting/es|Guionización de topología de datos]] se explica todo esto en detalle.

[[Topological_data_scripting/es|
Leer más sobre guionización pieza...]]
{{Top}}
<span id="Draft_module"></span>
<div class="mw-translate-fuzzy">
<div class="mw-translate-fuzzy">
== Borrador ==
Explorando el contenido de myshape, observarás que están disponibles varios subcomponentes interesantes como caras, aristas, vértices, sólidos o superficies, y un amplio rango de operaciones geométricas como cortes (sustracciones), común (intersecciones) o fusiones (unión). La página de [[Topological data scripting/es|Archivos de guión de topología de datos]] lo explica todo detalladamente.
</div>
</div>


FreeCAD proporciona varios módulos, como el [[Sketcher_Workbench/es|Croquizador]] o [[Draft_Workbench/es|Borrador]], que también crean objetos de piezas, pero le añade parámetros, o incluso un nuevo modo de manejar la geometría de las piezas. Nuestro cubo de ejemplo de arriba, es un perfecto ejemplo de objeto paramétrico. Todo lo que necesitas, para definir el cubo, es especificar un conjunto de parámetros, como las altura, ancho y longitud. Basados en los cuales, el objeto calculará automáticamente su forma de Pieza. FreeCAD te permite [[Scripted_objects/es|crear dichos objetos en Python]].
[[Topological_data_scripting/es|
Lea más sobre el guión de las piezas...]]


El [[Draft_Workbench/es|Borrador]] Módulo añade tipos de objetos paramétricos 2D (que son todos objetos Pieza) como líneas y círculos, y también proporciona algunas funciones genéricas que no sólo funcionan con objetos Borrador, sino con cualquier objeto Pieza. Para explorar lo que está disponible, simplemente haga:
[[#top|inicio]]

== Boceto ==

FreeCAD proporciona varios módulos, como el [[Sketcher Workbench/es|Croquizador]] o [[Draft Module/es|Boceto]], que también crean objetos de piezas, pero le añade parámetros, o incluso un nuevo modo de manejar la geometría de las piezas. Nuestro cubo de ejemplo de arriba, es un perfecto ejemplo de objeto paramétrico. Todo lo que necesitas, para definir el cubo, es especificar un conjunto de parámetros, como las altura, ancho y longitud. Basados en los cuales, el objeto calculará automáticamente su forma de Pieza. FreeCAD te permite [[Scripted objects/es|crear dichos objetos en Python]].

<div class="mw-translate-fuzzy">
El [[Draft Module/es|Módulo de Boceto]] añade diversos tipos de objetos 2D paramétricos (que son todos objetos de Piezas) como líneas y circunferencias, y también proporciona algunas funciones genéricas que funcionan no sólo en objetos creados en el módulo de Boceto, sino en cualquier objeto de Pieza. Para explorar lo que está disponible, simplemente haz lo siguiente:
</div>


{{Code|code=
{{Code|code=
Line 286: Line 255:
Draft.move(box, mvec)
Draft.move(box, mvec)
}}
}}
{{Top}}

<span id="Interface"></span>
[[#top|inicio]]

== Interfaz ==
== Interfaz ==


Line 298: Line 266:
}}
}}


Observa que el diálogo que aparece tiene el icono de FreeCAD en su barra de herramientas, lo que significa que Qt sabe que la orden ha sido emitida desde dentro de la aplicación FreeCAD. Es posible manipular cualquier parte de la interfaz de FreeCAD.
<div class="mw-translate-fuzzy">
Observa que el letrero de diálogo que aparece tiene el icono de FreeCAD en su barra de herramientas, lo que significa que Qt sabe que el comando ha sido ejecutado desde la aplicación FreeCAD. Podemos por lo tanto manipular directa y sencillamente cualquier parte de la interfaz de FreeCAD.
</div>


Qt es un sistema de interfaz muy potente que permite hacer cosas muy complejas. También tiene algunas herramientas fáciles de usar como el Qt Designer con el que puedes diseñar diálogos gráficamente y luego añadirlos a la interfaz de FreeCAD con unas pocas líneas de código Python.
<div class="mw-translate-fuzzy">
Qt es un sistema de interfaces muy potente, que te permite hacer cosas muy complejas, pero también dispone de varias herramientas de uso muy sencillo como el Qt Designer con el cual puedes diseñar letreros de diálogo graficamente y después añadirlos a la interfaz de FreeCAD con un par de líneas en Python.
</div>

<div class="mw-translate-fuzzy">
[[PySide/es|Lee más sobre PyQt aquí...]]
</div>

[[#top|inicio]]


[[PySide/es|Lee más sobre PySide aquí...]]
{{Top}}
<span id="Macros"></span>
== Macros ==
== Macros ==


Ahora que tienes una buena comprensión de los conceptos básicos, a dónde vamos para mantener nuestros archivos de guión en Python, y cómo vamos a ejecutarlos fácilmente desde FreeCAD? Existe un sencillo mecanismo para ello, denominado [[Macros/es|Macros]]. Una macro es simplemente un archivo de guión en Python, que puede ser añadida a una barra de herramientas y lanzada desde un simple clic de ratón. FreeCAD proporciona un simple editor de textos (Macro -> Macros -> Crear) donde puedes escribir o pegar archivos de guión. Una vez esté terminado, Herramientas -> Personalizar -> Macros te permite definir un botón para ella, que se puede añadir a las barras de herramientas.
Ahora que tienes una buena comprensión de los conceptos básicos, a dónde vamos para mantener nuestros archivos de guión en Python, y cómo vamos a ejecutarlos fácilmente desde FreeCAD? Existe un sencillo mecanismo para ello, denominado [[Macros/es|Macros]]. Una macro es simplemente un archivo de guión en Python, que puede ser añadida a una barra de herramientas y lanzada desde un simple clic de ratón. FreeCAD proporciona un simple editor de textos (Macro -> Macros -> Crear) donde puedes escribir o pegar archivos de guión. Una vez esté terminado, Herramientas -> Personalizar -> Macros te permite definir un botón para ella, que se puede añadir a las barras de herramientas.

==External scripts==

An alternative method for creating, saving, and running your own Python scripts is to create them outside FreeCAD, using an editor of your choice (for example, Vim). To run your Python script inside FreeCAD, be sure to save it with the {{FileName|.py}} extension.

Then use {{MenuCommand|File → Open}} to open your script. It will load into a new tab in the [[Main_view_area|Main view area]]. You can run your script by clicking the {{Button|[[Image:Std_DlgMacroExecuteDirect.svg|16px]] [[Std_DlgMacroExecuteDirect|Execute macro]]}} button. Any errors or script output will be shown in the [[Report_view|Report view]].

When you make and save any modifications to your already-loaded script, a dialog box will appear asking whether you want to reload the modified script into FreeCAD.


<div class="mw-translate-fuzzy">
<div class="mw-translate-fuzzy">
Ahora estas listo para ver más en profundidad los archivos de guión en FreeCAD. Dirígete al [[Power users hub/es|Centro de usuarios avanzados]]!
Ahora estás listo para profundizar en guionización FreeCAD. Así que dirígete al [[Power_users_hub/es|Centro usuarios avanzados]]!
</div>
</div>
{{Top}}

[[#top|inicio]]


{{Docnav/es
{{Docnav/es
Line 330: Line 298:
[[Category:Developer Documentation{{#translation:}}]]
[[Category:Developer Documentation{{#translation:}}]]
[[Category:Python Code{{#translation:}}]]
[[Category:Python Code{{#translation:}}]]
{{clear}}

Latest revision as of 20:02, 9 August 2023

Introducción

Python es un lenguaje de programación relativamente fácil de aprender y comprender. Es de código abierto y multiplataforma, y puede utilizarse para muchos fines: desde simples scripts de shell hasta programas muy complejos. Pero su uso más extendido es como lenguaje de scripting incrustado en otras aplicaciones. Así es como se utiliza dentro de FreeCAD. Desde la Consola de Python, o desde scripts personalizados, puedes controlar FreeCAD y hacer que realice operaciones muy complejas.

Por ejemplo, desde un archivo de guión de Python, puedes:

  • Crear nuevos objetos.
  • Modificar los objetos existentes.
  • Modificar la representación 3D de dichos objetos
  • Modificar la interfaz de FreeCAD

También existen diversas formas de utilizar Python en FreeCAD:

  • Desde el Interprete de Python de FreeCAD, donde puedes dictar comandos como en una interfaz del tipo de línea de comandos
  • Desde Macros, que son una forma conveniente de añadir una herramienta que no exista a la interfaz de FreeCAD
  • Desde archivos de guión externos, que pueden utilizarse para programar cosas mucho más complejas. Como Ambientes de trabajo completos.

En este tutorial, trabajaremos en varios ejemplos básicos para que puedas iniciarte, pero existe mucha más documentación sobre los documentación sobre guionización en Python disponible en esta wiki. Si eres totalmente nuevo en Python y quieres comprender cómo funciona, también tenemos una básica Introducción a Python.

Antes de proceder con la escritura en Python, vaya a Editar → Preferencias → General → Ventana de salida y marque dos casillas:

  • Redirigir salida Python interna a la vista de informe.
  • Redirigir errores Python internos a la vista de informe.

Luego vaya a Vista → Paneles y compruebe:

  • Vista de informe.

Escribiendo código en Python

Existen dos modos sencillos de escribir código de Python en FreeCAD: Desde la consola de Python (disponible en el menú Vista -> Vistas -> Consola de Python) o desde el editor de macros (Herramientas -> Macros). En la consola, escribes comandos de Python uno a uno, que son ejecutados al presionar Enter, mientras que las macros pueden contener archivos de guión más completos formados por varias líneas, que se ejecutan sólo cuando la macro es ejecutada.

La consola FreeCAD Python

En este tutorial se pueden utilizar ambos métodos. Puede copiar-pegar cada línea en la consola Python y luego presionar Enter, o copiar-pegar todo el código en una nueva ventana de Macro.

Inicio

Explorando FreeCAD

Vamos a empezar creando un nuevo documento vacío:

doc = FreeCAD.newDocument()

Si escribe esto en la consola de FreeCAD Python, notará que en cuanto teclee FreeCAD. aparece una ventana que le permite autocompletar rápidamente el resto de su línea. Mejor aún, cada entrada de la lista de autocompletar tiene un tooltip que explica lo que hace. Esto facilita la exploración de la funcionalidad disponible. Antes de elegir newDocument, eche un vistazo a las otras opciones.

El mecanismo de autocompletar de la consola Python de FreeCAD

Ahora nuestro nuevo documento se creará. Esto es similar a presionar el botón "Nuevo documento" en la barra de herramientas. En realidad, la mayoría de botones en FreeCAD no hacen nada más que ejecutar una línea o dos de código en Python. Aún mejor, puedes establecer una opción en Editar -> Preferencias -> General -> Macro para "mostrar los comandos de los archivos de guión en la consola de Python". Esto mostrará en la consola todo el código de Python ejecutado cuando presionas los botones. Muy útil para aprender como reproducir acciones en Python.

Ahora volvamos a nuestro documento y veamos qué podemos hacer con él:

doc.

Explore las opciones disponibles. Normalmente los nombres que empiezan con mayúscula son atributos, contienen un valor, mientras que los nombres que empiezan con minúscula son funciones (también llamadas métodos), "hacen algo". Los nombres que comienzan con un guión bajo suelen estar ahí para el funcionamiento interno del módulo, y no deberías preocuparte por ellos. Vamos a utilizar uno de los métodos para añadir un nuevo objeto a nuestro documento:

box = doc.addObject("Part::Box", "myBox")

No pasa nada. ¿Por qué? Porque FreeCAD está hecho para la gran imagen. Un día, trabajará con cientos de objetos complejos, todos dependiendo unos de otros. Hacer un pequeño cambio en algún lugar puede tener un gran impacto, puede necesitar recalcular todo el documento, lo que puede llevar mucho tiempo. Por esa razón casi ningún comando actualiza la escena automáticamente. Debes hacerlo manualmente:

doc.recompute()

Ahora nuestra caja apareció. Muchos de los botones que añaden objetos en FreeCAD en realidad hacen dos cosas: añadir el objeto, y volver a calcular. Si activaste la opción Mostrar comandos de script en la consola de python de arriba, intenta añadir una esfera con el botón de la GUI, verás las dos líneas de código Python ejecutándose una tras otra.

Ahora vamos a explorar el contenido de nuestro cubo:

box.

Verás automáticamente varias cosas interesantes como:

box.Height

Esto mostrará la altura actual de nuestro cubo. Ahora vamos a intentar cambiarla:

box.Height = 5

Si seleccionas tu caja con el ratón, verás que en el Editor de propiedades, en la pestaña Datos, aparece nuestra propiedad DatosAltura. Todas las propiedades de un objeto de FreeCAD que aparecen ahí (y también en la pestaña Vista, más adelante), son directamente accesibles por Python también, por sus nombres, como hicimos con la propiedad DatosAltura. Prueba a cambiar las otras dimensiones de la caja.

Traducción realizada con la versión gratuita del traductor www.DeepL.com/Translator

Inicio

Vectores y ubicaciones

Los vectores son un concepto muy fundamental en cualquier aplicación 3D. Son una lista de 3 números (X, Y y Z), describiendo un punto o posición en el espacio 3D. Un montón de cosas se pueden hacer con los vectores, como sumas, restas, proyecciones y mucho más. En FreeCAD los vectores funcionan así:

myvec = FreeCAD.Vector(2, 0, 0)
myvec.x
myvec.y
othervec = FreeCAD.Vector(0, 3, 0)
sumvec = myvec.add(othervec)

Otra característica común de los objetos de FreeCAD es su Ubicación. Cada objeto tiene una propiedad DatosUbicación, que contiene la DatosBase (posición) y DatosRotación (orientación) del objeto. Es fácil de manipular, por ejemplo para mover nuestro objeto:

box.Placement
box.Placement.Base
box.Placement.Base = sumvec
 
otherpla = FreeCAD.Placement()
box.Placement = otherpla

Ahora deberías comprender varios conceptos importantes antes de continuar avanzando.

Inicio

App y Gui

FreeCAD ha sido diseñado para que también pueda ser utilizado sin su interfaz de usuario, como una aplicación de línea de comandos. Por lo tanto, casi todos los objetos de FreeCAD constan de dos partes: un Object, su componente de "geometría", y un ViewObject, su componente "visual". Cuando trabajas en modo línea de comandos, la parte de geometría está presente, pero la parte visual está desactivada.

Para ilustrar el concepto, veamos nuestro objeto cubo. Las propiedades geométricas del cubo, como sus dimensiones, posición, etc. se almacenan en el Objeto. Mientras que sus propiedades visuales, como su color, grosor de línea, etc. se almacenan en el VistaObjeto. Esto se corresponde con las pestañas Datos y Vista' del Editor de propiedades. El objeto vista de un objeto se accede así:

vo = box.ViewObject

Ahora también puedes cambiar las propiedades en la pestaña Vista':

vo.Transparency = 80
vo.hide()
vo.show()

Cuando se inicia FreeCAD, la consola de Python ya carga dos módulos base: FreeCAD y FreeCADGui (a los que también se puede acceder por sus accesos directos App y Gui). Contienen todo tipo de funcionalidades genéricas para trabajar con documentos y sus objetos. Para ilustrar nuestro concepto, veamos que tanto FreeCAD como FreeCADGui contienen un atributo ActiveDocument, que es el documento actualmente abierto. FreeCAD.ActiveDocument y FreeCADGui.ActiveDocument no son el mismo objeto. Son los dos componentes de un documento de FreeCAD, y contienen diferentes atributos y métodos. Por ejemplo, FreeCADGui.ActiveDocument contiene ActiveView, que es la Vista 3D actualmente abierta.

Inicio

Módulos

El verdadero poder de FreeCAD reside en sus fieles módulos, con sus respectivos bancos de trabajo. La aplicación base de FreeCAD es más o menos un contenedor vacío. Sin sus módulos no puede hacer mucho más que crear nuevos documentos vacíos. Cada módulo no sólo añade nuevos ambientes de trabajo a la interfaz, sino también nuevos comandos de Python y nuevos tipos de objetos. Como resultado, varios tipos de objetos diferentes, e incluso totalmente incompatibles, pueden coexistir en el mismo documento. Los módulos más importantes de FreeCAD que veremos en este tutorial son:Piezas, Mallas, Croquizador o Borrador.

Croquizador y Borrador ambos utilizan el módulo Piezas para crear y manejar sus geometrías. Mientras que Malla es totalmente independiente, y maneja sus propios objetos. Más sobre esto a continuación.

Puedes comprobar todos los tipos de objeto base disponibles para el documento actual así:

doc.supportedTypes()

Los diferentes módulos de FreeCAD no se cargan automáticamente en la consola de Python. Esto es para evitar tener un arranque muy lento. Los módulos se cargan sólo cuando los necesitas. Así, por ejemplo, para explorar lo que hay dentro del módulo Pieza:

import Part
Part.

Pero ya hablaremos más adelante del módulo de Piezas.

Inicio

Malla

Las Mallas son un tipo de objeto 3D muy simple, utilizado por ejemplo por Sketchup, Blender y 3D Studio Max. Están compuestos por 3 elementos: puntos (también llamados vértices), líneas (también llamadas aristas) y caras. En muchas aplicaciones, incluido FreeCAD, las caras sólo pueden tener 3 vértices. Por supuesto, nada te impide tener una cara más grande formada por varios triángulos coplanares.

Las mallas son simples, pero como son simples puedes tener fácilmente millones de ellas en un solo documento. Sin embargo, en FreeCAD tienen menos uso y están principalmente ahí para que puedas importar objetos en formatos de malla (.stl, .obj) desde otras aplicaciones. El módulo de malla también se utilizó ampliamente como el principal módulo de prueba en el primer mes de vida de FreeCAD.

Los objetos de malla y los objetos de FreeCAD son cosas diferentes. Puedes ver el objeto FreeCAD como un contenedor para un objeto Malla (y como veremos más adelante, para los objetos Pieza también). Así que para añadir un objeto malla a FreeCAD, primero debemos crear un objeto FreeCAD y un objeto Malla, y luego añadir el objeto Malla al objeto FreeCAD:

import Mesh
mymesh = Mesh.createSphere()
mymesh.Facets
mymesh.Points
 
meshobj = doc.addObject("Mesh::Feature", "MyMesh")
meshobj.Mesh = mymesh
doc.recompute()

Este es un ejemplo estándar que utiliza el método createSphere() para crear una esfera, pero también puedes crear mallas personalizadas desde cero definiendo sus vértices y caras.

Leer más sobre guionización de malla...

Inicio

Piezas

El Pieza módulo es el módulo más potente de todo FreeCAD. Te permite crear y manipular objetos BREP. BREP significa "Representación de Límites". Un objeto BREP está definido por superficies que encierran y definen un volumen interior. A diferencia de las mallas, los objetos BREP pueden tener una gran variedad de componentes, desde caras planas hasta superficies NURBS muy complejas.

El módulo de Piezas está basado en la potente librería OpenCasCade, que permite realizar una amplia gama de operaciones complejas sobre estos objetos, como operaciones booleanas, fileteado, lofts, etc.

El módulo de Piezas funciona del mismo modo que el módulo de mallas: Se crea un objeto de FreeCAD, un objeto de Pieza, luego añadir el objeto de pieza al objeto de FreeCAD:

import Part
myshape = Part.makeSphere(10)
myshape.Volume
myshape.Area

shapeobj = doc.addObject("Part::Feature", "MyShape")
shapeobj.Shape = myshape
doc.recompute()

El módulo Pieza (como el módulo de Mallas) también tiene un atajo que automáticamente crea un objeto de FreeCAD y le añade una forma, por lo que puede acortar las tres últimas líneas a:

Part.show(myshape)

Al explorar el contenido de myshape, notarás muchos subcomponentes interesantes como Faces, Edges, Vertexes, Solids y Shells, y una amplia gama de operaciones de geometría como cut (sustracción), common (intersección) o fuse (unión). En la página Guionización de topología de datos se explica todo esto en detalle.

Leer más sobre guionización pieza...

Inicio

Borrador

FreeCAD proporciona varios módulos, como el Croquizador o Borrador, que también crean objetos de piezas, pero le añade parámetros, o incluso un nuevo modo de manejar la geometría de las piezas. Nuestro cubo de ejemplo de arriba, es un perfecto ejemplo de objeto paramétrico. Todo lo que necesitas, para definir el cubo, es especificar un conjunto de parámetros, como las altura, ancho y longitud. Basados en los cuales, el objeto calculará automáticamente su forma de Pieza. FreeCAD te permite crear dichos objetos en Python.

El Borrador Módulo añade tipos de objetos paramétricos 2D (que son todos objetos Pieza) como líneas y círculos, y también proporciona algunas funciones genéricas que no sólo funcionan con objetos Borrador, sino con cualquier objeto Pieza. Para explorar lo que está disponible, simplemente haga:

import Draft
rec = Draft.makeRectangle(5, 2)
mvec = FreeCAD.Vector(4, 4, 0)
Draft.move(rec, mvec)
Draft.move(box, mvec)

Inicio

Interfaz

La interfaz de usuario de FreeCAD está creada con Qt, un poderoso sistema de interfaces gráficas, responsable de dibujar y manejar todos los controles, menús, barras de herramientas y botones en toda la vista 3D. Qt proporciona un módulo, denominado PyQt, que permite a Python acceder y modificar interfaces Qt, como la de FreeCAD. Vamos a tratar de lidiar con la interfaz de Qt y producir un letrero de diálogo simple:

from PySide import QtGui
QtGui.QMessageBox.information(None, "Apollo program", "Houston, we have a problem")

Observa que el diálogo que aparece tiene el icono de FreeCAD en su barra de herramientas, lo que significa que Qt sabe que la orden ha sido emitida desde dentro de la aplicación FreeCAD. Es posible manipular cualquier parte de la interfaz de FreeCAD.

Qt es un sistema de interfaz muy potente que permite hacer cosas muy complejas. También tiene algunas herramientas fáciles de usar como el Qt Designer con el que puedes diseñar diálogos gráficamente y luego añadirlos a la interfaz de FreeCAD con unas pocas líneas de código Python.

Lee más sobre PySide aquí...

Inicio

Macros

Ahora que tienes una buena comprensión de los conceptos básicos, a dónde vamos para mantener nuestros archivos de guión en Python, y cómo vamos a ejecutarlos fácilmente desde FreeCAD? Existe un sencillo mecanismo para ello, denominado Macros. Una macro es simplemente un archivo de guión en Python, que puede ser añadida a una barra de herramientas y lanzada desde un simple clic de ratón. FreeCAD proporciona un simple editor de textos (Macro -> Macros -> Crear) donde puedes escribir o pegar archivos de guión. Una vez esté terminado, Herramientas -> Personalizar -> Macros te permite definir un botón para ella, que se puede añadir a las barras de herramientas.

External scripts

An alternative method for creating, saving, and running your own Python scripts is to create them outside FreeCAD, using an editor of your choice (for example, Vim). To run your Python script inside FreeCAD, be sure to save it with the .py extension.

Then use File → Open to open your script. It will load into a new tab in the Main view area. You can run your script by clicking the Execute macro button. Any errors or script output will be shown in the Report view.

When you make and save any modifications to your already-loaded script, a dialog box will appear asking whether you want to reload the modified script into FreeCAD.

Ahora estás listo para profundizar en guionización FreeCAD. Así que dirígete al Centro usuarios avanzados!

Inicio