Add scad files
This commit is contained in:
parent
43d2034576
commit
d49e7c5bba
|
@ -0,0 +1,72 @@
|
|||
STRIPS = 12;
|
||||
FRAMES = 33;
|
||||
PERFS = "single";
|
||||
PITCH = "long";
|
||||
|
||||
module rounded_cube (cube_arr = [1, 1, 1], d = 0, center = false) {
|
||||
off_x = 0;
|
||||
off_y = 0;
|
||||
r = d/2;
|
||||
union () {
|
||||
cube([cube_arr[0] - d, cube_arr[1], cube_arr[2]], center = center);
|
||||
cube([cube_arr[0], cube_arr[1] - d, cube_arr[2]], center = center);
|
||||
translate ([1 * (cube_arr[0] / 2) - r , 1 * (cube_arr[1] / 2)- r, 0]) cylinder(r = r, h = cube_arr[2], center = center);
|
||||
translate ([-1 * (cube_arr[0] / 2) + r, -1 * (cube_arr[1] / 2) + r, 0]) cylinder(r = r, h = cube_arr[2], center = center);
|
||||
translate ([1 * (cube_arr[0] / 2) - r, -1 * (cube_arr[1] / 2) + r, 0]) cylinder(r = r, h = cube_arr[2], center = center);
|
||||
translate ([-1 * (cube_arr[0] / 2) + r, 1 * (cube_arr[1] / 2)- r, 0]) cylinder(r = r, h = cube_arr[2], center = center);
|
||||
}
|
||||
}
|
||||
|
||||
module 16mm_perf () {
|
||||
$fn = 10;
|
||||
PERF_W = 1.829;
|
||||
PERF_H = 1.27;
|
||||
rounded_cube([PERF_W, PERF_H, 2], d = .5, center = true);
|
||||
}
|
||||
|
||||
module 16mm_film (frames = 10, double = false, long = true) {
|
||||
THICKNESS = 0.0047 * 25.4;
|
||||
WIDTH = 16;
|
||||
SPACING_LONG = 7.62; //long pitch (projection)
|
||||
SPACING_SHORT = 7.605; //short pitch
|
||||
PERF_OFFSET = (1.829 / 2) + .85;
|
||||
difference () {
|
||||
if (long) {
|
||||
cube([WIDTH, SPACING_LONG * frames, THICKNESS], center = true);
|
||||
} else {
|
||||
cube([WIDTH, SPACING_SHORT * frames, THICKNESS], center = true);
|
||||
}
|
||||
if (long) {
|
||||
OFFSET = (SPACING_LONG * frames) / 2;
|
||||
for (i = [0 : frames]) {
|
||||
translate([8 - PERF_OFFSET, -OFFSET + SPACING_LONG * i, 0]) 16mm_perf();
|
||||
}
|
||||
if (double) {
|
||||
for (i = [0 : frames]) {
|
||||
translate([-8 + PERF_OFFSET, -OFFSET + SPACING_LONG * i, 0]) 16mm_perf();
|
||||
}
|
||||
}
|
||||
} else {
|
||||
OFFSET = (SPACING_SHORT * frames) / 2;
|
||||
for (i = [0 : frames]) {
|
||||
translate([8 - PERF_OFFSET, -OFFSET + SPACING_LONG * i, 0]) 16mm_perf();
|
||||
}
|
||||
if (double) {
|
||||
for (i = [0 : frames]) {
|
||||
translate([-8 + PERF_OFFSET, -OFFSET + SPACING_LONG * i, 0]) 16mm_perf();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
projection() for (i = [0:STRIPS - 1]) {
|
||||
translate([16.01 * i, 0, 0]) {
|
||||
16mm_film(FRAMES, PERFS == "double", PITCH == "long");
|
||||
}
|
||||
}
|
||||
|
||||
echo("STRIP LENGTH", (PITCH == "long" ? 7.62 : 7.605) * FRAMES, "mm");
|
||||
echo("PAGE WIDTH", 16 * STRIPS, "mm");
|
||||
echo("PITCH", PITCH);
|
||||
echo("PERFS", PERFS);
|
|
@ -0,0 +1,13 @@
|
|||
W = 192;
|
||||
H = 251.45999;
|
||||
|
||||
module block (x, y) {
|
||||
translate([x, y, 0]) cube([10, 10, 10], center = true);
|
||||
}
|
||||
|
||||
projection () {
|
||||
block(0, 0);
|
||||
block(W - 10, 0);
|
||||
block(W -10, H - 10);
|
||||
block(0, H - 10);
|
||||
}
|
Loading…
Reference in New Issue