blob: 2ee18f288b7006b50721d5520cf6209752f82589 [file] [log] [blame]
Guido van Rossum2e449671990-11-05 19:44:36 +00001# HVSplit contains generic code for HSplit and VSplit.
2# HSplit and VSplit are specializations to either dimension.
3
4from Split import Split
5
6class HVSplit() = Split():
7 #
8 def create(self, (parent, hv)):
9 # hv is 0 or 1 for HSplit or VSplit
10 self = Split.create(self, parent)
11 self.hv = hv
12 return self
13 #
14 def minsize(self, m):
15 hv, vh = self.hv, 1 - self.hv
16 size = [0, 0]
17 for c in self.children:
18 csize = c.minsize(m)
19 if csize[vh] > size[vh]: size[vh] = csize[vh]
20 size[hv] = size[hv] + csize[hv]
21 return size[0], size[1]
22 #
23 def getbounds(self):
24 return self.bounds
25 #
26 def setbounds(self, bounds):
27 self.bounds = bounds
28 hv, vh = self.hv, 1 - self.hv
29 mf = self.parent.beginmeasuring
30 size = self.minsize(mf())
31 # XXX not yet used! Later for stretching
32 maxsize_hv = bounds[1][hv] - bounds[0][hv]
33 origin = [self.bounds[0][0], self.bounds[0][1]]
34 for c in self.children:
35 size = c.minsize(mf())
36 corner = [0, 0]
37 corner[vh] = bounds[1][vh]
38 corner[hv] = origin[hv] + size[hv]
39 c.setbounds((origin[0], origin[1]), \
40 (corner[0], corner[1]))
41 origin[hv] = corner[hv]
42 # XXX stretch
43 # XXX too-small
44 #
45
46class HSplit() = HVSplit():
47 def create(self, parent):
48 return HVSplit.create(self, (parent, 0))
49
50class VSplit() = HVSplit():
51 def create(self, parent):
52 return HVSplit.create(self, (parent, 1))