Add holesMargin param to rectangularWall
Allow callables and (callable, edgewidth) tuple as edge style
This commit is contained in:
parent
35bb326533
commit
cf19c86c9c
49
boxes.py
49
boxes.py
|
@ -2,10 +2,20 @@
|
|||
|
||||
import cairo
|
||||
import math
|
||||
from functools import wraps
|
||||
|
||||
def dist(dx, dy):
|
||||
return (dx*dx+dy*dy)**0.5
|
||||
|
||||
def restore(func):
|
||||
@wraps(func)
|
||||
def f(self, *args, **kw):
|
||||
self.ctx.save()
|
||||
func(self, *args, **kw)
|
||||
self.ctx.restore()
|
||||
return f
|
||||
|
||||
|
||||
class Boxes:
|
||||
|
||||
def __init__(self, width=300, height=200, thickness=3.0):
|
||||
|
@ -51,6 +61,7 @@ class Boxes:
|
|||
raise
|
||||
self.ctx.restore()
|
||||
|
||||
|
||||
############################################################
|
||||
### Turtle graphics commands
|
||||
############################################################
|
||||
|
@ -361,11 +372,16 @@ class Boxes:
|
|||
### parts
|
||||
##################################################
|
||||
|
||||
def roundedPlate(self, x, y, r, callback=None):
|
||||
def roundedPlate(self, x, y, r, callback=None,
|
||||
holesMargin=None, holesSettings=None):
|
||||
"""fits surroundingWall
|
||||
first edge is split to have a joint in the middle of the side
|
||||
callback is called at the beginning of the straight edges
|
||||
0, 1 for the two part of the first edge, 2, 3, 4 for the others"""
|
||||
0, 1 for the two part of the first edge, 2, 3, 4 for the others
|
||||
|
||||
set holesMargin to get hex holes.
|
||||
"""
|
||||
|
||||
self.ctx.save()
|
||||
self.moveTo(r, 0)
|
||||
self.cc(callback, 0)
|
||||
|
@ -377,9 +393,25 @@ class Boxes:
|
|||
self.cc(callback, i+2)
|
||||
self.fingerJoint(l-2*r)
|
||||
self.corner(90, r)
|
||||
|
||||
self.ctx.restore()
|
||||
self.ctx.save()
|
||||
|
||||
if holesMargin is not None:
|
||||
self.moveTo(holesMargin, holesMargin)
|
||||
if r > holesMargin:
|
||||
r -= holesMargin
|
||||
else:
|
||||
r = 0
|
||||
self.hexHolesPlate(x-2*holesMargin, y-2*holesMargin, r,
|
||||
settings=holesSettings)
|
||||
self.ctx.restore()
|
||||
|
||||
def _edge(self, l, style):
|
||||
if type(style) is tuple:
|
||||
style = style[0]
|
||||
if callable(style):
|
||||
return style(l)
|
||||
if style in 'eE':
|
||||
self.edge(l)
|
||||
elif style == 'h':
|
||||
|
@ -393,6 +425,8 @@ class Boxes:
|
|||
|
||||
def _edgewidth(self, style):
|
||||
"""return how far a given edge type needs to be set out"""
|
||||
if type(style) is tuple:
|
||||
return style[1]
|
||||
if style == 'h':
|
||||
return (self.fingerHoleEdgeWidth+1) * self.thickness
|
||||
elif style in 'FE':
|
||||
|
@ -442,7 +476,11 @@ class Boxes:
|
|||
self.edge(bottomwidth)
|
||||
self.corner(90)
|
||||
|
||||
def rectangularWall(self, x, y, edges="eeee"):
|
||||
@restore
|
||||
def rectangularWall(self, x, y, edges="eeee",
|
||||
holesMargin=None, holesSettings=None):
|
||||
if len(edges) != 4:
|
||||
raise ValueError, "four edges required"
|
||||
edges += edges # append for wrapping around
|
||||
for i, l in enumerate((x, y, x, y)):
|
||||
self._edge(self._edgewidth(edges[i-1]), 'e')
|
||||
|
@ -450,6 +488,11 @@ class Boxes:
|
|||
self._edge(self._edgewidth(edges[i+1]), 'e')
|
||||
self.corner(90)
|
||||
|
||||
if holesMargin is not None:
|
||||
self.moveTo(holesMargin+self._edgewidth(edges[-1]),
|
||||
holesMargin+self._edgewidth(edges[0]))
|
||||
self.hexHolesRectangle(x-2*holesMargin, y-2*holesMargin)
|
||||
|
||||
##################################################
|
||||
### main
|
||||
##################################################
|
||||
|
|
Loading…
Reference in New Issue