cam.puzzle_joinery#
Fabex ‘puzzle_joinery.py’ © 2021 Alain Pelletier
Functions to add various puzzle joints as curves.
Functions#
|
Create a joint shape based on the specified diameter and stem. |
|
Create a specified number of fingers for a joint tool. |
|
Add a twist lock to a receptacle. |
|
Add a twist lock to a male connector. |
|
Create a bar with specified dimensions and joint features. |
|
Generate an arc with specified parameters. |
|
Generate an arc bar joint with specified parameters. |
|
Generate an arc bar joint based on specified parameters. |
|
Generate a multi-angle joint based on specified parameters. |
|
Generate a 3D model based on specified parameters. |
|
Create a curved shape based on specified parameters. |
|
Generate a mitre joint based on specified parameters. |
|
Open a curve and add puzzle connectors with optional twist lock |
|
Create a tile shape based on specified dimensions and parameters. |
Module Contents#
- finger(diameter, stem=2)[source]#
Create a joint shape based on the specified diameter and stem.
This function generates a 3D joint shape using Blender’s curve operations. It calculates the dimensions of a rectangle and an ellipse based on the provided diameter and stem parameters. The function then creates these shapes, duplicates and mirrors them, and performs boolean operations to form the final joint shape. The resulting object is named and cleaned up to ensure no overlapping vertices remain.
- Parameters:
diameter (float) – The diameter of the tool for joint creation.
stem (float?) – The amount of radius the stem or neck of the joint will have. Defaults to 2.
- Returns:
This function does not return any value.
- Return type:
None
- fingers(diameter, inside, amount=1, stem=1)[source]#
Create a specified number of fingers for a joint tool.
This function generates a set of fingers based on the provided diameter and tolerance values. It calculates the necessary translations for positioning the fingers and duplicates them if more than one is required. Additionally, it creates a receptacle using a silhouette offset from the fingers, allowing for precise joint creation.
- Parameters:
diameter (float) – The diameter of the tool used for joint creation.
inside (float) – The tolerance in the joint receptacle.
amount (int?) – The number of fingers to create. Defaults to 1.
stem (float?) – The amount of radius the stem or neck of the joint will have. Defaults to 1.
- twist_female(name, length, diameter, tolerance, twist, tneck, tthick, twist_keep=False)[source]#
Add a twist lock to a receptacle.
This function modifies the receptacle by adding a twist lock feature if the twist parameter is set to True. It performs several operations including interlocking the twist, rotating the object, and moving it to the correct position. If twist_keep is True, it duplicates the twist lock for further modifications. The function utilizes parameters such as length, diameter, tolerance, and thickness to accurately create the twist lock.
- Parameters:
name (str) – The name of the receptacle to be modified.
length (float) – The length of the receptacle.
diameter (float) – The diameter of the receptacle.
tolerance (float) – The tolerance value for the twist lock.
twist (bool) – A flag indicating whether to add a twist lock.
tneck (float) – The neck thickness for the twist lock.
tthick (float) – The thickness of the twist lock.
twist_keep (bool?) – A flag indicating whether to keep the twist lock after duplication. Defaults to False.
- twist_male(name, length, diameter, tolerance, twist, tneck, tthick, angle, twist_keep=False, x=0, y=0)[source]#
Add a twist lock to a male connector.
This function modifies the geometry of a male connector by adding a twist lock feature. It utilizes various parameters to determine the dimensions and positioning of the twist lock. If the twist_keep parameter is set to True, it duplicates the twist lock for further modifications. The function also allows for adjustments in position through the x and y parameters.
- Parameters:
name (str) – The name of the connector to be modified.
length (float) – The length of the connector.
diameter (float) – The diameter of the connector.
tolerance (float) – The tolerance level for the twist lock.
twist (bool) – A flag indicating whether to add a twist lock.
tneck (float) – The neck thickness for the twist lock.
tthick (float) – The thickness of the twist lock.
angle (float) – The angle at which to rotate the twist lock.
twist_keep (bool?) – A flag indicating whether to keep the twist lock duplicate. Defaults to False.
x (float?) – The x-coordinate for positioning. Defaults to 0.
y (float?) – The y-coordinate for positioning. Defaults to 0.
- Returns:
- This function modifies the state of the connector but does not return a
value.
- Return type:
None
- bar(width, thick, diameter, tolerance, amount=0, stem=1, twist=False, tneck=0.5, tthick=0.01, twist_keep=False, twist_line=False, twist_line_amount=2, which='MF')[source]#
Create a bar with specified dimensions and joint features.
This function generates a bar with customizable parameters such as width, thickness, and joint characteristics. It can automatically determine the number of fingers in the joint if the amount is set to zero. The function also supports various options for twisting and neck dimensions, allowing for flexible design of the bar according to the specified parameters. The resulting bar can be manipulated further based on the provided options.
- Parameters:
width (float) – The length of the bar.
thick (float) – The thickness of the bar.
diameter (float) – The diameter of the tool used for joint creation.
tolerance (float) – The tolerance in the joint.
amount (int?) – The number of fingers in the joint; 0 means auto-generate. Defaults to 0.
stem (float?) – The radius of the stem or neck of the joint. Defaults to 1.
twist (bool?) – Whether to add a twist lock. Defaults to False.
tneck (float?) – The percentage the twist neck will have compared to thickness. Defaults to 0.5.
tthick (float?) – The thickness of the twist material. Defaults to 0.01.
twist_keep (bool?) – Whether to keep the twist feature. Defaults to False.
twist_line (bool?) – Whether to add a twist line. Defaults to False.
twist_line_amount (int?) – The amount for the twist line. Defaults to 2.
which (str?) – Specifies the type of joint; options are ‘M’, ‘F’, ‘MF’, ‘MM’, ‘FF’. Defaults to ‘MF’.
- Returns:
- This function does not return a value but modifies the state of the 3D
model in Blender.
- Return type:
None
- arc(radius, thick, angle, diameter, tolerance, amount=0, stem=1, twist=False, tneck=0.5, tthick=0.01, twist_keep=False, which='MF')[source]#
Generate an arc with specified parameters.
This function creates a 3D arc based on the provided radius, thickness, angle, and other parameters. It handles the generation of fingers for the joint and applies twisting features if specified. The function also manages the orientation and positioning of the generated arc in a 3D space.
- Parameters:
radius (float) – The radius of the curve.
thick (float) – The thickness of the bar.
angle (float) – The angle of the arc (must not be zero).
diameter (float) – The diameter of the tool for joint creation.
tolerance (float) – Tolerance in the joint.
amount (int?) – The amount of fingers in the joint; 0 means auto-generate. Defaults to 0.
stem (float?) – The amount of radius the stem or neck of the joint will have. Defaults to 1.
twist (bool?) – Whether to add a twist lock. Defaults to False.
tneck (float?) – Percentage the twist neck will have compared to thickness. Defaults to 0.5.
tthick (float?) – Thickness of the twist material. Defaults to 0.01.
twist_keep (bool?) – Whether to keep the twist. Defaults to False.
which (str?) – Specifies which joint to generate (‘M’, ‘F’, ‘MF’). Defaults to ‘MF’.
- Returns:
- This function does not return a value but modifies the 3D scene
directly.
- Return type:
None
- arc_bar_arc(length, radius, thick, angle, angleb, diameter, tolerance, amount=0, stem=1, twist=False, tneck=0.5, tthick=0.01, which='MF', twist_keep=False, twist_line=False, twist_line_amount=2)[source]#
Generate an arc bar joint with specified parameters.
This function creates a joint consisting of male and female sections based on the provided parameters. It adjusts the length to account for the radius and thickness, generates a base rectangle, and then constructs the male and/or female sections as specified. Additionally, it can create a twist lock feature if required. The function utilizes Blender’s bpy operations to manipulate 3D objects.
- Parameters:
length (float) – The total width of the segments including 2 * radius and thickness.
radius (float) – The radius of the curve.
thick (float) – The thickness of the bar.
angle (float) – The angle of the female part.
angleb (float) – The angle of the male part.
diameter (float) – The diameter of the tool for joint creation.
tolerance (float) – Tolerance in the joint.
amount (int?) – The number of fingers in the joint; 0 means auto-generate. Defaults to 0.
stem (float?) – The amount of radius the stem or neck of the joint will have. Defaults to 1.
twist (bool?) – Whether to add a twist lock feature. Defaults to False.
tneck (float?) – Percentage the twist neck will have compared to thickness. Defaults to 0.5.
tthick (float?) – Thickness of the twist material. Defaults to 0.01.
which (str?) – Specifies which joint to generate (‘M’, ‘F’, or ‘MF’). Defaults to ‘MF’.
twist_keep (bool?) – Whether to keep the twist after creation. Defaults to False.
twist_line (bool?) – Whether to create a twist line feature. Defaults to False.
twist_line_amount (int?) – Amount for the twist line feature. Defaults to 2.
- Returns:
- This function does not return a value but modifies the Blender scene
directly.
- Return type:
None
- arc_bar(length, radius, thick, angle, diameter, tolerance, amount=0, stem=1, twist=False, tneck=0.5, tthick=0.01, twist_keep=False, which='MF', twist_line=False, twist_line_amount=2)[source]#
Generate an arc bar joint based on specified parameters.
This function constructs an arc bar joint by generating male and female sections according to the specified parameters such as length, radius, thickness, and joint type. The function adjusts the length to account for the radius and thickness of the bar and creates the appropriate geometric shapes for the joint. It also includes options for twisting and adjusting the neck thickness of the joint.
- Parameters:
length (float) – The total width of the segments including 2 * radius and thickness.
radius (float) – The radius of the curve.
thick (float) – The thickness of the bar.
angle (float) – The angle of the female part.
diameter (float) – The diameter of the tool for joint creation.
tolerance (float) – Tolerance in the joint.
amount (int?) – The number of fingers in the joint; 0 means auto-generate. Defaults to 0.
stem (float?) – The amount of radius the stem or neck of the joint will have. Defaults to 1.
twist (bool?) – Whether to add a twist lock. Defaults to False.
tneck (float?) – Percentage the twist neck will have compared to thickness. Defaults to 0.5.
tthick (float?) – Thickness of the twist material. Defaults to 0.01.
twist_keep (bool?) – Whether to keep the twist. Defaults to False.
which (str?) – Specifies which joint to generate (‘M’, ‘F’, ‘MF’). Defaults to ‘MF’.
twist_line (bool?) – Whether to include a twist line. Defaults to False.
twist_line_amount (int?) – Amount of twist line. Defaults to 2.
- multiangle(radius, thick, angle, diameter, tolerance, amount=0, stem=1, twist=False, tneck=0.5, tthick=0.01, combination='MFF')[source]#
Generate a multi-angle joint based on specified parameters.
This function creates a multi-angle joint by generating various geometric shapes using the provided parameters such as radius, thickness, angle, diameter, and tolerance. It utilizes Blender’s operations to create and manipulate curves, resulting in a joint that can be customized with different combinations of male and female parts. The function also allows for automatic generation of the number of fingers in the joint and includes options for twisting and neck dimensions.
- Parameters:
radius (float) – The radius of the curve.
thick (float) – The thickness of the bar.
angle (float) – The angle of the female part.
diameter (float) – The diameter of the tool for joint creation.
tolerance (float) – Tolerance in the joint.
amount (int?) – The amount of fingers in the joint; 0 means auto-generate. Defaults to 0.
stem (float?) – The amount of radius the stem or neck of the joint will have. Defaults to 1.
twist (bool?) – Indicates if a twist lock addition is required. Defaults to False.
tneck (float?) – Percentage the twist neck will have compared to thickness. Defaults to 0.5.
tthick (float?) – Thickness of the twist material. Defaults to 0.01.
combination (str?) – Specifies which joint to generate (‘M’, ‘F’, ‘MF’, ‘MFF’, ‘MMF’). Defaults to ‘MFF’.
- Returns:
- This function does not return a value but performs operations in
Blender.
- Return type:
None
- t(length, thick, diameter, tolerance, amount=0, stem=1, twist=False, tneck=0.5, tthick=0.01, combination='MF', base_gender='M', corner=False)[source]#
Generate a 3D model based on specified parameters.
This function creates a 3D model by manipulating geometric shapes based on the provided parameters. It handles different combinations of shapes and orientations based on the specified gender and corner options. The function utilizes several helper functions to perform operations such as moving, duplicating, and uniting shapes to form the final model.
- Parameters:
length (float) – The length of the model.
thick (float) – The thickness of the model.
diameter (float) – The diameter of the model.
tolerance (float) – The tolerance level for the model dimensions.
amount (int?) – The amount of material to use. Defaults to 0.
stem (int?) – The stem value for the model. Defaults to 1.
twist (bool?) – Whether to apply a twist to the model. Defaults to False.
tneck (float?) – The neck thickness. Defaults to 0.5.
tthick (float?) – The thickness for the neck. Defaults to 0.01.
combination (str?) – The combination type (‘MF’, ‘F’, ‘M’). Defaults to ‘MF’.
base_gender (str?) – The base gender for the model (‘M’ or ‘F’). Defaults to ‘M’.
corner (bool?) – Whether to apply corner adjustments. Defaults to False.
- Returns:
- This function does not return a value but modifies the 3D model
directly.
- Return type:
None
- curved_t(length, thick, radius, diameter, tolerance, amount=0, stem=1, twist=False, tneck=0.5, tthick=0.01, combination='MF', base_gender='M')[source]#
Create a curved shape based on specified parameters.
This function generates a 3D curved shape using the provided dimensions and characteristics. It utilizes the bar and arc functions to create the desired geometry and applies transformations such as mirroring and union operations to achieve the final shape. The function also allows for customization based on the gender specification, which influences the shape’s design.
- Parameters:
length (float) – The length of the bar.
thick (float) – The thickness of the bar.
radius (float) – The radius of the arc.
diameter (float) – The diameter used in arc creation.
tolerance (float) – The tolerance level for the shape.
amount (int?) – The amount parameter for the shape generation. Defaults to 0.
stem (int?) – The stem parameter for the shape generation. Defaults to 1.
twist (bool?) – A flag indicating whether to apply a twist to the shape. Defaults to False.
tneck (float?) – The neck thickness parameter. Defaults to 0.5.
tthick (float?) – The thickness parameter for the neck. Defaults to 0.01.
combination (str?) – The combination type for the shape. Defaults to ‘MF’.
base_gender (str?) – The base gender for the shape design. Defaults to ‘M’.
- Returns:
- This function does not return a value but modifies the 3D model in the
environment.
- Return type:
None
- mitre(length, thick, angle, angleb, diameter, tolerance, amount=0, stem=1, twist=False, tneck=0.5, tthick=0.01, which='MF')[source]#
Generate a mitre joint based on specified parameters.
This function creates a 3D representation of a mitre joint using Blender’s bpy.ops.curve.simple operations. It generates a base rectangle and cutout shapes, then constructs male and female sections of the joint based on the provided angles and dimensions. The function allows for customization of various parameters such as thickness, diameter, tolerance, and the number of fingers in the joint. The resulting joint can be either male, female, or a combination of both.
- Parameters:
length (float) – The total width of the segments including 2 * radius and thickness.
thick (float) – The thickness of the bar.
angle (float) – The angle of the female part.
angleb (float) – The angle of the male part.
diameter (float) – The diameter of the tool for joint creation.
tolerance (float) – Tolerance in the joint.
amount (int?) – Amount of fingers in the joint; 0 means auto-generate. Defaults to 0.
stem (float?) – Amount of radius the stem or neck of the joint will have. Defaults to 1.
twist (bool?) – Indicates if a twist lock addition is required. Defaults to False.
tneck (float?) – Percentage the twist neck will have compared to thickness. Defaults to 0.5.
tthick (float?) – Thickness of the twist material. Defaults to 0.01.
which (str?) – Specifies which joint to generate (‘M’, ‘F’, ‘MF’). Defaults to ‘MF’.
- open_curve(line, thick, diameter, tolerance, amount=0, stem=1, twist=False, t_neck=0.5, t_thick=0.01, twist_amount=1, which='MF', twist_keep=False)[source]#
Open a curve and add puzzle connectors with optional twist lock connectors.
This function takes a shapely LineString and creates an open curve with specified parameters such as thickness, diameter, tolerance, and twist options. It generates puzzle connectors at the ends of the curve and can optionally add twist lock connectors along the curve. The function also handles the creation of the joint based on the provided parameters, ensuring that the resulting geometry meets the specified design requirements.
- Parameters:
line (LineString) – A shapely LineString representing the path of the curve.
thick (float) – The thickness of the bar used in the joint.
diameter (float) – The diameter of the tool for joint creation.
tolerance (float) – The tolerance in the joint.
amount (int?) – The number of fingers in the joint; 0 means auto-generate. Defaults to 0.
stem (float?) – The amount of radius the stem or neck of the joint will have. Defaults to 1.
twist (bool?) – Whether to add twist lock connectors. Defaults to False.
t_neck (float?) – The percentage the twist neck will have compared to thickness. Defaults to 0.5.
t_thick (float?) – The thickness of the twist material. Defaults to 0.01.
twist_amount (int?) – The amount of twist distributed on the curve, not counting joint twists. Defaults to 1.
which (str?) – Specifies the type of joint; options include ‘M’, ‘F’, ‘MF’, ‘MM’, ‘FF’. Defaults to ‘MF’.
twist_keep (bool?) – Whether to keep the twist lock connectors. Defaults to False.
- Returns:
- This function does not return a value but modifies the geometry in the
Blender context.
- Return type:
None
- tile(diameter, tolerance, tile_x_amount, tile_y_amount, stem=1)[source]#
Create a tile shape based on specified dimensions and parameters.
This function calculates the dimensions of a tile based on the provided diameter and tolerance, as well as the number of tiles in the x and y directions. It constructs the tile shape by creating a base and adding features such as fingers for interlocking. The function also handles transformations such as moving, rotating, and performing boolean operations to achieve the desired tile geometry.
- Parameters:
diameter (float) – The diameter of the tile.
tolerance (float) – The tolerance to be applied to the tile dimensions.
tile_x_amount (int) – The number of tiles along the x-axis.
tile_y_amount (int) – The number of tiles along the y-axis.
stem (int?) – A parameter affecting the tile’s features. Defaults to 1.
- Returns:
This function does not return a value but modifies global state.
- Return type:
None