Macro FCInfo/fr

Description
Donne des informations sur la forme sélectionnée et peut afficher une conversion de la longueur, de l'inclinaison (degrés, radians, grades, pourcentage), de la surface, du volume et du poids dans différentes unités (métriques et impériales). La macro fonctionne désormais aussi pour les éléments d'une esquisse en mode édition.



Utilisation
Sélectionnez un objet ou lancez l'application et sélectionnez un objet. Une série de renseignements s'affichent. Les calculs sont 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 à partir de FreeCAD.Vector (-24.0, 240.0, 7.0)




 * Coordinates X,Y and Z click to mouse
 * The creates point, axis, plane, copy vector axis from FreeCAD.Vector(-24.0, 240.0, 7.0)

Sector 3: Color on point


Secteur 3: Value km, hm, dam, m, dm, cm, mm, µm, nm, pm, fm, inch, link, foot, yard, perch, chain, furlong, mile, league, nautique.
 * Si l'objet est un périmètre de face, la longueur de l'objet est affichée. La taille de l'unité peut être sélectionnée :
 * Si l'objet est un cercle, une deuxième ligne s'affiche et donne le rayon du cercle.
 * Périmètre de la forme.

Sector 4: Value Units


km, hm, dam, m, dm, cm, mm, µm, nm, pm, fm, inch, link, foot, yard, perch, chain, furlong, mile, league, nautique.
 * : If the object is a face perimeter, length of the object is displayed. Unit size can be selected :
 * Length of the object : Length of the object or perimeter of the face.
 * If the object is a circle, a second lineEdit Radius : is opened and display the radius and diameter of circle.
 * Perimeter of the shape (12). Perimeter of the object and number of subObject (Edges) contained in the object.

Sector 5: Inclination



 * Inclination of the object can be displayed in:
 * decimal degree, ex:
 * degree minute seconde, ex:
 * radian, ex:
 * grade, ex:
 * pourcent, ex: 30° =
 * Inclinations in planes XY, YZ, ZX and their coordinates
 * Direction object, give the direction of object. The calculate is : coord_1 - coord_2 = direction (or reverse)
 * this button create a line in direction of the object.
 * ValueAt(0), returns the 3D vector corresponding to a parameter value.
 * this button create a line in ValueAt direction of the object.
 * NormalAt(0,0), returns the 3D vector corresponding to a parameter value.
 * this button create a line in NormalAt direction of the object.

Sector 6: Surface and Volume


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. (the "spinBox" is set to 7,5 kg, average density of steel. If you want a different default value, change the value of the density, line 204).
 * Surface of the form displayed, unit size can be selected.
 * Surface of the face displayed, unit size can be selected.
 * Volume of the form displayed, unit size can be selected.
 * Unit, choice your unit.
 * The unit mass can be chosen :
 * Weight of the form displayed, unit mass can be selected.
 * Density of the material in kg by dm3
 * Material
 * In beginning the macro search the file FCInfo_material.txt, if the file not exist, one file FCInfo_material.txt is created.
 * The file is created with 10 types of material saved in this format.
 * Title of material, Density on dm3 , Price on dm3 , text info on choice
 * (4 fields separate by coma)
 * Liquid Water (H2o),1,10.0,adapt Price
 * Mater Beton,2.4,10.0,adapt Price
 * Metal Aluminium (Al),2.7,10.0,adapt Price
 * Metal Copper (Cu),8.96,10.0,adapt Price
 * Metal Gold (Au),19.3,10.0,Gratis
 * Metal Iron (Fe),7.87,10.0,adapt Price
 * Metal Lead (Pb),11.35,10.0,adapt Price
 * Metal Magnesium (Mg),1.43,10.0,adapt Price
 * Metal Nickel (Ni),8.27,10.0,adapt Price
 * Metal Pewter (Sn),7.29,10.0,adapt Price
 * Metal Platinum (Pt),21.45,10.0,adapt Price
 * Metal Silver (Ag),10.5,10.0,adapt Price
 * Metal Sodium (Na),0.97,10.0,adapt Price
 * Metal Titanium (Ti),4.4,10.0,adapt Price
 * Metal Zinc (Zn),7.1,10.0,adapt Price
 * Wood Beechwood,0.8,10.0,adapt Price
 * Wood MDF,0.75,10.0,adapt Price
 * Wood Mahogany,0.6,10.0,adapt Price
 * Wood Oak,0.7,10.0,adapt Price
 * Wood White pine,0.4,10.0,adapt Price
 * New material or editing
 * you can modify or edit one new material in this format:
 * Title, Density on dm3, Price on dm3, text info on choice
 * (4 fields separate by coma)
 * you can also edit the file in your favorite editor respecting the specific format
 * you can save the file in a path desired with the variable : seTMaterialSavePathName
 * by default the file is created in the macro path
 * : delete the field displayed
 * : save the modification or the new material

