Compare commits

9 Commits

Author SHA1 Message Date
9a2344c970 Fix tandy lid pillars 2023-04-26 16:12:26 -03:00
d905b99d46 Minor dimensional tweaks for hinged lid 2023-04-25 17:24:59 -03:00
f37a4d8d00 git attributes 2023-04-24 15:53:30 -03:00
c87a32b745 LFS 2023-04-24 15:27:28 -03:00
7669678599 Fix M3 hex nut dimensions 2023-04-24 15:26:32 -03:00
92f4e4ab32 Add SVG extension 2023-04-22 23:25:45 -03:00
8ee471d48e move to right place 2023-04-16 22:46:27 -03:00
a08afe6775 Fix lint 2023-04-16 22:45:47 -03:00
79e5c3d5b0 Remove redundant file from repo 2023-04-16 22:41:52 -03:00
20 changed files with 272 additions and 195 deletions

0
.gitattributes vendored Normal file
View File

2
.gitignore vendored
View File

@ -174,3 +174,5 @@ poetry.toml
pyrightconfig.json
.lint
*right*stl
*left*stl

View File

@ -7,7 +7,8 @@
"emeraldwalk.RunOnSave",
"ms-vscode.makefile-tools",
"ms-python.python",
"mtsmfm.vscode-stl-viewer"
"mtsmfm.vscode-stl-viewer",
"sndst00m.vscode-native-svg-preview",
],
// List of extensions recommended by VS Code that should not be recommended for users of this workspace.
"unwantedRecommendations": [

View File

@ -8,7 +8,7 @@ all: $(STL_FILES) lint
lint: .lint
.lint: *.py components/*.py
flake8
black *.py */*.py
flake8
touch .lint

Binary file not shown.

Binary file not shown.

View File

@ -12,7 +12,7 @@ ti_radius = 2.35
ti_depth = 6.25
# M3 hex nut dimensions
m3_hn_diam = 5.5
m3_hn_diam = 6.2
m3_hn_hole = 3
m3_hn_thickness = 2.5
@ -125,7 +125,7 @@ hl_ring_radius = 5 # M3
hl_hinge_offset = max(p[1] for p in mounting_pillar_positions) + 6
hl_hinge_width = 25
# Base + this lid
hl_full_thickness = 43
hl_full_thickness = 45
## Dimensions for the simple lid

View File

@ -231,7 +231,7 @@ def model():
# Screen mount
model = (
# 1st layer
# Frame that contains the screen
model.workplaneFromTagged("base")
.center(0, -32)
.workplane(offset=dim.hl_full_thickness / 2 - dim.shell_t)
@ -246,7 +246,7 @@ def model():
.vertices()
.fillet(2)
)
.extrude(-2 - dim.scr_thickness)
.extrude(-1 - dim.scr_thickness)
# Hole for screws
.workplaneFromTagged("screen_plane")
.workplane(offset=1)
@ -259,7 +259,7 @@ def model():
.hole(dim.m3_hn_hole, depth=10)
# Holes for captured nuts
.workplaneFromTagged("screen_plane")
.workplane(offset=1)
.workplane(offset=1.5) # This is INSIDE THE LID
.rect(
dim.scr_w + 2 * dim.hl_bezel_width - dim.m3_hn_diam - 1,
dim.scr_h + 2 * dim.hl_bezel_height - dim.m3_hn_diam - 1,

Binary file not shown.

File diff suppressed because one or more lines are too long

Before

Width:  |  Height:  |  Size: 192 KiB

After

Width:  |  Height:  |  Size: 186 KiB

Binary file not shown.

Binary file not shown.

Binary file not shown.

107
simple_lid.py Normal file
View File

@ -0,0 +1,107 @@
import cadquery as cq
import dimensions as dim
from utils import extrude_shape2, hex_vents, punch_hole, export
def model():
# Create the basic shape of the case lid
model = (
cq.Workplane("XY")
# Hollow box
.box(dim.width, dim.sl_height, dim.sl_thickness)
.edges("|Z and >Y")
.fillet(2)
)
# Make many holes
vent = hex_vents(size=6, width=dim.width * 0.9, height=dim.sl_height * 0.9)[0]
model = punch_hole(
model=model,
face=">Z",
w=dim.width,
h=dim.sl_height,
x_offset=0.05 * dim.width,
y_offset=0.05 * dim.sl_height,
hole=vent,
depth=dim.sl_thickness,
)
# Add screw holes
for position in dim.mounting_pillar_positions:
model = (
model.faces(">Z")
.workplane(centerOption="CenterOfBoundBox")
.center(
-dim.width / 2 + position[0],
dim.sl_height / 2 - position[1] - dim.shell_t,
)
.placeSketch(cq.Sketch().circle(dim.m4_top / 2 + 1.5))
.extrude(-dim.sl_thickness)
.faces(">Z")
.workplane(centerOption="CenterOfBoundBox")
.center(
-dim.width / 2 + position[0],
dim.sl_height / 2 - position[1] - dim.shell_t,
)
.cskHole(dim.m4_bottom, dim.m4_top, 82, depth=None)
)
# Add front lip
model = (
model.faces(">Z")
.workplane(centerOption="CenterOfBoundBox")
.center(0, -dim.sl_height / 2 + dim.sl_lip_thickness / 2)
.placeSketch(
cq.Sketch().trapezoid(dim.width - 2 * dim.shell_t, dim.sl_lip_thickness, 90)
)
.extrude(-dim.sl_front_lip - dim.sl_thickness)
)
return model
def decorative_cover():
# A decorative thingie to cover the ugly seam in the middle
model = cq.Workplane("XY").box(10, dim.sl_height, 1).edges("|Z").fillet(1)
vent = hex_vents(
size=6, width=dim.width * 0.9, height=dim.sl_height * 0.9, density=0.775
)[0]
model = extrude_shape2(
model=model,
face=">Z",
w=dim.width,
h=dim.sl_height,
x_offset=0.05 * dim.width,
y_offset=0.05 * dim.sl_height,
hole=vent,
depth=3,
)
return model
if __name__ == "__main__":
model = model()
export(model, "simple_lid.stl")
cover = decorative_cover()
export(cover, "simple_lid_cover.stl")
export(
model,
"simple_lid.svg",
opt={
"projectionDir": (0, 0, 1),
},
)
export(
model.faces(">X").workplane(offset=-dim.width / 2).split(keepTop=True),
"simple_lid_right.stl",
)
export(
model.faces(">X").workplane(offset=-dim.width / 2).split(keepBottom=True),
"simple_lid_left.stl",
)

Binary file not shown.

Binary file not shown.

View File

@ -26,7 +26,7 @@ mounting_pillar_positions = [(x, -y) for x, y in dim.mounting_pillar_positions[:
mounting_pillars = (
cq.Sketch()
.push(dim.mounting_pillar_positions)
.push(mounting_pillar_positions)
.trapezoid(screen_pillars.pillar_width, screen_pillars.pillar_height, 90, mode="a")
.circle(dim.ti_radius, mode="s")
.clean()

Binary file not shown.

Binary file not shown.

Binary file not shown.