Macro FCInfo/fr

Description
Donne une série de renseignements sur la forme sélectionnée et peut afficher une conversion de la longueur, de l'inclinaison de la forme (degrés, radian, grade, pourcent), de la surface, du volume et du poids de la forme dans la densité sélectionnée dans différentes unités de grandeurs internationales et anglo-saxonnes.



Utilisation
Sélectionnez un objet ou lancez l'application et sélectionnez un objet, et une série de renseignements s'affichent. Les calculs son basés sur l'unité de FreeCAD, qui est le mm à chaque nouvelle sélection, l'unité de longueur revient toujours sur mm et angle sur degrés décimal.



Secteur 1: Document
 * Nom du document courant
 * Label de l'objet
 * Nom interne de l'objet
 * Sub élément, nom du sous élément
 * Le type d'objet

Secteur 2: Coordinates click mouse
 * Coordonnées X,Y et Z à l'endroit du clic de souris
 * Le bouton crée sur le point, l’axe, le plan, copie la forme de l’axe vectoriel FreeCAD.Vector (-24.0, 240.0, 7.0)

Secteur 3: Value
 * Longueur de l'objet, si l'objet est une face le périmètre de la face est affiché
 * boite déroulante permet de choisir l'unité de longueur voulue, sont disponibles : km, hm, dam, m, dm, cm, mm, µm, nm, pm, fm, inch, link, foot, yard, perch, chain, furlong, mile, league, nautique. Si un cercle est détecté une deuxième boîte de dialogue s'ouvre et affiche le rayon du cercle. Si l'objet est un cercle une seconde lineEdit est ouverte et affiche le rayon du cercle.
 * Périmètre du shape

Secteur 4: Vertexes et détails max 200 éléments seront affichés dans la table, s'il y a plus de 200 éléments, (!+ 200) s'affiche et le nombre total d'éléments de la forme (le détail de tous les éléments est sauvé dans un fichier au format CSV en cliquant sur le bouton . Le fichier peut être lu en cliquant sur le bouton ou avec un tableur externe comme LibreOffice OpenOffice ou celui de votre choix)
 * CheckBox case à cocher qui permet d'activer la recherche complète de tous les éléments de l'objet sélectionné. Cette option a été introduite pour diminuer le temps de recherche des éléments surtout pour les objets très compliqués. Si décochée (par défaut) seul les éléments principaux de l'objet seront recherchés et affichés.
 * Vertexes et détails du shape (compt_Edge), (compt_Faces), (compt_Vector of the Face)

