OttoSoles: Add dove tail joints to the connecting edges

This commit is contained in:
Florian Festi 2018-03-11 17:43:55 +01:00
parent f2106a2c8c
commit 0604744284
1 changed files with 15 additions and 8 deletions

View File

@ -44,23 +44,30 @@ class OttoSoles(Boxes):
w = self.width w = self.width
w2 = w * 2**0.5 - c2 / 2 w2 = w * 2**0.5 - c2 / 2
d = w * math.tan(math.radians(22.5)) d = w * math.tan(math.radians(22.5))
# Initialize canvas # Initialize canvas
self.open() self.open()
self.edges["d"].settings.setValues(w, size=0.4, depth=0.3,
radius=0.05)
self.moveTo(0, y, -90) self.moveTo(0, y, -90)
for i in range(self.num*2): for i in range(self.num*2):
if c2 >= 2 * d: if c2 >= 2 * d:
self.polyline((c2, 1), 45, (y-2*c, 1), 45, c2/2., 90, (w, 1), self.polyline((c2, 1), 45, (y-2*c, 1), 45, c2/2., 90)
90, c2/2-d, -45, (y-2*c-2*d, 1), -45, self.edges["d"](w)
self.polyline(0, 90, c2/2-d, -45, (y-2*c-2*d, 1), -45,
(c2-2*d, 1), -45, (c2-2*d, 1), -45,
(x-2*c-2*d, 1), -45, c2/2-d, 90, (w, 1), 90, (x-2*c-2*d, 1), -45, c2/2-d, 90)
c2/2., 45, (x-2*c, 1), 45) self.edges["D"](w)
self.polyline(0, 90, c2/2., 45, (x-2*c, 1), 45)
self.moveTo(0, w + c2/2. + 2*2**0.5*self.burn) self.moveTo(0, w + c2/2. + 2*2**0.5*self.burn)
else: else:
self.polyline((c2, 1), 45, (y-2*c, 1), 45, c2/2., 90, (w2, 1), self.polyline((c2, 1), 45, (y-2*c, 1), 45, c2/2., 90)
45, (y-2*w, 1), -90, (x-2*w, 1), 45, (w2, 1), 90, self.edges["d"](w2)
c2/2., 45, (x-2*c, 3), 45) self.polyline(0, 45, (y-2*w, 1), -90, (x-2*w, 1), 45)
self.edges["D"](w2)
self.polyline(0, 90, c2/2., 45, (x-2*c, 3), 45)
self.moveTo(0, w * 2**0.5 + 2*2**0.5*self.burn) self.moveTo(0, w * 2**0.5 + 2*2**0.5*self.burn)
self.close() self.close()