Reinforcement BarBendingSchedule/fr: Difference between revisions

From FreeCAD Documentation
(Created page with "Cette commande fait partie de l'atelier Reinforcement, un atelier externe qui peut être installé avec Image:Addo...")
No edit summary
(38 intermediate revisions by 3 users not shown)
Line 6: Line 6:
|[[Reinforcement_Workbench/fr|Atelier Reinforcement]]
|[[Reinforcement_Workbench/fr|Atelier Reinforcement]]
|IconL=Reinforcement_Bar_Shape_Cut_List.svg
|IconL=Reinforcement_Bar_Shape_Cut_List.svg
|IconC=Reinforcement_Workbench.svg
|IconR=Arch_Rebar_Drawing_Dimensioning.svg
|IconR=Arch_Rebar_Drawing_Dimensioning.svg
|IconC=Reinforcement_Workbench.svg
}}
}}


Line 15: Line 15:
|MenuLocation=Reinforcement → Bar Bending Schedule
|MenuLocation=Reinforcement → Bar Bending Schedule
|Workbenches=[[Arch_Workbench/fr|Arch]], [[BIM_Workbench/fr|BIM]]
|Workbenches=[[Arch_Workbench/fr|Arch]], [[BIM_Workbench/fr|BIM]]
|SeeAlso=[[Reinforcement_Workbench/fr|Reinforcement]], [[Arch_Rebar_BOM/fr|Arch Rebar Nomenclature]], [[Arch_Rebar_Drawing_Dimensioning/fr|Arch Rebar Dessins]]
|Version=0.19
|Version=0.19
|SeeAlso=[[Reinforcement_Workbench/fr|Reinforcement]], [[Arch_Rebar_BOM/fr|Arch Rebar Nomenclature]], [[Arch_Rebar_Drawing_Dimensioning/fr|Arch Rebar Dessins]]
}}
}}


Line 27: Line 27:
[[Image:Reinforcement_Bar_Bending_Schedule_example.svg|1300px]]
[[Image:Reinforcement_Bar_Bending_Schedule_example.svg|1300px]]


{{Caption|Bar Bending Schedule of reinforcing bars}}
{{Caption|Tableau des armatures}}


==Usage==
==Utilisation==


1. Select {{Button|[[Image:Arch_Rebar.svg|16px]] [[Arch Rebar|Arch Rebar]]}} and Rebar2 objects you want to include in Bar Bending Schedule. Or select {{Button|[[Image:Arch_Structure.svg|16px]] [[Arch Structure|Arch Structure]]}} objects to include {{Button|[[Image:Arch_Rebar.svg|16px]] [[Arch Rebar|Arch Rebar]]}} and Rebar2 objects hosted by that into Bar Bending Schedule. If nothing is selected, then Bar Bending Schedule will be generated for all {{Button|[[Image:Arch_Rebar.svg|16px]] [[Arch Rebar|Arch Rebar]]}} and Rebar2 objects present in the model.
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_Bending_Schedule.svg|16px]] [[Reinforcement Bar Bending Schedule|Bar Bending Schedule]]}} from the rebar tools.
2. Sélectionnez ensuite {{Button|[[Image:Reinforcement_Bar_Bending_Schedule.svg|16px]] [[Reinforcement Bar Bending Schedule/fr|Bar Bending Schedule]]}} 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 the screen as shown below.


[[Image:Reinforcement_Bar_Bending_Schedule_Dialog.png]]
[[Image:Reinforcement_Bar_Bending_Schedule_Dialog.png]]


