3 // should rename this to actual name of the product
7 lip_height = 2.0 - 0.15;
8 lip_depth = 2.5 /*?*/ - 0.20;
9 neck_width = 26.5 - 0.45;
10 neck_depth = 28.5 - 0.45;
11 neck_length = 1.5 + 0.50;
21 nep1 = nep0 + [0,1] * neck_length;
22 nep7 = nep0 + [1,0] * lip_depth;
23 nep2 = [ nep7[0] + extra_slope, nep1[1] + slope * (nep7[0] + extra_slope - nep1[0]) ];
24 nep3 = nep2 + [0, 0.1];
25 nep4 = [ nep0[0]-1, nep3[1] ];
26 nep6 = nep7 + [0,-1] * lip_height;
27 nep5 = [ nep4[0], nep6[1] ];
28 nepm = [ nep0[0], nep3[1] ];
30 total_height = nep2[1] - nep6[1];
31 nep_z_offset = -nep2[1];
32 nep_side_offset = [ neck_width/2, nep_z_offset ];
33 nep_rear_offset = [ neck_depth, nep_z_offset ];
35 module NeckEdgePlan() {
48 linextr_y_xz(-100,100,convexity=10){
51 translate(nep_side_offset) NeckEdgePlan();
52 rectfromto([-0.1, -total_height],
53 nep_side_offset + nepm);
57 linextr_x_yz(-100,100,convexity=10){
58 translate(nep_rear_offset) NeckEdgePlan();
59 rectfromto([0, -total_height],
60 nep_rear_offset + nepm);
66 c = demo_ceil + extra_slope;
69 ([ -(neck_width/2 + c), -demo_ceil ],
70 [ +(neck_width/2 + c), neck_depth + c]);