Guido van Rossum | 2e44967 | 1990-11-05 19:44:36 +0000 | [diff] [blame] | 1 | # HVSplit contains generic code for HSplit and VSplit. |
| 2 | # HSplit and VSplit are specializations to either dimension. |
| 3 | |
| 4 | from Split import Split |
| 5 | |
| 6 | class 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 | |
| 46 | class HSplit() = HVSplit(): |
| 47 | def create(self, parent): |
| 48 | return HVSplit.create(self, (parent, 0)) |
| 49 | |
| 50 | class VSplit() = HVSplit(): |
| 51 | def create(self, parent): |
| 52 | return HVSplit.create(self, (parent, 1)) |