| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
 | # HVSplit contains generic code for HSplit and VSplit.
# HSplit and VSplit are specializations to either dimension.
# XXX This does not yet stretch/shrink children if there is too much
# XXX or too little space in the split dimension.
# XXX (NB There is no interface to ask children for stretch preferences.)
from Split import Split
class HVSplit(Split):
	#
	def create(self, (parent, hv)):
		# hv is 0 for HSplit, 1 for VSplit
		self = Split.create(self, parent)
		self.hv = hv
		return self
	#
	def getminsize(self, (m, sugg_size)):
		hv, vh = self.hv, 1 - self.hv
		size = [0, 0]
		sugg_size = [sugg_size[0], sugg_size[1]]
		sugg_size[hv] = 0
		sugg_size = sugg_size[0], sugg_size[1] # Make a tuple
		for c in self.children:
			csize = c.getminsize(m, sugg_size)
			if csize[vh] > size[vh]: size[vh] = csize[vh]
			size[hv] = size[hv] + csize[hv]
		return size[0], size[1]
	#
	def getbounds(self):
		return self.bounds
	#
	def setbounds(self, bounds):
		self.bounds = bounds
		hv, vh = self.hv, 1 - self.hv
		mf = self.parent.beginmeasuring
		begin, end = bounds
		sugg_size = end[0] - begin[0], end[1] - begin[1]
		size = self.getminsize(mf(), sugg_size)
		origin = [begin[0], begin[1]]
		sugg_size = [sugg_size[0], sugg_size[1]] # Make a list
		sugg_size[hv] = 0
		sugg_size = sugg_size[0], sugg_size[1] # Make a tuple
		for c in self.children:
			size = c.getminsize(mf(), sugg_size)
			corner = [0, 0]
			corner[vh] = end[vh]
			corner[hv] = origin[hv] + size[hv]
			c.setbounds((origin[0], origin[1]), \
					(corner[0], corner[1]))
			origin[hv] = corner[hv]
			# XXX stretch
			# XXX too-small
	#
class HSplit(HVSplit):
	def create(self, parent):
		return HVSplit.create(self, (parent, 0))
class VSplit(HVSplit):
	def create(self, parent):
		return HVSplit.create(self, (parent, 1))
 |