OpenSCAD Workbench/fr

Introduction
L' atelier OpenSCAD est destiné à offrir une interopérabilité avec le logiciel open source OpenSCAD. Ce programme n'est pas distribué comme partie prenante de FreeCAD, mais doit être installé pour utiliser pleinement cet atelier. OpenSCAD ne doit pas être confondu avec OpenCASCADE, qui est le noyau géométrique que FreeCAD utilise pour créer la géométrie à l'écran. Les bibliothèques OpenCASCADE sont toujours nécessaires pour utiliser FreeCAD tandis que l'exécutable OpenSCAD est entièrement facultatif.

Il contient un importateur CSG pour ouvrir les fichiers CSG créés par OpenSCAD et un exportateur pour générer une arborescence basée sur CSG. Les géométries non basées sur des opérations CSG seront exportées sous forme de maillage.

Cet atelier contient des fonctions permettant de modifier l'arborescence des éléments CSG et de réparer les modèles. Il contient également des outils d'usage général qui ne nécessitent pas l'installation d'OpenSCAD et peuvent être utilisés conjointement avec d'autres ateliers. Par exemple, l'Atelier Mesh utilise en interne les fonctions OpenSCAD pour effectuer des opérations avec de maillage car elles sont assez robustes.



Dépendances
Dans FreeCAD 0.19, le module Ply (Python-Lex-Yacc), qui est utilisé pour importer des fichiers CSG, a été supprimé du code source de FreeCAD, car il s'agit d'une bibliothèque tierce non développée par FreeCAD. Par conséquent, vous devez maintenant installer Ply avant d'utiliser OpenSCAD Workbench. Lorsque vous utilisez une version pré-packagée et stable de FreeCAD, cette dépendance doit être installée automatiquement sur toutes les plates-formes. Dans d'autres cas, par exemple, lorsque vous voulez compiler à partir de la source, vous devrez peut-être l'installer à partir d'un référentiel en ligne.

Sur les systèmes basés sur Debian/Ubuntu, cela se fait de la manière suivante :

L'installation générale sur toutes les plates-formes peut être effectuée à partir de l'index du package Python.

Langage OpenSCAD et format de fichier
Le langage OpenSCAD permet l'utilisation de variables et de boucles. Il permet de spécifier les sous-modules pour réutiliser le code et les formes géométriques. Cette grande flexibilité, rend l'analyse très complexe. Actuellement le module OpenSCAD de FreeCAD ne permet pas de gérer le langage OpenSCAD nativement. Au contraire, si OpenSCAD est installé, il est utilisé pour compiler l'entrée dans un format de sortie nommé CSG. C'est un sous-ensemble du langage d'OpenSCAD et peut être utilisé comme entrée de OpenSCAD pour un traitement ultérieur. Cependant dans cette étape de la compilation, tous les comportements paramétriques sont perdus. Tous les noms de variables seront écartés, les boucles sont élargies et les expressions mathématiques sont évaluées.

Outils

 * [[Image:OpenSCAD_ColorCodeShape.svg|32px]] ColorCodeShape : Change la couleur de la sélection, ou toutes les formes en fonction de leurs validités.
 * [[Image:OpenSCAD_ReplaceObject.svg|32px]] Remplacement d'un objet : Remplace un objet dans l'arborescence des éléments.
 * [[Image:OpenSCAD_RemoveSubtree.svg|32px]] Suppression de l'arborescence : Supprime les objets sélectionnés, et toute leur descendance non référencée depuis d'autres objets.
 * [[Image:OpenSCAD_RefineShapeFeature.svg|32px]] Affinage de la forme : Crée et affine les caractéristiques de la forme.
 * [[Image:OpenSCAD_MirrorMeshFeature.svg|32px]] Maillage miroir: Crée un maillage en miroir.
 * [[Image:OpenSCAD_ScaleMeshFeature.svg|32px]] Mettre à l'echelle: Changer d'echelle un maillage.
 * [[Image:OpenSCAD_ResizeMeshFeature.svg|32px]] Redimensionner le maillage: Redimensionne le maillage.
 * [[Image:OpenSCAD_IncreaseToleranceFeature.svg|32px]] Augmenter la tolérance : Augmente la tolérance des arêtes/faces/sommets des objets sélectionnés.
 * [[Image:OpenSCAD_Edgestofaces.svg|32px]] Convertir des arêtes en faces : Converti les Bords en Faces. Utile pour préparer les formes géométriques DXF importées, pour les extruder.
 * [[Image:OpenSCAD_ExpandPlacements.svg|32px]] Développer les placements : Développe toutes les éléments vers le bas de l'arborescence.
 * [[Image:OpenSCAD_ExplodeGroup.svg|32px]] Dégrouper: Dégroupe les primitives des pièces fusionnées.
 * [[Image:OpenSCAD_AddOpenSCADElement.png|32px]] Ajout d'un élément OpenSCAD : Ajoute un élément OpenSCAD en entrant le code OpenSCAD dans le panneau de tâches et exécute le binaire OpenSCAD (OpenSCAD doit être installé sur votre ordinateur) Remarque: Cet icône ne s'affiche pas (même si OpenSCAD est installé sur votre ordinateur), vous devez également configurer FreeCAD. Voir ici pour plus de détails
 * [[Image:OpenSCAD_MeshBoolean.svg|32px]] Maillage à partir d'opération booléenne : Crée un nouvel objet maille avec une opération booléenne à partir de plusieurs formes.
 * [[Image:OpenSCAD_Hull.svg|32px]] Enveloppe convexe : Applique une coque aux formes sélectionnées.
 * [[Image:OpenSCAD_Minkowski.svg|32px]] Somme de Minkowski : Applique une somme de Minkowski aux formes sélectionnées.