Secteur 5: Inclinaison
 * Inclinaison de l'objet est affiché dans les formats suivants :
 * Degrés décimal, ex : 174.831872611°
 * Degrés minutes secondes, ex: 174° 49' 54.741401''
 * Radians, ex: 3.05139181449 rad
 * Grades, ex: 194.257636235 gon
 * Pourcent ex: 30° = 57.74%
 * Inclinaison des plans XY, YZ, ZX et leurs coordonnées correspondantes
 * '''Direction Objet", donne la direction de l'objet. La direction est calculée : direction = (ou inverse , coord_2 - coord_1 )
 * , crée une ligne dans la direction de l'objet (ex: 0,0,0 direction obtenue)
 * ValueAt, donne la direction valueAt du vecteur correspondant

Secteur 6: Surface et volume (Le "spinBox" est réglé sur 1,0 kg). tonne, quintal, kg, hg, dag, gramme, dg, cg, mg, µg, ng, pg, fg, gr (grain), dr (drachm), oz (once), oz t (once troy), lb t (livre troy), lb (livre av), st (stone), qtr (quarter), cwt (hundredweight), tonneau fr, ct
 * Surface de la forme sélectionnée dans l'unité choisie
 * Surface de la face sélectionnée dans l'unité choisie
 * Volume de la forme sélectionnée dans l'unité choisie
 * Densité du matériau utilisé en kg par dm3
 * La boîte déroulante permet de choisir l'unité de masse disponible:
 * Le poids de la forme est affiché dans l'unité de masse sélectionné

Secteur 7: BoundBox Le BoundBox est le volume occupé de l'objet dans l'espace, ce volume délimité par les coordonnées extérieures maximales dans les axes XYZ

Secteur 8: Centre du:
 * Centre du shape avec ses coordonnées XYZ
 * Center massique de la forme avec ses coordonnées XYZ
 * Le crée un point, axes, plans, copie du repère vectoriel sous la forme FreeCAD.Vector(-24.0, 240.0, 7.0)

Secteur 9: Inertie (même commande pour inertie massique)
 * Moment d'inertie et ses coordonnées (longueur et masse)
 * Le crée un point, axes, plans, copie du vecteur sous la forme FreeCAD.Vector(-24.0, 240.0, 7.0)
 * action line 1 : x1, y1, z1
 * action line 2 : x2, y2, z2
 * action line 3 : x3, y3, z3
 * action 4 diagonal : x1, y2, z3
 * Déterminant 1 : calcule le déterminant de la matrice en notation scientifique
 * Déterminant 2 : même valeur en notation décimale

Section 10: SpreadSheet
 * : Ouvre un fichier .FCInfo, csv, asc, txt
 * : Sauve les données dans un fichier .FCInfo, csv, asc, txt
 * : Le séparateur est une tabulation.
 * : Le séparateur est une virgule
 * : Le séparateur est un point virgule
 * : Le séparateur est un espace

Cette option permet de sauver le tableur avec différents séparateurs, Tabulation, Virgule, Point virgule, Espace

La tabulation est le séparateur par défaut du module spreadSheet de FreeCAD.

Le nombre de séparateurs est affiché à l'ouverture du fichier et permet "éventuellement" de déterminer le séparateur utilisé dans le fichier.

La virgule était le séparateur utilisé dans les anciennes versions de FCInfo (1.16 et avant)

Maintenant depuis la version 1.17 le séparateur utilisé par défaut est la tabulation

Si vous voulez convertir vos anciens fichiers .FCinfo : cochez l'option virgule ouvrez le fichier dans FCInfo et sauvez le avec l'option Tabulation cochée.

Section 11: Main
 * : si la case est cochée les coordonnées sont copiées en mémoire dans la format : FreeCAD.Vector(-24.0, 240.0, 7.0)
 * : si la case est cochée un point est créé aux coordonnées affichées.
 * : si la case est cochée une série d'axes dans les plans XYZ sont créés aux coordonnés affichées.
 * : si la case est cochée une série de plans dans les plans XYZ sont créés aux coordonnés affichées.
 * : Rafraîchi les données dans la macro.
 * : Quitte la macro (la macro reste en mémoire vous pouvez la redémarrer par votre bouton ou par le menu "Affichage → Panneaux → FCInfo"
 * 1 : Si cette case est cochée les informations sont affichées dans la vue rapport.
 * 2 : Si cette case est cochée la fenêtre de la macro est placée à gauche de l'écran sinon elle se placera à droite de l'écran (option par défaut).

Une fois la macro lancée, la macro reste active et la fenêtre reste visible. Il faut quitter la macro par la touche. Si vous quittez par la petite croix, la fenêtre disparaît et la macro reste en mémoire, les données continuent de s'afficher dans la vue rapport de FreeCAD.

Longueur :
km, hm, dam, m, dm, cm, mm, µm, nm, pm, fm, inch, link, foot, yard, perch, chain, furlong, mile, league, nautique.

Degrés d'angle :

 * 1) degré décimal, ex: 174.831872611°
 * 2) degré minute seconde, ex: 174° 49' 54.741401''
 * 3) radian, ex: 3.05139181449 rad
 * 4) grade, ex: 194.257636235 gon
 * 5) pourcent, ex: 30° = 57.74%

Compréhension de l'affichage des angles dans FCInfo.

Unités de masse :
ton, quintal, kg, hg, dag, gram, dg, cg, mg, µg, ng, pg, fg, gr (grain), dr (drachm), oz (once), oz t (once troy),

lb t (livre troy), lb (livre av), st (stone), qtr (quarter), cwt (hundredweight), tonneau fr, ct

Le "spinBox" de densité est réglé sur 7,5 kg, densité moyenne de l'acier. Si vous désirez mettre une autre valeur par défaut, modifiez la valeur de la densité ,ligne 208

Un fichier peut être créé par le bouton. Le fichier est écrit comme un fichier csv de cette manière, les données peuvent être étudiées dans un tableur dans FreeCAD ou OpenOffice, LibreOffice ...

Script
Copiez le contenu de la macro dans un fichier nommé "FCInfo.FCMacro"
 * Windows: habituellement " drive:\Users\your_user_name\AppData\Roaming\FreeCAD\ ".
 * Ubuntu : habituellement " /home/your_user_name/.FreeCAD ".

Ou, directement dans l'interface de FreeCAD.

Les icônes doivent se trouver dans le même répertoire que la macro.

Télécharger les images en vous positionnant sur les icônes   puis faites clic droit de la souris "Enregistrer l'image sous"(ne pas modifier le nom)

PS: trop long pour être contenu dans la page du wiki (pour le moment les pages du wiki n'acceptent que 64 ko) le code de la macro a été placé dans le forum 

Il y a aussi une version seulement FCInfo_Alternate_Linux pour la version FreeCAD 0.13... et PyQt4

Il y a aussi une version Macro_FCInfo_Alternate_Linux ici le code est modifié (à cause de l'erreur d'affichage des caractères : ² ³ ° µ" ordinal not in range (128)") qui posaient problèmes dans certaines configurations les fonctions sont les mêmes

Exemple :

Les fichiers sauvé avec cette version sont incompatibles avec les autres version (à cause de l'encodage différent)

Téléchargez le fichier des icônes de FCInfo Macro_FCInfo_Icon décompressez le fichier et copiez les images dans la même répertoire que la macro.

Téléchargez le fichier FCInfo docké à droite

(Ou sur le forum. )

PS: Cette macro utilise la fonction getSelection et la liste des objets commence à 1 ex: pour un cube Edge1 jusque Edge12 (arêtes) et le code qui liste les arêtes dans la console Python commence à 0 ex: pour un cube Edge[0] jusque Edge[11]

Cette différence est tout à fait normale le compteur de la liste/tableau dans OpenCascade commence toujours à 1 et pas à 0

Limitations
Toujours utiliser le bouton. Si vous quittez le programme sans passer par le bouton, le programme reste en mémoire et continue à s'exécuter et l'affichage continue dans le "rapport de visualisation". Vous devez quitter FreeCAD pour l’effacer de la mémoire.

Seuls les 200 premiers éléments de l’objet sont visibles dans le tableau, s’il y a plus de 200 éléments dans l’objet un signal sera affiché par "'(! +200)'". La liste complète des données est visible dans le fichier sauvegardé par le bouton.

Si la fenêtre de la macro n'est pas visible au lancement, regardez en bas de la fenêtre :





en projet :

lecture du fichier directement dans un tableau. fait

correspondances des "Edges" et de leurs coordonnées fait

association d'une substance à sa masse volumique

inclinaison sur l'élément plutôt que sur l'objet global fait

incrustation à droite dans l'interface de FreeCAD fait

actuellement :
 * ver 1.21-3.01, 07/11/2019 # 07/11/2019 ver "01.21-3-rmu" remplacé caractères micro = "U", square = "2", cube = "3", degrees = " deg" see "https://forum.freecadweb.org/viewtopic.php?f=3&t=6005&start=70#p345819"
 * ver 1.21-2.01 (1.21-rmu) 11/06/2019 rmu remplacé tous les caractères au dessus de 127 in ex: "°" en chr(176))   #degree
 * ver 1.21.01 (1.21-rmu) 30/05/2019 rmu change fixed positions to qt layouts grid.addWidget by rmu75 see the rmu75 fork "https://gist.github.com/rmu75/b165147bd1c2f2659c014103793ae1d8"
 * ver 1.21, 16/04/2019 optimisation pour Py 3... Qt 5...
 * ver 1.20, 29/01/2018 optimisation
 * ver 1.19, 20/01/2018 mise en place d'une case à cocher pour activer ou désactiver le module spreadSheet, le module ralenti la macro si l'objet sélectionné est "compliqué". Optimisation.
 * ver 1.18, 19/12/2017 ....
 * ver 1.17c, 14/12/2017 création de plans avec las mêmes coordonnées d'un projet dans un autre projet et remplacement de "FCInfo" by "__title__"
 * ver 1.17b, 13/12/2017 petite correction remplascé FCTreeView to FCInfo
 * ver 1.17, 12/12/2017 ajout et mise à jour de la section Moment of inertia mm et kg par pinq FCMacro and moment of inertia of assembly, et création de plans, axes, point, et ajout de l'option sépateur pour le spreadsheet
 * ver 1.16, 21/06/2017 ajout du contrôle de la hauteur des caractères (here PointSize 8) et checkbox pour la position de la fenêtre à gauche ou à droite


 * ver 1.16, 21/06/2017 ajout d'un contrôle sur la hauteur des caractères affichés, ajout d'une case à cocher pour positionner la macro à gauche ou droite et nouveau code de recherche de chemin de l'emplacement des macros.
 * ver 1.15, 19/12/2015 suppression de l'option PyQt4 voir la cause , ajout d'un checkBox pour éditer ou non les infos dans la vue rapport
 * ver 1.14, 04/08/2014 PyQt4 et PySide, correction des tooltips qui ne s'affichaient plus a cause de PySide, ajout de "fg" et d'une décimale dans la densité
 * ver 1.13, 27/07/2014 remplacement FCInfo_fr_Ver_1-12_Docked.FCMacro avec FCInfo_fr_Ver_1-13_Docked.FCMacro accepte PyQt4 et PySide


 * ver 1.12, 10/03/2014 ajout de tooltips sur les boutons.
 * ver 1.11, 04/03/2014 ajout de µm, nm, pm, fm, µg, ng, pg, pour-cent, correction de la grandeur carat "cd" en "ct", affichage du label et du nom interne, correction du calcul des angles XY YZ ZX fonctionnait bien sur un objet simple mais donnait une valeur erronée sur une pièce composée (prenait d'autres coordonnées ! découvert en comparant le tableau et les coordonnées affichées dans la section Inclinaisons), fenêtre volante ou dockable n'importe où dans FreeCAD


 * ver 1.10.b, 19/11/2013 boutons à l'extérieur du scrollbar et blocage des dimensions de la fenêtre
 * ver 1.10, 18/11/2013 ajout d'une "scrollbar" pour diminuer la dimension de la fenêtre
 * ver 1.08.b 10/11/2013 correction d'erreur d'affichage de la surface des faces listées dans le tableau et remplacement des "print" par "App.Console.PrintMessage"

ver 1.09, 04/11/2013 fonctionne parfaitement sur Windows et Linux (cause de l'erreur les caractères : ² ³ ° " ordinal not in range(128)")

Dans certaines distributions Linux et dans le cas d'une erreur "ordinal not in range (128)" une autre version existe sur cette page Macro_FCInfo_Alternate_Linux


 * ver 1.08, 24/10/2013 correction de l'affichage dans le fichier des "Faces" et "Edges" haut dessus de 100 objets
 * ver 1.07, 11/10/2013 correspondance des "Faces" et de leurs coordonnées.
 * ver 1.06, 22/09/2013 correspondances des "Edges" et de leurs coordonnées, inclinaison sur l'élément plutôt que sur l'objet global
 * ver 1.05, 17/09/2013 ajout d'un icône pour le tableur, conversion en tonneau fr, affichage des dimensions hors tout à la place des coordonnées.
 * ver 1.04, 11/09/2013: lecture du fichier et affichage directement dans un tableau
 * ver 1.03, 09/09/2013: affichage plus clair dans Vue rapport et remplacement par "typeObject = sel[0].Shape.ShapeType"
 * ver 1.02, 7/09/2013 : petites mises au point
 * ver 1.00, 6/09/2013

Liens
Voir aussi Arch Prise de cotes

Vous pouvez faire part de vos commentaires sur le forum Info Workbench - Help with icons please.

Ici un autre post traitant de FCInfo Macro