thehd = [ tile_hard_edge_hole_dist, tile_hard_edge_hole_dist ];
interlock_rad = interlock_dia/2;
-interlock_negative_rad = interlock_rad + 0.25;
+interlock_negative_rad = interlock_rad + 0.125;
module Post(){
mirror([0,0,1]) {
}
}
-module InterlockCore(r) {
+module InterlockCore(r, plusth, ymir) {
dx = sqrt(3) * r;
$fn= 80;
- translate([0, -thehd[0], 1]){
- mirror([0,0,1]){
- linear_extrude(height=tile_th+2){
- circle(r=r);
- difference(){
- translate([-dx, -0.1])
- square([ dx*2, r/2 + 0.1 ]);
- for (xi = [-1, 1]) {
- translate([ xi*dx, r ])
- circle(r=r);
+ translate([0, -thehd[0], plusth]){
+ mirror([0,ymir,0]){
+ mirror([0,0,1]){
+ linear_extrude(height=tile_th+plusth*2, convexity=10){
+ circle(r=r);
+ difference(){
+ translate([-dx, -0.1])
+ square([ dx*2, r/2 + 0.1 ]);
+ for (xi = [-1, 1]) {
+ translate([ xi*dx, r ])
+ circle(r=r);
+ }
}
}
}
module InterlockNegative(this_post, right_post) {
INREFFRAME(this_post, right_post)
- InterlockCore(interlock_negative_rad);
+ InterlockCore(interlock_negative_rad, 1, 0);
}
-module TestPiece1(){
+module Interlock(this_post, right_post) {
+ INREFFRAME(this_post, right_post)
+ InterlockCore(interlock_rad, 0, 1);
+}
+
+module TestPiece1(){ ////toplevel
holes = [ [-100, 0],
[ 0, 0]
];
difference(){
TileBase(holes[0], holes[1]);
InterlockNegative(holes[1], holes[1] + [0,1]);
-
}
Posts(holes);
RoundEdge(holes[0], holes[1]);
RoundLeftCorner(holes[0], holes[1]);
}
-TestPiece1();
+module TestPiece2(){ ////toplevel
+ holes = [ [ 0, 0],
+ [ 50, 0]
+ ];
+ TileBase(holes[0], holes[1]);
+ Posts(holes);
+ RoundEdge(holes[0], holes[1]);
+ Interlock(holes[0], holes[0] + [0, -1]);
+}
+
+module Demo(){
+ translate([ -thehd[1], 0 ])
+ color("blue")
+ TestPiece1();
+ translate([ +thehd[1], 0 ])
+ TestPiece2();
+}
+
+//TestPiece1();
+//TestPiece2();
+//Demo();