Préférences

 * [[Image:Std_DlgPreferences.svg|32px]] Préférences...: préférences disponibles dans OpenSCAD Tools.

Limites
OpenSCAD permet la construction de formes géométriques solides, comme l'importation de fichiers de maillage et d'extrusion géométriques 2d à partir de fichiers DXF. FreeCAD permet ainsi de faire des .CSG avec primitives. Le noyau géométrique de FreeCAD (OCCT) travaille sur une représentation des frontières. La conversion de .CSG en BREP doit donc être théoriquement possible, alors que la conversion de BREP vers .CSG ne l'est généralement pas.

OpenSCAD fonctionne en interne avec les maillages (mesh). Certaines opérations qui sont utiles sur les maillages ne sont pas significatives sur un modèle BREP et peuvent ne pas être entièrement supporté. Parmi celle-ci figurent le recouvrement convexe, la somme de Minkowski, glide et subdiv. Pour l’instant OpenSCAD est exécuté pour réaliser le recouvrement convexe et la somme de Minkowski et importer le résultat. Cela signifie que la géométrie impliquée sera triangulée. Avec OpenSCAD la mise à l’échelle non uniforme est souvent utilisée, ce qui ne pose pas de problèmes avec les maillages. Avec notre noyau géométrique, les formes primitives (lignes, sections circulaires, etc) sont converties en BSpline avant d’être déformées. Ces BSplines sont connues pour poser problèmes avec des opérations booléennes futures. Une solution automatique n’est pas disponible pour le moment. S’il vous plaît n’hésitez pas à poster sur le forum si vous rencontrez ce genre de problème. Souvent ce genre de problèmes peut être résolu en modélisant des parties plus petites. Une déformation d’un cylindre peut être remplacée par l’extrusion d’une ellipse.

Importing text
Importing OpenSCAD code with texts requires that the fonts that are used are properly installed on your system. You can verify this by opening OpenSCAD as a standalone tool and checking the list in. The list will also give you the correct font names. If a font does not appear in the list after installing, you may have to manually copy the font file to the appropriate system directory.

Importing texts is relatively slow. Behind the scenes FreeCAD uses a DXF file created by OpenSCAD. The more contours there are the slower the import.

It can be a good idea to first import a simple test case (replace with the correct font name):

TESTFONT="NameOfFont"; linear_extrude(0.001) { text("A", size=5, font=TESTFONT); };

Please note that statements in your source files are ignored when importing in FreeCAD. Under OpenSCAD the effect of a statement is that the provided font file is temporarily added to the list of known fonts (although even there the statement does not work when a script is modified interactively).

Conseils
Lors de l'importation du fichier DXF, il faut définir la précision du projet à une valeur raisonnable, car cela aura une incidence sur la détection des arêtes connectées.

Si FreeCAD se bloque lors de l'importation de CSG, il est fortement recommandé d'activer la case à cocher Vérifier les modèles automatiquement après une opération booléenne dans le menu

Tutoriels

 * Importer code OpenSCAD

Liens

 * Dépôt du code source d'OpenSCAD GitHub
 * Open tickets tagged "Openscad" sur le FreeCAD bugtracker
 * Plus de renseignements au sujet d'Openscad sur Thingiverse