Flexbox3: Fix radius of lid

May still be off a bit. But I can't see why...
This commit is contained in:
Florian Festi 2017-02-16 23:18:44 +01:00
parent 117ace3233
commit cc577956a4
1 changed files with 16 additions and 5 deletions

View File

@ -94,15 +94,26 @@ class FlexBox3(Boxes):
x, y, z, r, d, h = self.x, self.y, self.z, self.radius, self.d, self.h x, y, z, r, d, h = self.x, self.y, self.z, self.radius, self.d, self.h
t = self.thickness t = self.thickness
r2 = r + t if r + t <= h + t else h + t r2 = r + t if r + t <= h + t else h + t
self.moveTo(self.thickness, self.thickness) self.moveTo(self.thickness, 0)
self.edge(h + self.thickness - r2) if r < h:
self.corner(90, r2) r2 = r + t
self.edge(r - r2 + 2 * t) self.edge(h + self.thickness - r2)
self.corner(90, r2)
self.edge(r - r2 + 2 * t)
base_l = x + 2 * t
else:
a = math.acos((r-h)/(r+t))
ang = math.degrees(a)
base_l = x + (r+t) * math.sin(a) - r
self.corner(90-ang)
self.corner(ang, r+t)
self.edges["F"](x - r) self.edges["F"](x - r)
self.rectangleCorner("F", "f") self.rectangleCorner("F", "f")
self.edges["g"](h) self.edges["g"](h)
self.rectangleCorner("f", "e") self.rectangleCorner("f", "e")
self.edge(x + 2 * t) self.edge(base_l)
self.corner(90)
def render(self): def render(self):
if self.outside: if self.outside: