mirror of
https://github.com/gumyr/build123d.git
synced 2025-12-06 10:41:20 -08:00
35 lines
1,004 B
Python
35 lines
1,004 B
Python
# [Code]
|
|
|
|
from build123d import *
|
|
from ocp_vscode import show_object
|
|
|
|
segment_count = 6
|
|
|
|
# Create a path for the sweep along the handle - added to pending_edges
|
|
handle_center_line = Spline(
|
|
(-10, 0, 0),
|
|
(0, 0, 5),
|
|
(10, 0, 0),
|
|
tangents=((0, 0, 1), (0, 0, -1)),
|
|
tangent_scalars=(1.5, 1.5),
|
|
)
|
|
|
|
# Create the cross sections - added to pending_faces
|
|
sections = Sketch()
|
|
for i in range(segment_count + 1):
|
|
location = handle_center_line ^ (i / segment_count)
|
|
if i % segment_count == 0:
|
|
circle = location * Circle(1)
|
|
else:
|
|
circle = location * Rectangle(1.25, 3)
|
|
circle = fillet(circle.vertices(), radius=0.2)
|
|
sections += circle
|
|
|
|
# Create the handle by sweeping along the path
|
|
handle = sweep(sections, path=handle_center_line, multisection=True)
|
|
|
|
show_object(handle_center_line, name="handle_path")
|
|
for i, circle in enumerate(sections):
|
|
show_object(circle, name="section" + str(i))
|
|
show_object(handle, name="handle", options=dict(alpha=0.6))
|
|
# [End]
|