mirror of
https://github.com/gumyr/build123d.git
synced 2025-12-06 02:30:55 -08:00
- Unbreak the three broken tutorials (fixes #848) - This involved a rewrite of PPP-01-10 because I already had my own solution to that one and I couldn't easily tell what was going wrong with the previous solution. - Add assertions to all the tutorials so that non-raising means success - Add the TTT examples to `test_examples.py` added recently for #909 - Also added sympy to development dependencies since one of the TTT examples uses it.
54 lines
1.6 KiB
Python
54 lines
1.6 KiB
Python
"""
|
|
Too Tall Toby Party Pack 01-01 Bearing Bracket
|
|
"""
|
|
|
|
from build123d import *
|
|
from ocp_vscode import *
|
|
|
|
densa = 7800 / 1e6 # carbon steel density g/mm^3
|
|
densb = 2700 / 1e6 # aluminum alloy
|
|
densc = 1020 / 1e6 # ABS
|
|
|
|
with BuildPart() as p:
|
|
with BuildSketch() as s:
|
|
Rectangle(115, 50)
|
|
with Locations((5 / 2, 0)):
|
|
SlotOverall(90, 12, mode=Mode.SUBTRACT)
|
|
extrude(amount=15)
|
|
|
|
with BuildSketch(Plane.XZ.offset(50 / 2)) as s3:
|
|
with Locations((-115 / 2 + 26, 15)):
|
|
SlotOverall(42 + 2 * 26 + 12, 2 * 26, rotation=90)
|
|
zz = extrude(amount=-12)
|
|
split(bisect_by=Plane.XY)
|
|
edgs = p.part.edges().filter_by(Axis.Y).group_by(Axis.X)[-2]
|
|
fillet(edgs, 9)
|
|
|
|
with Locations(zz.faces().sort_by(Axis.Y)[0]):
|
|
with Locations((42 / 2 + 6, 0)):
|
|
CounterBoreHole(24 / 2, 34 / 2, 4)
|
|
mirror(about=Plane.XZ)
|
|
|
|
with BuildSketch() as s4:
|
|
RectangleRounded(115, 50, 6)
|
|
extrude(amount=80, mode=Mode.INTERSECT)
|
|
# fillet does not work right, mode intersect is safer
|
|
|
|
with BuildSketch(Plane.YZ) as s4:
|
|
with BuildLine() as bl:
|
|
l1 = Line((0, 0), (18 / 2, 0))
|
|
l2 = PolarLine(l1 @ 1, 8, 60, length_mode=LengthMode.VERTICAL)
|
|
l3 = Line(l2 @ 1, (0, 8))
|
|
mirror(about=Plane.YZ)
|
|
make_face()
|
|
extrude(amount=115/2, both=True, mode=Mode.SUBTRACT)
|
|
|
|
show_object(p)
|
|
|
|
|
|
got_mass = p.part.volume*densa
|
|
want_mass = 797.15
|
|
tolerance = 1
|
|
delta = abs(got_mass - want_mass)
|
|
print(f"Mass: {got_mass:0.2f} g")
|
|
assert delta < tolerance, f'{got_mass=}, {want_mass=}, {delta=}, {tolerance=}'
|