def test_inner_padding(): cells = drawing.make_grid( Rect.from_size(10, 10), num_rows=1, num_cols=1, inner_padding=1, ) assert cells == { (0, 0): Rect(0, 0, 10, 10), } cells = drawing.make_grid( Rect.from_size(10, 11), num_rows=2, num_cols=1, inner_padding=1, ) assert cells == { (0, 0): Rect(0, 6, 10, 5), (1, 0): Rect(0, 0, 10, 5), } cells = drawing.make_grid(Rect.from_size(11, 10), num_rows=1, num_cols=2, inner_padding=1) assert cells == { (0, 0): Rect(0, 0, 5, 10), (0, 1): Rect(6, 0, 5, 10), }
def test_padding(): cells = drawing.make_grid( Rect.from_size(10, 10), num_rows=1, num_cols=1, padding=1, ) assert cells == { (0, 0): Rect(1, 1, 8, 8), } cells = drawing.make_grid( Rect.from_size(10, 11), num_rows=2, num_cols=1, padding=1, ) assert cells == { (0, 0): Rect(1, 6, 8, 4), (1, 0): Rect(1, 1, 8, 4), } cells = drawing.make_grid(Rect.from_size(11, 10), num_rows=1, num_cols=2, padding=1) assert cells == { (0, 0): Rect(1, 1, 4, 8), (0, 1): Rect(6, 1, 4, 8), }
def test_negative_sizes(): # Initially I thought this should be an error, but then I decided that it # probably just works as you'd expect it to, and it might be a useful way # to create an overlapping effect or to get rid of padding in certain # places. # row_heights can be negative. cells = drawing.make_grid( Rect.from_size(10, 10), num_rows=2, num_cols=1, row_heights={0: -2}, ) assert cells == { (0, 0): Rect(0, 12, 10, -2), (1, 0): Rect(0, 0, 10, 12), } # default_row_height can be negative. cells = drawing.make_grid( Rect.from_size(10, 10), num_rows=2, num_cols=1, row_heights={1: 'expand'}, default_row_height=-2, ) assert cells == { (0, 0): Rect(0, 12, 10, -2), (1, 0): Rect(0, 0, 10, 12), } # col_widths can be negative. cells = drawing.make_grid( Rect.from_size(10, 10), num_rows=1, num_cols=2, col_widths={0: -2}, ) assert cells == { (0, 0): Rect(0, 0, -2, 10), (0, 1): Rect(-2, 0, 12, 10), } # default_col_width can be negative. cells = drawing.make_grid( Rect.from_size(10, 10), num_rows=1, num_cols=2, col_widths={1: 'expand'}, default_col_width=-2, ) assert cells == { (0, 0): Rect(0, 0, -2, 10), (0, 1): Rect(-2, 0, 12, 10), }
def test_one_cell(): cells = drawing.make_grid( Rect.from_size(10, 10), num_rows=1, num_cols=1, ) assert cells == { (0, 0): Rect(0, 0, 10, 10), }
def test_infer_grid_size(): cells = drawing.make_grid( Rect.from_size(10, 10), cells={ (0, 0): Rect.null(), }, ) assert cells == { (0, 0): Rect(0, 0, 10, 10), } cells = drawing.make_grid( Rect.from_size(10, 10), cells={ (0, 0): Rect.null(), (1, 0): Rect.null(), }, ) assert cells == { (0, 0): Rect(0, 5, 10, 5), (1, 0): Rect(0, 0, 10, 5), } cells = drawing.make_grid( Rect.from_size(10, 10), cells={ (0, 0): Rect.null(), (0, 1): Rect.null(), }, ) assert cells == { (0, 0): Rect(0, 0, 5, 10), (0, 1): Rect(5, 0, 5, 10), } cells = drawing.make_grid( Rect.from_size(10, 10), cells={ (0, 0): Rect.null(), (1, 1): Rect.null(), }, ) assert cells == { (0, 0): Rect(0, 5, 5, 5), (0, 1): Rect(5, 5, 5, 5), (1, 0): Rect(0, 0, 5, 5), (1, 1): Rect(5, 0, 5, 5), }
def test_no_expandable_cells(): # If the grid can't fill all the space made available to it, it will pack # against the top-left corner. I chose this corner arbitrarily (although # other corners would've been slightly harder to implement). I decided # against adding the ability to control how the grid fits in its bounding # box for two reasons. First, you can get the same effect by simply adding # expandable rows or columns. Second, you can just change the bounding # box. Still, it's possible I'll change my mind about this behavior. cells = drawing.make_grid( Rect.from_size(10, 10), num_rows=1, num_cols=1, row_heights={0: 2}, col_widths={0: 2}, ) assert cells == { (0, 0): Rect(0, 8, 2, 2), } cells = drawing.make_grid( Rect.from_size(10, 10), num_rows=1, num_cols=1, default_row_height=2, default_col_width=2, ) assert cells == { (0, 0): Rect(0, 8, 2, 2), } cells = drawing.make_grid( Rect.from_size(10, 10), cells={ (0, 0): Rect.from_size(2, 2), }, default_row_height=0, default_col_width=0, ) assert cells == { (0, 0): Rect(0, 8, 2, 2), }
def test_make_claim(): grid = drawing.Grid() cells = { (0, 0): Rect.from_size(1, 2), (1, 1): Rect.from_size(3, 4), } assert grid.make_claim(cells) == (6, 8) assert grid.make_claim() == (6, 8) assert grid.min_width == 6 assert grid.min_height == 8 assert grid.min_bounding_rect == Rect(0, 0, 6, 8) grid.default_row_height = 0 grid.default_col_width = 0 assert grid.make_claim(cells) == (4, 6) assert grid.make_claim() == (4, 6) assert grid.min_width == 4 assert grid.min_height == 6 assert grid.min_bounding_rect == Rect(0, 0, 4, 6)
def test_two_cells(): cells = drawing.make_grid( Rect.from_size(10, 10), num_rows=2, num_cols=1, ) assert cells == { (0, 0): Rect(0, 5, 10, 5), (1, 0): Rect(0, 0, 10, 5), } cells = drawing.make_grid( Rect.from_size(10, 10), num_rows=1, num_cols=2, ) assert cells == { (0, 0): Rect(0, 0, 5, 10), (0, 1): Rect(5, 0, 5, 10), }
def test_min_cell_rect_vs_row_height(): # If there is a cell larger than the specified row height, make the row big # enough to fit that cell. cells = drawing.make_grid( Rect.from_size(10, 10), cells={ (0, 0): Rect.from_size(2, 2), }, num_rows=2, num_cols=1, row_heights={0: 0}, ) assert cells == { (0, 0): Rect(0, 8, 10, 2), (1, 0): Rect(0, 0, 10, 8), } # If the specified row height is larger than any of the cells in the row, # make the row the specified height. cells = drawing.make_grid( Rect.from_size(10, 10), cells={ (0, 0): Rect.from_size(2, 2), }, num_rows=2, num_cols=1, row_heights={0: 4}, ) assert cells == { (0, 0): Rect(0, 6, 10, 4), (1, 0): Rect(0, 0, 10, 6), } # If there are multiple cells in the row, the row should be big enough for # all of them. cells = drawing.make_grid( Rect.from_size(10, 10), cells={ (0, 0): Rect.from_size(2, 2), (0, 1): Rect.from_size(4, 4), }, num_rows=2, num_cols=2, row_heights={0: 0}, ) assert cells == { (0, 0): Rect(0, 6, 5, 4), (0, 1): Rect(5, 6, 5, 4), (1, 0): Rect(0, 0, 5, 6), (1, 1): Rect(5, 0, 5, 6), }
def test_request_row_height(): cells = drawing.make_grid( Rect.from_size(10, 10), num_rows=2, num_cols=1, row_heights={0: 2}, ) assert cells == { (0, 0): Rect(0, 8, 10, 2), (1, 0): Rect(0, 0, 10, 8), } cells = drawing.make_grid( Rect.from_size(10, 10), num_rows=2, num_cols=1, row_heights={1: 2}, ) assert cells == { (0, 0): Rect(0, 2, 10, 8), (1, 0): Rect(0, 0, 10, 2), }
def test_request_col_width(): cells = drawing.make_grid( Rect.from_size(10, 10), num_rows=1, num_cols=2, col_widths={0: 2}, ) assert cells == { (0, 0): Rect(0, 0, 2, 10), (0, 1): Rect(2, 0, 8, 10), } cells = drawing.make_grid( Rect.from_size(10, 10), num_rows=1, num_cols=2, col_widths={1: 2}, ) assert cells == { (0, 0): Rect(0, 0, 8, 10), (0, 1): Rect(8, 0, 2, 10), }
def test_min_cell_rect_vs_col_width(): cells = drawing.make_grid( Rect.from_size(10, 10), cells={ (0, 0): Rect.from_size(2, 2), }, num_rows=1, num_cols=2, col_widths={0: 0}, ) assert cells == { (0, 0): Rect(0, 0, 2, 10), (0, 1): Rect(2, 0, 8, 10), } cells = drawing.make_grid( Rect.from_size(10, 10), cells={ (0, 0): Rect.from_size(2, 2), }, num_rows=1, num_cols=2, col_widths={0: 4}, ) assert cells == { (0, 0): Rect(0, 0, 4, 10), (0, 1): Rect(4, 0, 6, 10), } # If there are multiple cells in the column, the column should be big # enough for all of them. cells = drawing.make_grid( Rect.from_size(10, 10), cells={ (0, 0): Rect.from_size(2, 2), (1, 0): Rect.from_size(4, 4), }, num_rows=2, num_cols=2, col_widths={0: 0}, ) assert cells == { (0, 0): Rect(0, 5, 4, 5), (1, 0): Rect(0, 0, 4, 5), (0, 1): Rect(4, 5, 6, 5), (1, 1): Rect(4, 0, 6, 5), }
def test_default_row_height(): cells = drawing.make_grid( Rect.from_size(10, 10), num_rows=2, num_cols=1, row_heights={0: 'expand'}, default_row_height=2, ) assert cells == { (0, 0): Rect(0, 2, 10, 8), (1, 0): Rect(0, 0, 10, 2), } cells = drawing.make_grid( Rect.from_size(10, 10), num_rows=2, num_cols=1, row_heights={1: 'expand'}, default_row_height=2, ) assert cells == { (0, 0): Rect(0, 8, 10, 2), (1, 0): Rect(0, 0, 10, 8), }
def test_default_col_width(): cells = drawing.make_grid( Rect.from_size(10, 10), num_rows=1, num_cols=2, col_widths={0: 'expand'}, default_col_width=2, ) assert cells == { (0, 0): Rect(0, 0, 8, 10), (0, 1): Rect(8, 0, 2, 10), } cells = drawing.make_grid( Rect.from_size(10, 10), num_rows=1, num_cols=2, col_widths={1: 'expand'}, default_col_width=2, ) assert cells == { (0, 0): Rect(0, 0, 2, 10), (0, 1): Rect(2, 0, 8, 10), }
def test_real_examples(): cells = drawing.make_grid( Rect.from_size(640, 480), cells={ (0, 0): Rect(0, 0, 10, 10), (0, 1): Rect(0, 0, 310, 10), (0, 2): Rect(0, 0, 10, 10), (0, 3): Rect(0, 0, 10, 10), }, col_widths={1: 0}, ) assert cells == { (0, 0): Rect(0, 0, 110, 480), (0, 1): Rect(110, 0, 310, 480), (0, 2): Rect(420, 0, 110, 480), (0, 3): Rect(530, 0, 110, 480), }
def test_make_cells(): grid = drawing.Grid() grid.num_rows = 2 grid.num_cols = 2 expected_results = [ (Rect.from_size(10, 10), { (0, 0): Rect(0, 5, 5, 5), (0, 1): Rect(5, 5, 5, 5), (1, 0): Rect(0, 0, 5, 5), (1, 1): Rect(5, 0, 5, 5), }), (Rect.from_size(20, 20), { (0, 0): Rect(0, 10, 10, 10), (0, 1): Rect(10, 10, 10, 10), (1, 0): Rect(0, 0, 10, 10), (1, 1): Rect(10, 0, 10, 10), }), ] for bbox, cells in expected_results: assert grid.make_cells(bbox) == cells assert grid.make_cells() == cells assert grid.cell_rects == cells assert grid.bounding_rect == bbox
#!/usr/bin/env python3 import pyglet import glooey import run_demos from vecrec import Vector, Rect window = pyglet.window.Window() batch = pyglet.graphics.Batch() full = Rect.from_pyglet_window(window) left = Rect(full.left, full.bottom, full.width/2, full.height) right = Rect(full.left, full.bottom, full.width/2, full.height) right.left = left.right left.shrink(50) right.shrink(50) @run_demos.on_space(window, batch) def test_outline(): a = glooey.drawing.Outline(left, batch=batch) b = glooey.drawing.Outline(right, batch=batch) yield "Show two unconnected outlines." a.hide() b.hide() c = glooey.drawing.Outline(full, batch=batch) yield "Put an outline just inside the window." c.hide() @window.event