{{Caption|Dialog Box for the Reinforcement Bar Bending Schedule tool}}
{{Caption|Boîte de dialogue de l'outil Reinforcement Bar Bending Schedule}}


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 Bar Bending Schedule for rebars.
7. Cliquez sur {{Button|OK}} ou {{Button|Apply}} pour générer un Tableau d'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|Reinforcement Group By}}: Reinforcement Group By specifies how reinforcement objects should be grouped in Bar Bending Schedule i.e. "Host" or "Mark".
* {{PropertyData/fr|Reinforcement Group By}} : spécifie comment les objets armatures doivent être regroupés dans le Tableau des armatures, c'est-à-dire "Host" ou "Mark".
* {{PropertyData|Rebar Length Type}}: Rebar Length Type specifies the type of rebar length used for BOM calculations i.e. "RealLength" or "LengthWithSharpEdges".
* {{PropertyData/fr|Rebar Length Type}} : type de longueur d'armature spécifie le type de longueur d'armature utilisé pour les calculs de nomenclature, c'est-à-dire "RealLength" ou "LengthWithSharpEdges".
* {{PropertyData|Column Headers}}: A dictionary with column_data as key and tuple (column_display_header, column_sequence) as value.
* {{PropertyData/fr|Column Headers}} : dictionnaire avec column_data comme clé et tuple (column_display_header, column_sequence) comme valeur.
* {{PropertyData|Column Units}}: A dictionary with keys: "Diameter", "RebarLength", "RebarsTotalLength" and their corresponding units as value.
* {{PropertyData/fr|Column Units}} : dictionnaire avec les clés: "Diameter", "RebarLength", "RebarsTotalLength" et leurs unités correspondantes comme valeur.
* {{PropertyData|Font Family}}: Font Family of text in Bar Bending Schedule SVG.
* {{PropertyData/fr|Font Family}} : famille de polices de texte dans Bar Bending Schedule SVG.
* {{PropertyData|Font Size}}: Font size in mm.
* {{PropertyData/fr|Font Size}} : taille de la police en mm.
* {{PropertyData|Column Width}}: Width of each column in Bar Bending Schedule SVG.
* {{PropertyData/fr|Column Width}} : largeur de chaque colonne dans Bar Bending Schedule SVG.
* {{PropertyData|Row Height}}: Height of each row in Bar Bending Schedule SVG.
* {{PropertyData/fr|Row Height}} : hauteur de chaque ligne dans Bar Bending Schedule SVG.
* {{PropertyData|SVG Output File}}: The output file to write generated rebar shape cut list SVG.
* {{PropertyData/fr|SVG Output File}} : fichier de sortie pour écrire la Nomenclature de façonnage des armatures SVG.


'''Rebar Shape column data:''' The data related to the Rebar Shape column in Bar Bending Schedule
'''Rebar Shape column data :''' données relatives à la colonne forme d'armature dans le Tableau des armatures
* {{PropertyData|Column Header}}: The column header for the rebar shape column.
* {{PropertyData/fr|Column Header}} : en-tête de colonne de la colonne de forme d'armature.
* {{PropertyData|Stirrup Extended Edge Offset}}: The offset of extended end edges of the stirrup, so that end edges of the stirrup with a 90-degree bent angle do not overlap with stirrup edges.
* {{PropertyData/fr|Stirrup Extended Edge Offset}} : 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.
* {{PropertyData|Rebars Stroke Width}}: The stroke-width of rebars in the rebar shape column.
* {{PropertyData/fr|Rebars Stroke Width}} : largeur de trait des armatures dans la colonne de forme d'armature.
* {{PropertyData|Rebars Color Style}}: The color style of rebars.
* {{PropertyData/fr|Rebars Color Style}} : style de couleur des armatures.


'''Rebar Shape Column Dimension Data:''' The data related to rebar shape dimensions in the Rebar Shape column
'''Rebar Shape Column Dimension Data :''' données relatives aux dimensions de forme d'armature dans la colonne Forme d'armature
* {{PropertyData|Include Dimensions}}: If True, then each rebar edge dimensions and bent angle dimensions will be included in the rebar shape cut list.
* {{PropertyData/fr|Include Dimensions}} : si True, les dimensions de chaque bord d'armature et les dimensions d'angle plié seront incluses dans le Tableau des armatures.
* {{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}} : 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 a dimension label.
* {{PropertyData/fr|Rebar Edge Dimension Precision}} : nombre de décimales à afficher pour la longueur du bord de l'armature sous forme d'étiquette de cote.
* {{PropertyData|Dimension Font Family}}: The font-family of dimension text.
* {{PropertyData/fr|Dimension Font Family}} : famille de polices du texte de dimension.
* {{PropertyData|Dimension Font Size}}: The font-size of dimension text.
* {{PropertyData/fr|Dimension Police Size}} : 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}} : liste des angles pliés pour ne pas inclure leurs dimensions.
* {{PropertyData|Helical Rebar Dimension Label Format}}: The format of the 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}} : 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ïde


==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|Reinforcement API]] et [[FreeCAD Scripting Basics/fr|FreeCAD Scripts de bases]].