Sector 7: Cost



 * Cost total : cost total of the object selected


 * Price (kc/dm3) : price of the material selected (Metal Aluminium (Al),2.7,10.0,adapt Price)

Sector 8: BoundBox



 * BoundBox gives extreme dimensions of the shape.
 * maximum X length :
 * maximum Y length :
 * maximum Z length :
 * diagonal length :
 * : create 6 rectangles to dimensions of boundbox
 * : create volume to dimensions of boundbox
 * : create the dimension of the triangle (boundbox)
 * If the is checked, the spinbox dimension of text  is operational for give your value (3.0 by default)

Sector 9: Center of:



 * Center of the shape and these coordinates XYZ
 * Center of mass and these coordinates XYZ
 * The creates on point, axis, plane, copy vector axis form FreeCAD.Vector(-24.0, 240.0, 7.0) (see Sector 13)

Sector 10: Inertia


same for length and weigth
 * Moment of inertia and these coordinates length and weigth
 * The button creates on point, axis, plane, copy vector axis form FreeCAD.Vector(-24.0, 240.0, 7.0) (see Sector 13)
 * action line 1 :, , ,
 * action line 2 :, , ,
 * action line 3 :, , ,
 * action 4 diagonal :, ,
 * Determinant 1 :  computes the determinant of the matrix, in scientific value
 * Determinant 2 :  computes the determinant of the matrix, in decimal value

Sector 11: Vertexes and details


max 200 lines in the table, if there are more than 200 lines it appears (!+ 200) and the number of lines If the object is complicate with many object the time to be long and the research is repeated to all click mouse (full details can save be the button in a file in CSV format and can be viewed the file in spreadsheet with the  or by an external spreadsheet as LibreOffice OpenOffice or other)
 * CheckBox for for search or not all details of the object. If it is not checked, only the principal value is displayed.
 * Vertexes and details of the shape (compt_Edge), (compt_Faces), (compt_Vector of the Face)

Sector 12: SpreadSheet



 * : read the data in a spreadsheet saved .FCInfo or txt, asc, csv
 * : save the data in disk in the form selected below .FCInfo or txt, asc, csv
 * : the separator is Tabulation (by default)
 * : the separator is Comma
 * : the separator is Semicolon
 * : the separator is Space

Option pour sauvegarder ou lire la feuille de calcul avec différents séparateurs, Tabulation, Virgule, Point-virgule, Espace . La tabulation est le séparateur pour l'[Spreadsheet_Workbench/fr|atelier Spreadsheet] de FreeCAD

Les numéros de ces quatre séparateurs sont calculés pour aider en cas d'inconnu

Les VIRGULES sont les anciens séparateurs de la macro FCInfo (01.16 et avant)

Maintenant pour la compatibilité avec le tableur FreeCAD et depuis la version 01.17, la TABULATION est le séparateur par défaut

Si vous voulez convertir votre ancienne feuille de calcul FCInfo : ouvrez-la dans FCInfo et enregistrez-la avec l'option Tabulation cochée.

