Reinforcement BarShapeCutList/fr: Difference between revisions

From FreeCAD Documentation
(Created page with "1. Sélectionnez les objets {{Button|16px Arch Armatures}} et Rebar2 que vous souhaitez inclure dans la nomenclature de façonnage d...")
No edit summary
(42 intermediate revisions by 2 users not shown)
Line 14: Line 14:
|Name/fr=Reinforcement Nomenclature de façonnage des armatures
|Name/fr=Reinforcement Nomenclature de façonnage des armatures
|MenuLocation=Reinforcement → Rebar Shape Cut List
|MenuLocation=Reinforcement → Rebar Shape Cut List
|Workbenches=[[Reinforcement_Workbench/fr|Reinforcement]], [[Arch_Workbench|Arch]], [[BIM_Workbench|BIM]]
|Workbenches=[[Arch_Workbench|Arch]], [[BIM_Workbench|BIM]]
|SeeAlso=[[Arch_Rebar_Drawing_Dimensioning/fr|Arch Dimensionnement des dessins d'armatures]], [[Arch_Rebar_BOM/fr|Arch Nomenclature armature]]
|SeeAlso=[[Reinforcement_Workbench/fr|Reinforcement]], [[Arch_Rebar_Drawing_Dimensioning/fr|Arch Rebar Dimensions dessins]], [[Arch_Rebar_BOM/fr|Arch Rebar Nomenclature]]
|Version=0.19
|Version=0.19
}}
}}
Line 21: Line 21:
==Description==
==Description==


L'outil [[Reinforcement_Bar_Shape_Cut_List/fr|Rebar Shape Cut List]] permet à l'utilisateur de créer une liste pour la coupe et le pliage des barres d'armature.
L'outil [[Reinforcement_Bar_Shape_Cut_List/fr|Rebar Shape Cut List]] permet à l'utilisateur de créer une nomenclature de façonnage des armatures.


