main_height = 95;
+spike_web_thick = 2.52 + 0.5;
+
spike_top_width = 21.04;
spike_botpos_height = 9.5;
topwall_width = 1.5;
+// calculated
+
+main_width = spike_top_width + topwall_width*2;
+
module NegativePlan(){
x4z =
(spike_top_width - spike_botpos_width) /
polygon([[ x0, -5],
[ x0, 0],
[ x1, z1],
+ [ x1, z1+5],
+ [-x1, z1+5],
[-x1, z1],
[-x0, 0],
[-x0, -5]]);
}
module PositivePlan(){
- w = spike_top_width + topwall_width*2;
+ w = main_width;
translate([ -w/2, 0 ])
square([ w, main_height ]);
}
-PositivePlan();
-//NegativePlan();
+module MultiplySolidifyPlan(th){
+ for (r=[0,90]) {
+ rotate([0,0,r])
+ rotate([90,0,0])
+ translate([0,0,-th/2])
+ linear_extrude(height=th)
+ children(0);
+ }
+}
+
+module Main(){
+ MultiplySolidifyPlan(spike_web_thick) NegativePlan();
+}
+
+module PlanTest(){
+ linear_extrude(height=2.0){
+ difference(){
+ PositivePlan();
+ NegativePlan();
+ }
+ difference(){
+ circle(r = spike_botpos_width/2 + 5);
+ circle(r = spike_botpos_width/2);
+ translate([-50, 0]) square([100,50]);
+ }
+ }
+ linear_extrude(height=4.0){
+ difference(){
+ translate([ -main_width/2, 0 ]) square([ main_width, 2 ]);
+ NegativePlan();
+ }
+ }
+}
+
+//PlanTest();
+Main();