Sector 13: Main



 * : if this CheckBox is checked, the informations are displayed in the report view window
 * : if checked, one point is created in the coordinate displayed form : FreeCAD.Vector(-24.0, 240.0, 7.0)
 * : if checked, one axis is created in the coordinate displayed form : FreeCAD.Vector(-24.0, 240.0, 7.0)
 * : if checked, one axis plane is created in the coordinate displayed form : FreeCAD.Vector(-24.0, 240.0, 7.0)
 * : None clipBoard
 * : If checked the coordinate are copy in the clipBoard Form : FreeCAD.Vector(X.0, Y.0, Z.0) FreeCAD model
 * : If checked the coordinate are copy in the clipBoard Form : X, Y, Z with Comma separator
 * : If checked the coordinate are copy in the clipBoard Form : X Y Z as is with Space separator
 * : if this CheckBox is not checked, the window macro are displayed to right (default). If it is checked the window macro are displayed to left. If the option is 1 mode fly (User parameter:BaseApp/Preferences/Macros/FCMmacros/FCInfo/seTPositionFlyRightLeft) this button is not visible.
 * : refresh the display of data in report view
 * : exit properly the macro

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.

Options


Les unités utilisées


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



Unité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 ou gr
 * 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

La "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: le code est trop long pour être contenu dans la page du wiki (pour le moment les pages du wiki n'acceptent que 64 KB). Le code de la macro a été placé dans le forum'''

ColoredParagraph| 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 :

remplacés par

Les fichiers sauvegardés avec cette version sont incompatibles avec l'autre version (docké ou non).

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 à Edge12 (arêtes) et le code qui liste les arêtes dans la console Python commence à 0 ex: pour un cube Edge[0] à 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. Si 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

Version
ver 1.27 2023/06/30 optimize the styleSheet, correct the left/right position and restore view after edition sketcher

replaced by


 * ver 1.26c 2022/04/19 mise à niveau Erreur BSpline avec Gear Bspline=Line


 * ver 1.26b 20/02/2022 mise à jour pour détecter BSpline dans SubObject


 * ver 1.26 06/02/2022 ajouter des informations sur les objets Mesh et Points, décoder les couleurs, dupliquer un objet ou un sous-objet, mémoriser le dernier chemin et d'autres options de préférences.

Ajout de
 * ver 1.25e 18/12/2021 ajouter l'info détaillée à BSpline (ToByArcs) et l'info "sel[0].TypeId".
 * ver 1.25d 12/12/2021 ---
 * ver 1.25c 12/12/2021 correction de "strAround((" par "str(Around(" et autres petits ...
 * ver 1.25b 11/12/2021 correction erreur dans changement/modification nouveau matériel et réorganisation
 * ver 1.25 10/12/2021 PySide2 et ajout de matériel comboBox
 * Ver 1.24 02/12/2021 Ajout de adjustedGlobalPlacement modifié par edwilliams16 pour le placement avec Body, traçage boundbox.
 * ver 1.23cb 25/11/2021 delete "import Sketcher * " create conflict with "open(OpenName, "r")' ? ??


 * ver 1.25d, 13/12/2021 petite correction champ matériel décommanter le "'try...Except" !!!
 * ver 1.25c, 12/12/2021 petite correction nouveau matériel
 * ver 1.23b, 20/11/2021 petite correction, ajout de l'info texte au début de la macro et ordonner le code texte.
 * ver 1.23, 19/11/2021 inclut l'icône dans la macro, le nombre de décimales affichées, la hauteur du texte, configure les options dans les Préférences de Freecad, corrige les infos pour les éléments de l'esquisse en mode édition.
 * ver 1.22, 12/11/2020 : maintenant la macro est totalement désinstallée en utilisant :

How do i exit from FreeCAD instead of Python?

instead:

et j'ai ajouté la possibilité d'afficher ou non la fenêtre "Message d'erreur" "Faux" par défaut, si vous voulez activer la fenêtre d'avertissement allez à :


 * 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