Cette commande fait partie de l'[[Reinforcement Workbench/fr|Atelier Reinforcement]], un [[External workbench/fr|Atelier externe]] qui peut être installé avec le [[Image:AddonManager.svg|24px]] [[Addon Manager/fr|Gestionnaire d'Addon]] via le menu {{MenuCommand|Outils → Gestionnaire d'Addon → Reinforcement}}.
Cette commande fait partie de l'[[Reinforcement Workbench/fr|Atelier Reinforcement]], un [[External workbenches/fr|Atelier externe]] qui peut être installé avec le [[Image:AddonManager.svg|24px]] [[Addon Manager/fr|Gestionnaire d'Addon]] via le menu {{MenuCommand|Outils → Gestionnaire d'Addon → Reinforcement}}.


[[Image:Reinforcement_Bar_Shape_Cut_List_example.svg|800px]]
[[Image:Reinforcement_Bar_Shape_Cut_List_example.svg|800px]]
Line 33: Line 33:
1. Sélectionnez les objets {{Button|[[Image:Arch_Rebar.svg|16px]] [[Arch Rebar/fr|Arch Armatures]]}} et Rebar2 que vous souhaitez inclure dans la nomenclature de façonnage des armatures ou sélectionnez les objets {{Button|[[Image:Arch_Structure.svg|16px]] [[Arch Structure/fr|Arch Structure]]}} à inclure aux {{Button|[[Image:Arch_Rebar.svg|16px]] [[Arch Rebar/fr|Arch Armatures]]}} et les objets Rebar2 hébergés par celui-ci dans la nomenclature de façonnage des armatures. Si rien n'est sélectionné, la nomenclature de façonnage des armatures sera générée pour tous les objets {{Button|[[Image:Arch_Rebar.svg|16px]] [[Arch Rebar/fr|Arch Armatures]]}} et Rebar2 présents dans le modèle.
1. Sélectionnez les objets {{Button|[[Image:Arch_Rebar.svg|16px]] [[Arch Rebar/fr|Arch Armatures]]}} et Rebar2 que vous souhaitez inclure dans la nomenclature de façonnage des armatures ou sélectionnez les objets {{Button|[[Image:Arch_Structure.svg|16px]] [[Arch Structure/fr|Arch Structure]]}} à inclure aux {{Button|[[Image:Arch_Rebar.svg|16px]] [[Arch Rebar/fr|Arch Armatures]]}} et les objets Rebar2 hébergés par celui-ci dans la nomenclature de façonnage des armatures. Si rien n'est sélectionné, la nomenclature de façonnage des armatures sera générée pour tous les objets {{Button|[[Image:Arch_Rebar.svg|16px]] [[Arch Rebar/fr|Arch Armatures]]}} et Rebar2 présents dans le modèle.


2. Then select {{Button|[[Image:Reinforcement_Bar_Shape_Cut_List.svg|16px]] [[Reinforcement Bar Shape Cut List|Rebar Shape Cut List]]}} from the rebar tools.
2. Sélectionnez ensuite {{Button|[[Image:Reinforcement_Bar_Shape_Cut_List.svg|16px]] [[Reinforcement_Bar_Shape_Cut_List|Rebar Shape Cut List]]}} dans les outils d'armature.


3. Une boîte de dialogue apparaîtra à l'écran, comme indiqué ci-dessous.
3. A dialog box will pop-out on screen as shown below.


[[Image:Reinforcement_Bar_Shape_Cut_List_Dialog.png]]
[[Image:Reinforcement_Bar_Shape_Cut_List_Dialog.png]]


{{Caption|Dialog Box for the Reinforcement Bar Shape Cut List tool}}
{{Caption|Boîte de dialogue de l'outil Nomenclature de façonnage des armatures}}


4. Modifiez les données en fonction de vos besoins.
4. Modify data to suit your requirements.


5. Click {{Button|OK}} or {{Button|Apply}} to generate Rebar Shape Cut List for rebars.
7. Cliquez sur {{Button|OK}} ou {{Button|Apply}} pour générer la Nomenclature de façonnage des armatures.


6. Click {{Button|Cancel}} to exit the dialog box.
6. Cliquez sur {{Button|Cancel}} pour quitter la boîte de dialogue.


==Properties==
==Propriétés==


'''General:'''
'''Général:'''
* {{PropertyData|Stirrup Extended Edge Offset}}: The offset of extended end edges of stirrup, so that end edges of stirrup with 90 degree bent angle do not overlap with stirrup edges.
* {{PropertyData/fr|Stirrup Extended Edge Offset}}: Le décalage des bords d'extrémité étendus de l'étrier, de sorte que les bords d'extrémité de l'étrier avec un angle de pliage de 90 degrés ne se chevauchent pas avec les bords de l'étrier.
* {{PropertyData|Rebars Stroke Width}}: The stroke-width of rebars in rebar shape cut list.
* {{PropertyData/fr|Rebars Stroke Width}}: La largeur de trait des armatures dans la nomenclature de façonnage.
* {{PropertyData|Rebars Color Style}}: The color style of rebars.
* {{PropertyData/fr|Rebars Color Style}}: Le style de couleur des armatures.
* {{PropertyData|Row Height}}: The height of each row of rebar shape in rebar shape cut list.
* {{PropertyData/fr|Row Height}}: La hauteur de chaque ligne de forme d'armature dans la nomenclature de façonnage.
* {{PropertyData|Column Width}}: The width of each column of rebar shape in rebar shape cut list.
* {{PropertyData/fr|Column Width}}: La largeur de chaque colonne de forme d'armature dans la nomenclature de façonnage.
* {{PropertyData|Column Count}}: The number of columns in rebar shape cut list.
* {{PropertyData/fr|Column Count}}: Le nombre de colonnes dans la nomenclature de façonnage.
* {{PropertyData|Side Padding}}: The padding on each side of rebar shape.
* {{PropertyData/fr|Side Padding}}: Le rembourrage de chaque côté de la forme de l'armature.
* {{PropertyData|Horizontal Rebar Shape}}: If True, then rebar shape will be made horizontal by rotating max length edge of rebar shape.
* {{PropertyData/fr|Horizontal Rebar Shape}}: Si True, alors la forme de l'armature sera rendue horizontale en faisant pivoter le bord de longueur maximale de la forme d'armature.
* {{PropertyData|Include Mark}}: If it is set to True, then rebar.Mark will be included for each rebar shape in rebar shape cut list.
* {{PropertyData/fr|Include Mark}}: si elle est définie sur True, alors rebar.Mark sera inclus pour chaque forme d'armature dans la nomenclature de façonnage.
* {{PropertyData|SVG Output File}}: The output file to write generated rebar shape cut list svg.
* {{PropertyData/fr|SVG Output File}}: Le fichier de sortie pour écrire le SVG de la nomenclature de façonnage.


'''Dimension Data:'''
'''Données de dimension:'''
* {{PropertyData|Include Dimensions}}: If True, then each rebar edge dimensions and bent angle dimensions will be included in rebar shape cut list.
* {{PropertyData/fr|Include Dimensions}}: Si True, les dimensions de chaque arête d'armature et les cotes d'angle plié seront incluses dans la nomenclature de façonnage.
* {{PropertyData|Include Units in Dimension Label}}: If it is True, then rebar edge length units will be shown in dimension label.
* {{PropertyData/fr|Include Units in Dimension Label}}: Si la valeur est True, les unités de longueur de bord d'armature seront affichées dans l'étiquette de dimension.
* {{PropertyData|Rebar Edge Dimension Units}}: The units to be used for rebar edge length dimensions.
* {{PropertyData/fr|Rebar Edge Dimension Units}}: Les unités à utiliser pour les dimensions de longueur de bord d'armature.
* {{PropertyData|Rebar Edge Dimension Precision}}: The number of decimals that should be shown for rebar edge length as dimension label.
* {{PropertyData/fr|Rebar Edge Dimension Precision}}: Le nombre de décimales à afficher pour la longueur du bord de l'armature comme étiquette de cote.
* {{PropertyData|Dimension Font Family}}: The font-family of dimension text.
* {{PropertyData/fr|Dimension Font Family}}: La famille de polices du texte de dimension.
* {{PropertyData|Dimension Font Size}}: The font-size of dimension text.
* {{PropertyData/fr|Dimension Police Size}}: La taille de la police du texte de dimension.
* {{PropertyData|Bent Angle Dimension Exclude List}}: The list of bent angles to not include their dimensions.
* {{PropertyData/fr|Bent Angle Dimension Exclude List}}: La liste des angles pliés pour ne pas inclure leurs dimensions.
* {{PropertyData|Helical Rebar Dimension Label Format}}: The format of helical rebar dimension label. e.g. "%L,r=%R,pitch=%P" where %L -> Length of helical rebar, %R -> Helix radius of helical rebar, %P -> Helix pitch of helical rebar.
* {{PropertyData/fr|Helical Rebar Dimension Label Format}}: Le format de l'étiquette de dimension d'armature hélicoïdale. Par exemple: "%L,r=%R,pitch=%P" %L -> Longueur de l'armature hélicoïdale, %R -> Rayon d'hélice de l'armature hélicoïdale, %P -> Pas d'hélice de l'armature hélicoïdale.


==Scripting==
==Script==


{{Emphasis|See also:}} [[Arch API|Arch API]], [[Reinforcement API|Reinforcement API]] and [[FreeCAD Scripting Basics|FreeCAD Scripting Basics]].
{{Emphasis|Voir aussi:}} [[Arch API/fr|Arch API]], [[Reinforcement API/fr|API de renforts]] et [[FreeCAD Scripting Basics/fr|FreeCAD Scripts de Base]].


The [[Reinforcement Bar Shape Cut List|Rebar Shape Cut List]] tool can be used in [[macros|macros]] and from the [[Python|Python]] console by using the following function:
L'outil [[Reinforcement Bar Shape Cut List/fr|Nomenclature de façonnage des armatures]] peut être utilisé dans des [[macros/fr|macros]] et à partir de la console [[Python/fr|Python]] à l'aide des fonctions suivantes:


=== Create Rebar Shape SVG ===
=== Créer la forme d'une armature en SVG ===


{{Code|code=
{{Code|code=
Line 103: Line 103:
}}
}}


* Generates and return a rebar shape svg element for given {{incode|rebar}} object.
* Génère et renvoie un élément SVG de forme d'armature pour un objet {{incode|rebar}} donné.
* {{incode|rebar}} object can be of type <ArchRebar._Rebar> or <rebar2.BaseRebar>, to generate its shape svg.
* L'objet {{incode|rebar}} peut être de type <ArchRebar._Rebar> ou <rebar2.BaseRebar>, pour générer sa forme SVG.
* {{incode|view_direction}} specifies the view point direction for rebar shape. It can be of type {{incode|FreeCAD.Vector}} or {{incode|WorkingPlane.Plane}} though {{incode|WorkingPlane.Plane}} is preferred.
* {{incode|view_direction}} spécifie la direction du viewpoint pour la forme de l'armature. Il peut être de type {{incode|FreeCAD.Vector}} ou {{incode|WorkingPlane.Plane}} bien que {{incode|WorkingPlane.Plane}} soit préféré.
* {{incode|include_mark}} specifies if rebar.Mark is to be included in rebar shape svg or not.
* {{incode|include_mark}} spécifie si rebar.Mark doit être inclus dans le SVG de forme d'armature ou non.
* {{incode|stirrup_extended_edge_offset}} is the offset of extended end edges of stirrup, so that end edges of stirrup with 90 degree bent angle do not overlap with stirrup edges.
* {{incode|stirrup_extended_edge_offset}} est le décalage des bords d'extrémité étendus de l'étrier, de sorte que les bords d'extrémité de l'étrier avec un angle plié à 90 degrés ne se chevauchent pas avec les bords de l'étrier.
* {{incode|rebar_stroke_width}} specifies the stroke-width of rebar in svg.
* {{incode|rebar_stroke_width}} spécifie la largeur de trait de l'armature en SVG.
* {{incode|rebar_color_style}} specifies the color style of rebar. It can be "shape color" or "color_name or hex_value_of_color". "shape color" means select color of rebar shape.
* {{incode|rebar_color_style}} spécifie le style de couleur de l'armature. Il peut s'agir de "couleur de forme" ou "nom_couleur ou valeur_hexique_de_couleur". "couleur de forme" signifie sélectionner la couleur de la forme de l'armature.
* {{incode|include_dimensions}} specifies if each rebar edge dimensions and bent angle dimensions is to be included in rebar shape svg.
* {{incode|include_dimensions}} spécifie si chaque dimension d'arête d'armature et les dimensions d'angle plié doivent être incluses dans le SVG de forme d'armature.
* {{incode|rebar_dimension_units}} specifies the units to be used for rebar length dimensions.
* {{incode|rebar_dimension_units}} spécifie les unités à utiliser pour les dimensions de longueur d'armature.
* {{incode|rebar_length_dimension_precision}} specifies the number of decimals that should be shown for rebar length as dimension label. Set it to None to use user preferred unit precision from FreeCAD unit preferences.
* {{incode|rebar_length_dimension_precision}} spécifie le nombre de décimales à afficher pour la longueur de l'armature en tant qu'étiquette de dimension. Définissez-le sur Aucun pour utiliser la précision d'unité préférée de l'utilisateur dans les préférences d'unité de FreeCAD.
* {{incode|include_units_in_dimension_label}} specifies if rebar length units is to be shown in dimension label.
* {{incode|include_units_in_dimension_label}} spécifie si les unités de longueur d'armature doivent être affichées dans l'étiquette de dimension.
* {{incode|bent_angle_dimension_exclude_list}} specifies the list of bent angles to not include their dimensions.
* {{incode|bent_angle_dimension_exclude_list}} spécifie la liste des angles pliés pour ne pas inclure leurs dimensions.
* {{incode|dimension_font_family}} specifies the font-family of dimension text.
* {{incode|dimension_font_family}} spécifie la famille de polices du texte de cote.
* {{incode|dimension_font_size}} specifies the font-size of dimension text.
* {{incode|dimension_font_size}} spécifie la taille de la police du texte de cote.
* {{incode|helical_rebar_dimension_label_format}} specifies the format of helical rebar dimension label. E.g. "%L,r=%R,pitch=%P" where:
* {{incode|helical_rebar_dimension_label_format}} spécifie le format de l'étiquette de dimension d'armature hélicoïdale. Par exemple. "%L,r=%R,pitch=%P" :
%L -> Length of helical rebar
%L -> Longueur de l'armature hélicoïdale
%R -> Helix radius of helical rebar
%R -> Rayon d'hélice de l'armature hélicoïdale
%P -> Helix pitch of helical rebar
%P -> Pas d'hélice de l'armature hélicoïdale
* {{incode|scale}} specifies the scale value to scale rebar svg. The scale parameter helps to scale down rebar_stroke_width and dimension_font_size to make them resolution independent. If max_height or max_width is set to non-zero value, then scale parameter will be ignored.
* {{incode|scale}} spécifie la valeur d'échelle pour mettre à l'échelle le SVG d'armature. Le paramètre d'échelle aide à réduire rebar_stroke_width et dimension_font_size pour les rendre indépendants de la résolution. Si max_height ou max_width est défini sur une valeur différente de zéro, le paramètre d'échelle sera ignoré.
* {{incode|max_height}} specifies the maximum height of rebar shape svg. Set it to 0 to have rebar shape svg height based on scale parameter.
* {{incode|max_height}} spécifie la hauteur maximale du SVG de forme d'armature. Définissez-le sur 0 pour avoir une hauteur de SVG de forme d'armature basée sur le paramètre d'échelle.
* {{incode|max_width}} specifies the maximum width of rebar shape svg. Set it to 0 to have rebar shape svg width based on scale parameter.
* {{incode|max_width}} spécifie la largeur maximale du SVG de forme d'armature. Définissez-le sur 0 pour avoir une largeur de SVG de forme d'armature basée sur le paramètre d'échelle.
* {{incode|side_padding}} specifies the padding on each side of rebar shape.
* {{incode|side_padding}} spécifie le rembourrage de chaque côté de la forme de l'armature.
* {{incode|horizontal_shape}} specifies if rebar shape is to be made horizontal by rotating max length edge of rebar shape.
* {{incode|horizontal_shape}} spécifie si la forme d'armature doit être rendue horizontale en faisant pivoter le bord de longueur maximale de la forme d'armature.


==== Example ====
==== Exemple ====


{{Code|code=
{{Code|code=
Line 178: Line 178:
}}
}}


=== Create Rebar Shape Cut List SVG ===
=== Créer la nomenclature de façonnage d'armatures en SVG ===


{{Code|code=
{{Code|code=
Line 212: Line 212:
}}
}}


* Generate and return rebar shape cut list svg element for given {{incode|base_rebars_list}}.
* Génère et renvoie un élément SVG de liste de coupe de forme d'armature pour {{incode|base_rebars_list}}.
* {{incode|base_rebars_list}} is a list of <ArchRebar._Rebar> or <rebar2.BaseRebar> objects, to generate their RebarShape cut list. If not provided, then all ArchRebars and rebar2.BaseRebar objects with unique Mark from ActiveDocument will be selected and rebars with no Mark assigned will be ignored.
* {{incode|base_rebars_list}} est une liste d'objets <ArchRebar._Rebar> ou <rebar2.BaseRebar>, pour générer leur liste de coupe RebarShape. S'il n'est pas fourni, tous les objets ArchRebars et rebar2.BaseRebar avec une marque unique d'ActiveDocument seront sélectionnés et les armatures sans marque attribuée seront ignorées.
* {{incode|view_directions}} is a list of view point directions for each rebar shape. It can be either of type {{incode|FreeCAD.Vector}} or {{incode|WorkingPlane.Plane}} OR their list. Keep it {{incode|FreeCAD.Vector(0, 0, 0)}} to automatically choose view_directions.
* {{incode|view_directions}} est une liste de directions de viewpoint pour chaque forme d'armature. Il peut être de type {{incode|FreeCAD.Vector}} ou {{incode|WorkingPlane.Plane}} OU leur liste. Gardez-le {{incode|FreeCAD.Vector(0, 0, 0)}} pour choisir automatiquement view_directions.
* {{incode|include_mark}} specifies if rebar.Mark is to be included for each rebar shape in rebar shape cut list svg or not.
* {{incode|include_mark}} spécifie si rebar.Mark doit être inclus pour chaque forme d'armature dans la liste de coupe de forme d'armature SVG ou non.
* {{incode|stirrup_extended_edge_offset}} specifies the offset of extended end edges of stirrup, so that end edges of stirrup with 90 degree bent angle do not overlap with stirrup edges.
* {{incode|stirrup_extended_edge_offset}} spécifie le décalage des bords d'extrémité étendus de l'étrier, de sorte que les bords d'extrémité de l'étrier avec un angle plié à 90 degrés ne se chevauchent pas avec les bords de l'étrier.
* {{incode|rebars_stroke_width}} specifies the stroke-width of rebars in rebar shape cut list svg.
* {{incode|rebars_stroke_width}} spécifie la largeur de trait des armatures en SVG de liste de coupe de forme d'armature.
* {{incode|rebars_color_style}} specifies the color style of rebars. It can be "shape color" or "color_name or hex_value_of_color". "shape color" means select color of rebar shape.
* {{incode|rebars_color_style}} spécifie le style de couleur des armatures. Il peut s'agir de "shape color" ou "color_name ou hex_value_of_color". "shape color" signifie sélectionner la couleur de la forme de l'armature.
* {{incode|include_dimensions}} specifies if each rebar edge dimensions and bent angle dimensions is to be included in rebar shape cut list.
* {{incode|include_dimensions}} spécifie si les dimensions de chaque arête d'armature et les cotes d'angle plié doivent être incluses dans la liste de coupe des formes d'armature.
* {{incode|rebar_edge_dimension_units}} specifies the units to be used for rebar edge length dimensions.
* {{incode|rebar_edge_dimension_units}} spécifie les unités à utiliser pour les dimensions de longueur d'arête d'armature.
* {{incode|rebar_edge_dimension_precision}} specifies the number of decimals that should be shown for rebar length as dimension label. Set it to None to use user preferred unit precision from FreeCAD unit preferences.
* {{incode|rebar_edge_dimension_precision}} spécifie le nombre de décimales à afficher pour la longueur de l'armature comme étiquette de dimension. Définissez-le sur Aucun pour utiliser la précision d'unité préférée de l'utilisateur dans les préférences d'unité de FreeCAD.
* {{incode|include_units_in_dimension_label}} specifies if rebars edge length units is to be shown in dimension label.
* {{incode|include_units_in_dimension_label}} spécifie si les unités de longueur d'arête des armatures doivent être affichées dans l'étiquette de dimension.
* {{incode|bent_angle_dimension_exclude_list}} specifies the list of bent angles to not include their dimensions.
* {{incode|bent_angle_dimension_exclude_list}} spécifie la liste des angles pliés pour ne pas inclure leurs dimensions.
* {{incode|dimension_font_family}} specifies the font-family of dimension text.
* {{incode|dimension_font_family}} spécifie la famille de polices du texte de cote.
* {{incode|dimension_font_size}} specifies the font-size of dimension text.
* {{incode|dimension_font_size}} spécifie la taille de la police du texte de cote.
* {{incode|helical_rebar_dimension_label_format}} specifies the format of helical rebar dimension label. E.g. "%L,r=%R,pitch=%P" where:
* {{incode|helical_rebar_dimension_label_format}} spécifie le format de l'étiquette de dimension d'armature hélicoïdale. Par exemple. "%L,r=%R,pitch=%P" :
%L -> Length of helical rebar
%L -> Longueur de l'armature hélicoïdale
%R -> Helix radius of helical rebar
%R -> Rayon d'hélice de l'armature hélicoïdale
%P -> Helix pitch of helical rebar
%P -> Pas d'hélice de l'armature hélicoïdale
* {{incode|row_height}} specifies the height of each row of rebar shape in rebar shape cut list.
* {{incode|row_height}} spécifie la hauteur de chaque ligne de forme d'armature dans la liste de coupe de forme d'armature.
* {{incode|column_width}} specifies the width of each row of rebar shape in rebar shape cut list.
* {{incode|column_width}} spécifie la largeur de chaque ligne de forme d'armature dans la liste de coupe de forme d'armature.
* {{incode|column_count}} specifies the number of columns in rebar shape cut list. Set it to "row_count" to have column_count <= row_count
* {{incode|column_count}} spécifie le nombre de colonnes dans la liste de coupe de forme d'armature. Définissez-le sur "row_count" pour avoir column_count <= row_count
* {{incode|side_padding}} specifies the padding on each side of rebar shape in rebar shape cut list.
* {{incode|side_padding}} spécifie le remplissage de chaque côté de la forme d'armature dans la liste de coupe de forme d'armature.
* {{incode|horizontal_rebar_shape}} specifies if rebar shape is to be made horizontal by rotating max length edge of rebar shape.
* {{incode|horizontal_rebar_shape}} spécifie si la forme de l'armature doit être rendue horizontale en faisant pivoter le bord de longueur maximale de la forme de l'armature.
* {{incode|output_file}} specifies the output file to write generated rebar shape cut list svg.
* {{incode|output_file}} spécifie le fichier de sortie pour écrire le SVG de la liste de coupe de forme d'armature générée.


==== Example ====
==== Exemple ====


{{Code|code=
{{Code|code=
Line 255: Line 255:
FreeCAD.ActiveDocument.recompute()
FreeCAD.ActiveDocument.recompute()


# Créer des barres d'armature droites
# Create Straight Rebars
rebar_group = SingleTie.makeSingleTieFourRebars(
rebar_group = SingleTie.makeSingleTieFourRebars(
l_cover_of_tie=40,
l_cover_of_tie=40,
Line 279: Line 279:
).rebar_group
).rebar_group


# Assign Mark to straight rebars
# Attribuer Mark aux armatures droites
for straight_rebar in rebar_group.RebarGroups[1].MainRebars:
for straight_rebar in rebar_group.RebarGroups[1].MainRebars:
straight_rebar.Mark = "main_sb"
straight_rebar.Mark = "main_sb"




# Créer armatures en forme de L avec le crochet dirigé le long de l'axe des x.
# Create LShaped Rebars with hook along x-axis
rebar_group = SingleTie.makeSingleTieFourRebars(
rebar_group = SingleTie.makeSingleTieFourRebars(
l_cover_of_tie=40,
l_cover_of_tie=40,
Line 308: Line 308:
).rebar_group
).rebar_group


# Assign Mark to lshape rebars
# Attribuer Mark aux armatures en L
for lshape_rebar in rebar_group.RebarGroups[1].MainRebars:
for lshape_rebar in rebar_group.RebarGroups[1].MainRebars:
lshape_rebar.Mark = "main_lb"
lshape_rebar.Mark = "main_lb"
Line 314: Line 314:
output_file = str(Path.home() / "RebarShapeCutList.svg")
output_file = str(Path.home() / "RebarShapeCutList.svg")


# Créer une nomenclature de façonnage des armatures pour toutes les armatures de base du modèle
# Create Rebar Shape Cut List for all base rebars in model
RebarShapeCutListfunc.getRebarShapeCutList(
RebarShapeCutListfunc.getRebarShapeCutList(
base_rebars_list=None,
base_rebars_list=None,

Revision as of 14:01, 28 September 2020

Reinforcement Nomenclature de façonnage des armatures

Emplacement du menu
Reinforcement → Rebar Shape Cut List
Ateliers
Arch, BIM
Raccourci par défaut
Aucun
Introduit dans la version
0.19
Voir aussi
Reinforcement, Arch Rebar Dimensions dessins, Arch Rebar Nomenclature

Description

L'outil Rebar Shape Cut List permet à l'utilisateur de créer une nomenclature de façonnage des armatures.

Cette commande fait partie de l'Atelier Reinforcement, un Atelier externe qui peut être installé avec le Gestionnaire d'Addon via le menu Outils → Gestionnaire d'Addon → Reinforcement.

Nomenclature de façonnage d'armatures

Utilisation

1. Sélectionnez les objets Arch Armatures et Rebar2 que vous souhaitez inclure dans la nomenclature de façonnage des armatures ou sélectionnez les objets Arch Structure à inclure aux Arch Armatures et les objets Rebar2 hébergés par celui-ci dans la nomenclature de façonnage des armatures. Si rien n'est sélectionné, la nomenclature de façonnage des armatures sera générée pour tous les objets Arch Armatures et Rebar2 présents dans le modèle.

2. Sélectionnez ensuite Rebar Shape Cut List dans les outils d'armature.

3. Une boîte de dialogue apparaîtra à l'écran, comme indiqué ci-dessous.

Boîte de dialogue de l'outil Nomenclature de façonnage des armatures

4. Modifiez les données en fonction de vos besoins.

7. Cliquez sur OK ou Apply pour générer la Nomenclature de façonnage des armatures.

6. Cliquez sur Cancel pour quitter la boîte de dialogue.

Propriétés

Général:

  • DonnéesStirrup Extended Edge Offset: Le décalage des bords d'extrémité étendus de l'étrier, de sorte que les bords d'extrémité de l'étrier avec un angle de pliage de 90 degrés ne se chevauchent pas avec les bords de l'étrier.
  • DonnéesRebars Stroke Width: La largeur de trait des armatures dans la nomenclature de façonnage.
  • DonnéesRebars Color Style: Le style de couleur des armatures.
  • DonnéesRow Height: La hauteur de chaque ligne de forme d'armature dans la nomenclature de façonnage.
  • DonnéesColumn Width: La largeur de chaque colonne de forme d'armature dans la nomenclature de façonnage.
  • DonnéesColumn Count: Le nombre de colonnes dans la nomenclature de façonnage.
  • DonnéesSide Padding: Le rembourrage de chaque côté de la forme de l'armature.
  • DonnéesHorizontal Rebar Shape: Si True, alors la forme de l'armature sera rendue horizontale en faisant pivoter le bord de longueur maximale de la forme d'armature.
  • DonnéesInclude Mark: si elle est définie sur True, alors rebar.Mark sera inclus pour chaque forme d'armature dans la nomenclature de façonnage.
  • DonnéesSVG Output File: Le fichier de sortie pour écrire le SVG de la nomenclature de façonnage.

Données de dimension:

  • DonnéesInclude Dimensions: Si True, les dimensions de chaque arête d'armature et les cotes d'angle plié seront incluses dans la nomenclature de façonnage.
  • DonnéesInclude Units in Dimension Label: Si la valeur est True, les unités de longueur de bord d'armature seront affichées dans l'étiquette de dimension.
  • DonnéesRebar Edge Dimension Units: Les unités à utiliser pour les dimensions de longueur de bord d'armature.
  • DonnéesRebar Edge Dimension Precision: Le nombre de décimales à afficher pour la longueur du bord de l'armature comme étiquette de cote.
  • DonnéesDimension Font Family: La famille de polices du texte de dimension.
  • DonnéesDimension Police Size: La taille de la police du texte de dimension.
  • DonnéesBent Angle Dimension Exclude List: La liste des angles pliés pour ne pas inclure leurs dimensions.
  • DonnéesHelical Rebar Dimension Label Format: Le format de l'étiquette de dimension d'armature hélicoïdale. Par exemple: "%L,r=%R,pitch=%P" où %L -> Longueur de l'armature hélicoïdale, %R -> Rayon d'hélice de l'armature hélicoïdale, %P -> Pas d'hélice de l'armature hélicoïdale.

Script

Voir aussi: Arch API, API de renforts et FreeCAD Scripts de Base.

L'outil Nomenclature de façonnage des armatures peut être utilisé dans des macros et à partir de la console Python à l'aide des fonctions suivantes:

Créer la forme d'une armature en SVG

getRebarShapeSVG(
    rebar,
    view_direction: Union[FreeCAD.Vector, WorkingPlane.Plane] = FreeCAD.Vector(0, 0, 0),
    include_mark: bool = True,
    stirrup_extended_edge_offset: float = 2,
    rebar_stroke_width: float = 0.35,
    rebar_color_style: str = "shape color",
    include_dimensions: bool = True,
    rebar_dimension_units: str = "mm",
    rebar_length_dimension_precision: int = 0,
    include_units_in_dimension_label: bool = False,
    bent_angle_dimension_exclude_list: Tuple[float, ...] = (45, 90, 180),
    dimension_font_family: str = "DejaVu Sans",
    dimension_font_size: float = 2,
    helical_rebar_dimension_label_format: str = "%L,r=%R,pitch=%P",
    scale: float = 1,
    max_height: float = 0,
    max_width: float = 0,
    side_padding: float = 1,
    horizontal_shape: bool = False,
) -> ElementTree.Element
  • Génère et renvoie un élément SVG de forme d'armature pour un objet rebar donné.
  • L'objet rebar peut être de type <ArchRebar._Rebar> ou <rebar2.BaseRebar>, pour générer sa forme SVG.
  • view_direction spécifie la direction du viewpoint pour la forme de l'armature. Il peut être de type FreeCAD.Vector ou WorkingPlane.Plane bien que WorkingPlane.Plane soit préféré.
  • include_mark spécifie si rebar.Mark doit être inclus dans le SVG de forme d'armature ou non.
  • stirrup_extended_edge_offset est le décalage des bords d'extrémité étendus de l'étrier, de sorte que les bords d'extrémité de l'étrier avec un angle plié à 90 degrés ne se chevauchent pas avec les bords de l'étrier.
  • rebar_stroke_width spécifie la largeur de trait de l'armature en SVG.
  • rebar_color_style spécifie le style de couleur de l'armature. Il peut s'agir de "couleur de forme" ou "nom_couleur ou valeur_hexique_de_couleur". "couleur de forme" signifie sélectionner la couleur de la forme de l'armature.
  • include_dimensions spécifie si chaque dimension d'arête d'armature et les dimensions d'angle plié doivent être incluses dans le SVG de forme d'armature.
  • rebar_dimension_units spécifie les unités à utiliser pour les dimensions de longueur d'armature.
  • rebar_length_dimension_precision spécifie le nombre de décimales à afficher pour la longueur de l'armature en tant qu'étiquette de dimension. Définissez-le sur Aucun pour utiliser la précision d'unité préférée de l'utilisateur dans les préférences d'unité de FreeCAD.
  • include_units_in_dimension_label spécifie si les unités de longueur d'armature doivent être affichées dans l'étiquette de dimension.
  • bent_angle_dimension_exclude_list spécifie la liste des angles pliés pour ne pas inclure leurs dimensions.
  • dimension_font_family spécifie la famille de polices du texte de cote.
  • dimension_font_size spécifie la taille de la police du texte de cote.
  • helical_rebar_dimension_label_format spécifie le format de l'étiquette de dimension d'armature hélicoïdale. Par exemple. "%L,r=%R,pitch=%P" où:
   %L -> Longueur de l'armature hélicoïdale
   %R -> Rayon d'hélice de l'armature hélicoïdale
   %P -> Pas d'hélice de l'armature hélicoïdale
  • scale spécifie la valeur d'échelle pour mettre à l'échelle le SVG d'armature. Le paramètre d'échelle aide à réduire rebar_stroke_width et dimension_font_size pour les rendre indépendants de la résolution. Si max_height ou max_width est défini sur une valeur différente de zéro, le paramètre d'échelle sera ignoré.
  • max_height spécifie la hauteur maximale du SVG de forme d'armature. Définissez-le sur 0 pour avoir une hauteur de SVG de forme d'armature basée sur le paramètre d'échelle.
  • max_width spécifie la largeur maximale du SVG de forme d'armature. Définissez-le sur 0 pour avoir une largeur de SVG de forme d'armature basée sur le paramètre d'échelle.
  • side_padding spécifie le rembourrage de chaque côté de la forme de l'armature.
  • horizontal_shape spécifie si la forme d'armature doit être rendue horizontale en faisant pivoter le bord de longueur maximale de la forme d'armature.

Exemple

from pathlib import Path
from xml.dom import minidom
from xml.etree import ElementTree

import Draft, Arch, Stirrup
from RebarShapeCutList import RebarShapeCutListfunc

Rect = Draft.makeRectangle(400, 400)
Structure = Arch.makeStructure(Rect, height=1600)
Structure.ViewObject.Transparency = 80
FreeCAD.ActiveDocument.recompute()

Rebar = Stirrup.makeStirrup(
    20, 20, 20, 20, 20, 90, 4, 8, 2, True, 10, Structure, "Face6"
)

rebar_shape_svg = RebarShapeCutListfunc.getRebarShapeSVG(
    Rebar,
    view_direction=FreeCAD.Vector(0, 0, 0),
    include_mark=True,
    stirrup_extended_edge_offset=2,
    rebar_stroke_width=0.35,
    rebar_color_style="shape color",
    include_dimensions=True,
    rebar_dimension_units="mm",
    rebar_length_dimension_precision=0,
    include_units_in_dimension_label=True,
    bent_angle_dimension_exclude_list=(45, 90, 180),
    dimension_font_family="DejaVu Sans",
    dimension_font_size=2,
    helical_rebar_dimension_label_format="%L,r=%R,pitch=%P",
    scale=1,
    max_height=100,
    max_width=100,
    side_padding=1,
    horizontal_shape=False,
)

output_file = str(Path.home() / "StirrupRebarShape.svg")
with open(output_file, "w", encoding="utf-8") as f:
    f.write(
        minidom.parseString(
            ElementTree.tostring(rebar_shape_svg, encoding="unicode")
        ).toprettyxml(indent="  ")
    )

Créer la nomenclature de façonnage d'armatures en SVG

getRebarShapeCutList(
    base_rebars_list: Optional[List] = None,
    view_directions: Union[
        Union[FreeCAD.Vector, WorkingPlane.Plane],
        List[Union[FreeCAD.Vector, WorkingPlane.Plane]],
    ] = FreeCAD.Vector(0, 0, 0),
    include_mark: bool = True,
    stirrup_extended_edge_offset: float = 2,
    rebars_stroke_width: float = 0.35,
    rebars_color_style: str = "shape color",
    include_dimensions: bool = True,
    rebar_edge_dimension_units: str = "mm",
    rebar_edge_dimension_precision: int = 0,
    include_units_in_dimension_label: bool = False,
    bent_angle_dimension_exclude_list: Union[Tuple[float, ...], List[float]] = (
        45,
        90,
        180,
    ),
    dimension_font_family: str = "DejaVu Sans",
    dimension_font_size: float = 2,
    helical_rebar_dimension_label_format: str = "%L,r=%R,pitch=%P",
    row_height: float = 40,
    column_width: float = 60,
    column_count: Union[int, Literal["row_count"]] = "row_count",
    side_padding: float = 1,
    horizontal_rebar_shape: bool = True,
    output_file: Optional[str] = None,
) -> ElementTree.Element
  • Génère et renvoie un élément SVG de liste de coupe de forme d'armature pour base_rebars_list.
  • base_rebars_list est une liste d'objets <ArchRebar._Rebar> ou <rebar2.BaseRebar>, pour générer leur liste de coupe RebarShape. S'il n'est pas fourni, tous les objets ArchRebars et rebar2.BaseRebar avec une marque unique d'ActiveDocument seront sélectionnés et les armatures sans marque attribuée seront ignorées.
  • view_directions est une liste de directions de viewpoint pour chaque forme d'armature. Il peut être de type FreeCAD.Vector ou WorkingPlane.Plane OU leur liste. Gardez-le FreeCAD.Vector(0, 0, 0) pour choisir automatiquement view_directions.
  • include_mark spécifie si rebar.Mark doit être inclus pour chaque forme d'armature dans la liste de coupe de forme d'armature SVG ou non.
  • stirrup_extended_edge_offset spécifie le décalage des bords d'extrémité étendus de l'étrier, de sorte que les bords d'extrémité de l'étrier avec un angle plié à 90 degrés ne se chevauchent pas avec les bords de l'étrier.
  • rebars_stroke_width spécifie la largeur de trait des armatures en SVG de liste de coupe de forme d'armature.
  • rebars_color_style spécifie le style de couleur des armatures. Il peut s'agir de "shape color" ou "color_name ou hex_value_of_color". "shape color" signifie sélectionner la couleur de la forme de l'armature.
  • include_dimensions spécifie si les dimensions de chaque arête d'armature et les cotes d'angle plié doivent être incluses dans la liste de coupe des formes d'armature.
  • rebar_edge_dimension_units spécifie les unités à utiliser pour les dimensions de longueur d'arête d'armature.
  • rebar_edge_dimension_precision spécifie le nombre de décimales à afficher pour la longueur de l'armature comme étiquette de dimension. Définissez-le sur Aucun pour utiliser la précision d'unité préférée de l'utilisateur dans les préférences d'unité de FreeCAD.
  • include_units_in_dimension_label spécifie si les unités de longueur d'arête des armatures doivent être affichées dans l'étiquette de dimension.
  • bent_angle_dimension_exclude_list spécifie la liste des angles pliés pour ne pas inclure leurs dimensions.
  • dimension_font_family spécifie la famille de polices du texte de cote.
  • dimension_font_size spécifie la taille de la police du texte de cote.
  • helical_rebar_dimension_label_format spécifie le format de l'étiquette de dimension d'armature hélicoïdale. Par exemple. "%L,r=%R,pitch=%P" où:
   %L -> Longueur de l'armature hélicoïdale
   %R -> Rayon d'hélice de l'armature hélicoïdale
   %P -> Pas d'hélice de l'armature hélicoïdale
  • row_height spécifie la hauteur de chaque ligne de forme d'armature dans la liste de coupe de forme d'armature.
  • column_width spécifie la largeur de chaque ligne de forme d'armature dans la liste de coupe de forme d'armature.
  • column_count spécifie le nombre de colonnes dans la liste de coupe de forme d'armature. Définissez-le sur "row_count" pour avoir column_count <= row_count
  • side_padding spécifie le remplissage de chaque côté de la forme d'armature dans la liste de coupe de forme d'armature.
  • horizontal_rebar_shape spécifie si la forme de l'armature doit être rendue horizontale en faisant pivoter le bord de longueur maximale de la forme de l'armature.
  • output_file spécifie le fichier de sortie pour écrire le SVG de la liste de coupe de forme d'armature générée.

Exemple

from pathlib import Path

import FreeCAD, Draft, Arch
from ColumnReinforcement import SingleTie
from RebarShapeCutList import RebarShapeCutListfunc

Rect1 = Draft.makeRectangle(400, 400)
Structure1 = Arch.makeStructure(Rect1, height=1600)
Structure1.ViewObject.Transparency = 80
Rect2 = Draft.makeRectangle(500, 500)
Structure2 = Arch.makeStructure(Rect2, height=1600)
Structure2.ViewObject.Transparency = 80
Structure2.Placement = FreeCAD.Placement(FreeCAD.Vector(1000, 0, 0), FreeCAD.Rotation(FreeCAD.Vector(0, 0, 1), 0))
FreeCAD.ActiveDocument.recompute()

# Créer des barres d'armature droites
rebar_group = SingleTie.makeSingleTieFourRebars(
    l_cover_of_tie=40,        
    r_cover_of_tie=40,
    t_cover_of_tie=40,
    b_cover_of_tie=40,
    offset_of_tie=100,
    bent_angle=135,
    extension_factor=8,
    dia_of_tie=8,
    number_spacing_check=True,
    number_spacing_value=10,
    dia_of_rebars=16,
    t_offset_of_rebars=40,
    b_offset_of_rebars=40,
    rebar_type="StraightRebar",
    hook_orientation="Top Inside",
    hook_extend_along="x-axis",
    l_rebar_rounding=None,
    hook_extension=None,
    structure=Structure1,
    facename="Face6",
).rebar_group

# Attribuer Mark aux armatures droites
for straight_rebar in rebar_group.RebarGroups[1].MainRebars:
    straight_rebar.Mark = "main_sb"


# Créer armatures en forme de L avec le crochet dirigé le long de l'axe des x.
rebar_group = SingleTie.makeSingleTieFourRebars(
    l_cover_of_tie=40,
    r_cover_of_tie=40,
    t_cover_of_tie=40,
    b_cover_of_tie=40,
    offset_of_tie=100,
    bent_angle=90,
    extension_factor=8,
    dia_of_tie=8,
    number_spacing_check=True,
    number_spacing_value=10,
    dia_of_rebars=16,
    t_offset_of_rebars=-40,
    b_offset_of_rebars=-40,
    rebar_type="LShapeRebar",
    hook_orientation="Top Outside",
    hook_extend_along="x-axis",
    l_rebar_rounding=2,
    hook_extension=100,
    structure=Structure2,
    facename="Face6",
).rebar_group

# Attribuer Mark aux armatures en L
for lshape_rebar in rebar_group.RebarGroups[1].MainRebars:
    lshape_rebar.Mark = "main_lb"

output_file = str(Path.home() / "RebarShapeCutList.svg")

# Créer une nomenclature de façonnage des armatures pour toutes les armatures de base du modèle
RebarShapeCutListfunc.getRebarShapeCutList(
    base_rebars_list=None,
    view_directions=FreeCAD.Vector(0, 0, 0),
    include_mark=True,
    stirrup_extended_edge_offset=2,
    rebars_stroke_width=0.35,
    rebars_color_style="shape color",
    include_dimensions=True,
    rebar_edge_dimension_units="mm",
    rebar_edge_dimension_precision=0,
    include_units_in_dimension_label=False,
    bent_angle_dimension_exclude_list=(45, 90, 180),
    dimension_font_family="DejaVu Sans",
    dimension_font_size=2,
    helical_rebar_dimension_label_format="%L,r=%R,pitch=%P",
    row_height=40,
    column_width=60,
    column_count="row_count",
    side_padding=1,
    horizontal_rebar_shape=True,
    output_file=output_file,
)