The [[Reinforcement Bar Bending Schedule|Bar Bending Schedule]] tool can be used in [[macros|macros]] and from the [[Python|Python]] console by using the following function:
L'outil [[Reinforcement Bar Bending Schedule/fr|Bar Bending Schedule]] peut être utilisé dans des [[macros/fr|macros]] et à partir de la console [[Python/fr|Python]] à l'aide des fonctions suivantes :


=== Create Bar Bending Schedule ===
===Créer un Tableau d'armatures ===


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


* Generates and returns a bar bending schedule SVG element for given {{incode|rebar_objects}}.
* Génère et renvoie un élément SVG du Tableau des armatures pour un {{incode|rebar_objects}}.
* {{incode|rebar_objects}} is a list of <ArchRebar._Rebar> or <rebar2.BaseRebar> objects, to generate their bar bending schedule. If not provided, then all ArchRebars and rebar2.BaseRebar objects with unique Mark from ActiveDocument will be selected.
* {{incode|rebar_objects}} est une liste d'objets <ArchRebar._Rebar> ou <rebar2.BaseRebar>, pour générer le tableau. S'il n'est pas fourni, tous les objets ArchRebars et rebar2.BaseRebar avec une marque unique d'ActiveDocument seront sélectionnés.
* {{incode|column_headers}} is a dictionary with keys: "Host", "Mark", "RebarsCount", "Diameter", "RebarLength", "RebarsTotalLength" and values are tuple of column_header and their sequence number.
* {{incode|column_headers}} est un dictionnaire avec les clés: "Host", "Mark", "RebarsCount", "Diameter", "RebarLength", "RebarsTotalLength" et les valeurs sont un tuple de column_header et leur numéro de séquence.
Example: {
Exemple : {
"Host": ("Member", 1),
"Host": ("Member", 1),
"Mark": ("Mark", 2),
"Mark": ("Mark", 2),
Line 130: Line 130:
"RebarsTotalLength": ("Total Length in m", 6),
"RebarsTotalLength": ("Total Length in m", 6),
}
}
set column sequence number to 0 to hide column.
mettez le numéro de séquence de la colonne sur 0 pour masquer la colonne.
* {{incode|column_units}} is a dictionary with keys: "Diameter", "RebarLength", "RebarsTotalLength" and their corresponding units as value.
* {{incode|column_units}} est un dictionnaire avec les clés: "Diameter", "RebarLength", "RebarsTotalLength" et leurs unités correspondantes comme valeur.
Example: {
Exemple: {
"Diameter": "mm",
"Diameter": "mm",
"RebarLength": "m",
"RebarLength": "m",
"RebarsTotalLength": "m",
"RebarsTotalLength": "m",
}
}
* {{incode|dia_weight_map}} is a dictionary with diameter as key and corresponding weight as value.
* {{incode|dia_weight_map}} est un dictionnaire avec le diamètre comme clé et le poids correspondant comme valeur.
Syntax: {
Syntaxe: {
6: FreeCAD.Units.Quantity("0.222 kg/m"),
6: FreeCAD.Units.Quantity("0.222 kg/m"),
8: FreeCAD.Units.Quantity("0.395 kg/m"),
8: FreeCAD.Units.Quantity("0.395 kg/m"),
Line 145: Line 145:
...,
...,
}
}
* {{incode|rebar_length_type}} specifies the type of rebar length used for bar bending schedule calculations; it can be "RealLength" or "LengthWithSharpEdges".
* {{incode|rebar_length_type}} spécifie le type de longueur d'armature utilisé pour les calculs; il peut s'agir de "RealLength" ou "LengthWithSharpEdges".
* {{incode|reinforcement_group_by}} specifies how reinforcement objects should be grouped; it can be "Mark" or "Host".
* {{incode|reinforcement_group_by}} spécifie comment les objets armatures doivent être groupés; il peut s'agir de "Mark" ou "Host".
* {{incode|font_family}} specifies the font family of data text.
* {{incode|font_family}} spécifie la famille de polices du texte de données.
* {{incode|font_size}} specifies the font size of the data text.
* {{incode|font_size}} spécifie la taille de la police du texte des données.
* {{incode|column_width}} specifies the width of each column in the bar bending schedule SVG.
* {{incode|column_width}} spécifie la largeur de chaque colonne dans le tableau des barres SVG.
* {{incode|row_height}} specifies the height of each row in the bar bending schedule SVG.
* {{incode|row_height}} spécifie la hauteur de chaque ligne dans le tableau des barres SVG.
* {{incode|rebar_shape_column_header}} specifies the column header for the rebar shape column.
* {{incode|rebar_shape_column_header}} spécifie l'en-tête de colonne pour la colonne de forme d'armature.
* {{incode|rebar_shape_view_directions}} is a list of viewpoint 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|rebar_shape_view_directions}} est une liste de directions de point de vue 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|rebar_shape_stirrup_extended_edge_offset}} specifies the offset of extended end edges of the stirrup, so that end edges of the stirrup with a 90-degree bent angle do not overlap with stirrup edges.
* {{incode|rebar_shape_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|rebar_shape_color_style}} specifies the color style of rebars. It can be "shape color" or "color_name or hex_value_of_color". "shape color" means to select the color of rebar shape.
* {{incode|rebar_shape_color_style}} spécifie le style de couleur des armatures. Il peut s'agir de "shape color" ou "color_name or hex_value_of_color". "shape color" signifie sélectionner la couleur de la forme de l'armature.
* {{incode|rebar_shape_stroke_width}} specifies the stroke-width of rebars in rebar shape SVG.
* {{incode|rebar_shape_stroke_width}} spécifie la largeur de trait des armatures en forme d'armature SVG.
* {{incode|rebar_shape_include_dimensions}} specifies if each rebar edge dimensions and bent angle dimensions are to be included in rebar shape SVG.
* {{incode|rebar_shape_include_dimensions}} spécifie si les dimensions de chaque arête d'armature et les cotes d'angle plié doivent être incluses dans la forme d'armature SVG.
* {{incode|rebar_shape_dimension_font_size}} specifies the font-size of dimension text in rebar shape SVG.
* {{incode|rebar_shape_dimension_font_size}} spécifie la taille de police du texte de cote en forme d'armature SVG.
* {{incode|rebar_shape_edge_dimension_units}} specifies the units to be used for rebar edge length dimensions in rebar shape SVG.
* {{incode|rebar_shape_edge_dimension_units}} spécifie les unités à utiliser pour les dimensions de longueur d'arête d'armature en forme d'armature SVG.
* {{incode|rebar_shape_edge_dimension_precision}} specifies the number of decimals that should be shown for rebar length as dimension label in rebar shape SVG. Set it to None to use user preferred unit precision from FreeCAD unit preferences.
* {{incode|rebar_shape_edge_dimension_precision}} spécifie le nombre de décimales à afficher pour la longueur de l'armature en tant qu'étiquette de cote dans la forme d'armature SVG. 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_edge_dimension_units_in_dimension_label}} specifies if rebars edge length units are to be shown in dimension label in rebar shape SVG.
* {{incode|include_edge_dimension_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 cote en forme d'armature SVG.
* {{incode|rebar_shape_bent_angle_dimension_exclude_list}} specifies the list of bent angles to not include their dimensions in rebar shape SVG.
* {{incode|rebar_shape_bent_angle_dimension_exclude_list}} spécifie la liste des angles pliés pour ne pas inclure leurs dimensions dans la forme d'armature SVG.
* {{incode|helical_rebar_dimension_label_format}} specifies the format of the helical rebar dimension label in rebar shape SVG. E.g. "%L,r=%R,pitch=%P" where:
* {{incode|helical_rebar_dimension_label_format}} spécifie le format de l'étiquette de cote d'armature hélicoïdale en forme d'armature SVG. 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|output_file}} specifies the output file to write generated bar bending schedule SVG.
* {{incode|output_file}} spécifie le fichier de sortie pour écrire le programme de pliage de barres généré SVG.


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


{{Code|code=
{{Code|code=
Line 186: Line 186:
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 210: Line 210:
).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 239: Line 239:
).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 281: Line 281:
output_file = str(Path.home() / "BarBendingSchedule.svg")
output_file = str(Path.home() / "BarBendingSchedule.svg")


# Créer un Tableau des armatures pour toutes les armatures dans le modèle
# Create Bar Bending Schedule for all rebars in model
BBSfunc.getBarBendingSchedule(
BBSfunc.getBarBendingSchedule(
rebar_objects=None,
rebar_objects=None,
Line 314: Line 314:
|[[Reinforcement_Workbench/fr|Atelier Reinforcement]]
|[[Reinforcement_Workbench/fr|Atelier Reinforcement]]
|IconL=Reinforcement_Bar_Shape_Cut_List.svg
|IconL=Reinforcement_Bar_Shape_Cut_List.svg
|IconC=Reinforcement_Workbench.svg
|IconR=Arch_Rebar_Drawing_Dimensioning.svg
|IconR=Arch_Rebar_Drawing_Dimensioning.svg
|IconC=Reinforcement_Workbench.svg
}}
}}


[[Category:External Command Reference{{#translation:}}]]
[[Category:External Command Reference{{#translation:}}]]
[[Category:Reinforcement{{#translation:}}]]
[[Category:Reinforcement{{#translation:}}]]

Revision as of 16:25, 22 May 2021

Reinforcement Tableau des armatures

Emplacement du menu
Reinforcement → Bar Bending Schedule
Ateliers
Arch, BIM
Raccourci par défaut
Aucun
Introduit dans la version
0.19
Voir aussi
Reinforcement, Arch Rebar Nomenclature, Arch Rebar Dessins

Description

L'outil Tableau des armatures permet à l'utilisateur de créer la nomenclature de pliage des barres d'armature.

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

Tableau des 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 Bar Bending Schedule 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 Reinforcement Bar Bending Schedule

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

7. Cliquez sur OK ou Apply pour générer un Tableau d'armatures.

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

Propriétés

Général :

  • DonnéesReinforcement Group By : spécifie comment les objets armatures doivent être regroupés dans le Tableau des armatures, c'est-à-dire "Host" ou "Mark".
  • DonnéesRebar Length Type : type de longueur d'armature spécifie le type de longueur d'armature utilisé pour les calculs de nomenclature, c'est-à-dire "RealLength" ou "LengthWithSharpEdges".
  • DonnéesColumn Headers : dictionnaire avec column_data comme clé et tuple (column_display_header, column_sequence) comme valeur.
  • DonnéesColumn Units : dictionnaire avec les clés: "Diameter", "RebarLength", "RebarsTotalLength" et leurs unités correspondantes comme valeur.
  • DonnéesFont Family : famille de polices de texte dans Bar Bending Schedule SVG.
  • DonnéesFont Size : taille de la police en mm.
  • DonnéesColumn Width : largeur de chaque colonne dans Bar Bending Schedule SVG.
  • DonnéesRow Height : hauteur de chaque ligne dans Bar Bending Schedule SVG.
  • DonnéesSVG Output File : fichier de sortie pour écrire la Nomenclature de façonnage des armatures SVG.

Rebar Shape column data : données relatives à la colonne forme d'armature dans le Tableau des armatures

  • DonnéesColumn Header : en-tête de colonne de la colonne de forme d'armature.
  • DonnéesStirrup Extended Edge Offset : 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.
  • DonnéesRebars Stroke Width : largeur de trait des armatures dans la colonne de forme d'armature.
  • DonnéesRebars Color Style : style de couleur des armatures.

Rebar Shape Column Dimension Data : données relatives aux dimensions de forme d'armature dans la colonne Forme d'armature

  • DonnéesInclude Dimensions : si True, les dimensions de chaque bord d'armature et les dimensions d'angle plié seront incluses dans le Tableau des armatures.
  • 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 : unités à utiliser pour les dimensions de longueur de bord d'armature.
  • DonnéesRebar Edge Dimension Precision : nombre de décimales à afficher pour la longueur du bord de l'armature sous forme d'étiquette de cote.
  • DonnéesDimension Font Family : famille de polices du texte de dimension.
  • DonnéesDimension Police Size : taille de la police du texte de dimension.
  • DonnéesBent Angle Dimension Exclude List : liste des angles pliés pour ne pas inclure leurs dimensions.
  • DonnéesHelical Rebar Dimension Label Format : 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ïde

Script

Voir aussi : Arch API, Reinforcement API et FreeCAD Scripts de bases.

L'outil Bar Bending Schedule peut être utilisé dans des macros et à partir de la console Python à l'aide des fonctions suivantes :

Créer un Tableau d'armatures

getBarBendingSchedule(
    rebar_objects: Optional[List] = None,
    column_headers: Optional[Dict[str, Tuple[str, int]]] = None,
    column_units: Optional[Dict[str, str]] = None,
    dia_weight_map: Optional[Dict[float, FreeCAD.Units.Quantity]] = None,
    rebar_length_type: Optional[
        Literal["RealLength", "LengthWithSharpEdges"]
    ] = None,
    reinforcement_group_by: Optional[Literal["Mark", "Host"]] = None,
    font_family: Optional[str] = None,
    font_size: float = 5,
    column_width: float = 60,
    row_height: float = 30,
    rebar_shape_column_header: str = "Rebar Shape (mm)",
    rebar_shape_view_directions: Union[
        Union[FreeCAD.Vector, WorkingPlane.Plane],
        List[Union[FreeCAD.Vector, WorkingPlane.Plane]],
    ] = FreeCAD.Vector(0, 0, 0),
    rebar_shape_stirrup_extended_edge_offset: float = 2,
    rebar_shape_color_style: str = "shape color",
    rebar_shape_stroke_width: float = 0.35,
    rebar_shape_include_dimensions: bool = True,
    rebar_shape_dimension_font_size: float = 3,
    rebar_shape_edge_dimension_units: str = "mm",
    rebar_shape_edge_dimension_precision: int = 0,
    include_edge_dimension_units_in_dimension_label: bool = False,
    rebar_shape_bent_angle_dimension_exclude_list: Union[
        List[float], Tuple[float, ...]
    ] = (45, 90, 180),
    helical_rebar_dimension_label_format: str = "%L,r=%R,pitch=%P",
    output_file: Optional[str] = None,
) -> xml.ElementTree.Element
  • Génère et renvoie un élément SVG du Tableau des armatures pour un rebar_objects.
  • rebar_objects est une liste d'objets <ArchRebar._Rebar> ou <rebar2.BaseRebar>, pour générer le tableau. S'il n'est pas fourni, tous les objets ArchRebars et rebar2.BaseRebar avec une marque unique d'ActiveDocument seront sélectionnés.
  • column_headers est un dictionnaire avec les clés: "Host", "Mark", "RebarsCount", "Diameter", "RebarLength", "RebarsTotalLength" et les valeurs sont un tuple de column_header et leur numéro de séquence.
   Exemple : {
                "Host": ("Member", 1),
                "Mark": ("Mark", 2),
                "RebarsCount": ("No. of Rebars", 3),
                "Diameter": ("Diameter in mm", 4),
                "RebarLength": ("Length in m/piece", 5),
                "RebarsTotalLength": ("Total Length in m", 6),
            }
            mettez le numéro de séquence de la colonne sur 0 pour masquer la colonne.
  • column_units est un dictionnaire avec les clés: "Diameter", "RebarLength", "RebarsTotalLength" et leurs unités correspondantes comme valeur.
   Exemple: {
                "Diameter": "mm",
                "RebarLength": "m",
                "RebarsTotalLength": "m",
            }
  • dia_weight_map est un dictionnaire avec le diamètre comme clé et le poids correspondant comme valeur.
   Syntaxe: {
                6: FreeCAD.Units.Quantity("0.222 kg/m"),
                8: FreeCAD.Units.Quantity("0.395 kg/m"),
                10: FreeCAD.Units.Quantity("0.617 kg/m"),
                12: FreeCAD.Units.Quantity("0.888 kg/m"),
                ...,
            }
  • rebar_length_type spécifie le type de longueur d'armature utilisé pour les calculs; il peut s'agir de "RealLength" ou "LengthWithSharpEdges".
  • reinforcement_group_by spécifie comment les objets armatures doivent être groupés; il peut s'agir de "Mark" ou "Host".
  • font_family spécifie la famille de polices du texte de données.
  • font_size spécifie la taille de la police du texte des données.
  • column_width spécifie la largeur de chaque colonne dans le tableau des barres SVG.
  • row_height spécifie la hauteur de chaque ligne dans le tableau des barres SVG.
  • rebar_shape_column_header spécifie l'en-tête de colonne pour la colonne de forme d'armature.
  • rebar_shape_view_directions est une liste de directions de point de vue 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.
  • rebar_shape_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.
  • rebar_shape_color_style spécifie le style de couleur des armatures. Il peut s'agir de "shape color" ou "color_name or hex_value_of_color". "shape color" signifie sélectionner la couleur de la forme de l'armature.
  • rebar_shape_stroke_width spécifie la largeur de trait des armatures en forme d'armature SVG.
  • rebar_shape_include_dimensions spécifie si les dimensions de chaque arête d'armature et les cotes d'angle plié doivent être incluses dans la forme d'armature SVG.
  • rebar_shape_dimension_font_size spécifie la taille de police du texte de cote en forme d'armature SVG.
  • rebar_shape_edge_dimension_units spécifie les unités à utiliser pour les dimensions de longueur d'arête d'armature en forme d'armature SVG.
  • rebar_shape_edge_dimension_precision spécifie le nombre de décimales à afficher pour la longueur de l'armature en tant qu'étiquette de cote dans la forme d'armature SVG. 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_edge_dimension_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 cote en forme d'armature SVG.
  • rebar_shape_bent_angle_dimension_exclude_list spécifie la liste des angles pliés pour ne pas inclure leurs dimensions dans la forme d'armature SVG.
  • helical_rebar_dimension_label_format spécifie le format de l'étiquette de cote d'armature hélicoïdale en forme d'armature SVG. 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
  • output_file spécifie le fichier de sortie pour écrire le programme de pliage de barres généré SVG.

Exemple

from pathlib import Path

import FreeCAD, Draft, Arch
from ColumnReinforcement import SingleTie
from BarBendingSchedule import BBSfunc

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"

FreeCAD.ActiveDocument.recompute()

COLUMN_UNITS = {
    "Diameter": "mm",
    "RebarLength": "m",
    "RebarsTotalLength": "m",
}

COLUMN_HEADERS = {
    "Host": ("Member", 1),
    "Mark": ("Mark", 2),
    "RebarsCount": ("No. of Rebars", 3),
    "Diameter": ("Diameter in " + COLUMN_UNITS["Diameter"], 4),
    "RebarLength": ("Length in " + COLUMN_UNITS["RebarLength"] + "/piece", 5),
    "RebarsTotalLength": ("Total Length in " + COLUMN_UNITS["RebarsTotalLength"], 6),
}

DIA_WEIGHT_MAP = {
    6: FreeCAD.Units.Quantity("0.222 kg/m"),
    8: FreeCAD.Units.Quantity("0.395 kg/m"),
    10: FreeCAD.Units.Quantity("0.617 kg/m"),
    12: FreeCAD.Units.Quantity("0.888 kg/m"),
    14: FreeCAD.Units.Quantity("1.206 kg/m"),
    16: FreeCAD.Units.Quantity("1.578 kg/m"),
    18: FreeCAD.Units.Quantity("2.000 kg/m"),
    20: FreeCAD.Units.Quantity("2.466 kg/m"),
    22: FreeCAD.Units.Quantity("2.980 kg/m"),
    25: FreeCAD.Units.Quantity("3.854 kg/m"),
    28: FreeCAD.Units.Quantity("4.830 kg/m"),
    32: FreeCAD.Units.Quantity("6.313 kg/m"),
    36: FreeCAD.Units.Quantity("7.990 kg/m"),
    40: FreeCAD.Units.Quantity("9.864 kg/m"),
    45: FreeCAD.Units.Quantity("12.490 kg/m"),
    50: FreeCAD.Units.Quantity("15.410 kg/m"),
}

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

# Créer un Tableau des armatures pour toutes les armatures dans le modèle
BBSfunc.getBarBendingSchedule(
    rebar_objects=None,
    column_headers=COLUMN_HEADERS,
    column_units=COLUMN_UNITS,
    dia_weight_map=DIA_WEIGHT_MAP,
    rebar_length_type="LengthWithSharpEdges",
    reinforcement_group_by="Host",
    font_family="DejaVu Sans",
    font_size=5,
    column_width=60,
    row_height=30,
    rebar_shape_column_header="Rebar Shape (" "mm)",
    rebar_shape_view_directions=FreeCAD.Vector(0, 0, 0),
    rebar_shape_stirrup_extended_edge_offset=2,
    rebar_shape_color_style="shape color",
    rebar_shape_stroke_width=0.35,
    rebar_shape_include_dimensions=True,
    rebar_shape_dimension_font_size=3,
    rebar_shape_edge_dimension_units="mm",
    rebar_shape_edge_dimension_precision=0,
    include_edge_dimension_units_in_dimension_label=False,
    rebar_shape_bent_angle_dimension_exclude_list=(45, 90, 180),
    helical_rebar_dimension_label_format="%L,r=%R,pitch=%P",
    output_file=output_file,
)