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