import random
grid_x_count = 10
grid_y_count = 18
inert = []
for y in range(grid_y_count):
inert.append([])
for x in range(grid_x_count):
inert[y].append(' ')
piece_structures = [
[
[
[' ', ' ', ' ', ' '],
['i', 'i', 'i', 'i'],
[' ', ' ', ' ', ' '],
[' ', ' ', ' ', ' '],
],
[
[' ', 'i', ' ', ' '],
[' ', 'i', ' ', ' '],
[' ', 'i', ' ', ' '],
[' ', 'i', ' ', ' '],
],
],
[
[
[' ', ' ', ' ', ' '],
[' ', 'o', 'o', ' '],
[' ', 'o', 'o', ' '],
[' ', ' ', ' ', ' '],
],
],
[
[
[' ', ' ', ' ', ' '],
['j', 'j', 'j', ' '],
[' ', ' ', 'j', ' '],
[' ', ' ', ' ', ' '],
],
[
[' ', 'j', ' ', ' '],
[' ', 'j', ' ', ' '],
['j', 'j', ' ', ' '],
[' ', ' ', ' ', ' '],
],
[
['j', ' ', ' ', ' '],
['j', 'j', 'j', ' '],
[' ', ' ', ' ', ' '],
[' ', ' ', ' ', ' '],
],
[
[' ', 'j', 'j', ' '],
[' ', 'j', ' ', ' '],
[' ', 'j', ' ', ' '],
[' ', ' ', ' ', ' '],
],
],
[
[
[' ', ' ', ' ', ' '],
['l', 'l', 'l', ' '],
['l', ' ', ' ', ' '],
[' ', ' ', ' ', ' '],
],
[
[' ', 'l', ' ', ' '],
[' ', 'l', ' ', ' '],
[' ', 'l', 'l', ' '],
[' ', ' ', ' ', ' '],
],
[
[' ', ' ', 'l', ' '],
['l', 'l', 'l', ' '],
[' ', ' ', ' ', ' '],
[' ', ' ', ' ', ' '],
],
[
['l', 'l', ' ', ' '],
[' ', 'l', ' ', ' '],
[' ', 'l', ' ', ' '],
[' ', ' ', ' ', ' '],
],
],
[
[
[' ', ' ', ' ', ' '],
['t', 't', 't', ' '],
[' ', 't', ' ', ' '],
[' ', ' ', ' ', ' '],
],
[
[' ', 't', ' ', ' '],
[' ', 't', 't', ' '],
[' ', 't', ' ', ' '],
[' ', ' ', ' ', ' '],
],
[
[' ', 't', ' ', ' '],
['t', 't', 't', ' '],
[' ', ' ', ' ', ' '],
[' ', ' ', ' ', ' '],
],
[
[' ', 't', ' ', ' '],
['t', 't', ' ', ' '],
[' ', 't', ' ', ' '],
[' ', ' ', ' ', ' '],
],
],
[
[
[' ', ' ', ' ', ' '],
[' ', 's', 's', ' '],
['s', 's', ' ', ' '],
[' ', ' ', ' ', ' '],
],
[
['s', ' ', ' ', ' '],
['s', 's', ' ', ' '],
[' ', 's', ' ', ' '],
[' ', ' ', ' ', ' '],
],
],
[
[
[' ', ' ', ' ', ' '],
['z', 'z', ' ', ' '],
[' ', 'z', 'z', ' '],
[' ', ' ', ' ', ' '],
],
[
[' ', 'z', ' ', ' '],
['z', 'z', ' ', ' '],
['z', ' ', ' ', ' '],
[' ', ' ', ' ', ' '],
],
],
]
def new_sequence():
global sequence
sequence = list(range(len(piece_structures)))
random.shuffle(sequence)
new_sequence()
def new_piece():
global piece_x
global piece_y
global piece_type
global piece_rotation
piece_x = 3
piece_y = 0
piece_type = sequence.pop()
if len(sequence) == 0:
new_sequence()
piece_rotation = 0
new_piece()
piece_x_count = 4
piece_y_count = 4
timer = 0
timer_limit = 0.5
def can_piece_move(test_x, test_y, test_rotation):
for y in range(piece_y_count):
for x in range(piece_x_count):
test_block_x = test_x + x
test_block_y = test_y + y
if (
piece_structures[piece_type][test_rotation][y][x] != ' ' and (
test_block_x < 0
or test_block_x >= grid_x_count
or test_block_y >= grid_y_count
or inert[test_block_y][test_block_x] != ' '
)
):
return False
return True
def update(dt):
global timer
global piece_y
timer += dt
if timer >= timer_limit:
timer = 0
test_y = piece_y + 1
if can_piece_move(piece_x, test_y, piece_rotation):
piece_y = test_y
else:
for y in range(piece_y_count):
for x in range(piece_x_count):
block = piece_structures[piece_type][piece_rotation][y][x]
if block != ' ':
inert[piece_y + y][piece_x + x] = block
for y in range(grid_y_count):
complete = True
for x in range(grid_x_count):
if inert[y][x] == ' ':
complete = False
break
if complete:
print('Complete row: ' + str(y))
new_piece()
def on_key_down(key):
global piece_rotation
global piece_x
global piece_y
global timer
if key == keys.X:
test_rotation = piece_rotation + 1
if test_rotation > len(piece_structures[piece_type]) - 1:
test_rotation = 0
if can_piece_move(piece_x, piece_y, test_rotation):
piece_rotation = test_rotation
elif key == keys.Z:
test_rotation = piece_rotation - 1
if test_rotation < 0:
test_rotation = len(piece_structures[piece_type]) - 1
if can_piece_move(piece_x, piece_y, test_rotation):
piece_rotation = test_rotation
elif key == keys.LEFT:
test_x = piece_x - 1
if can_piece_move(test_x, piece_y, piece_rotation):
piece_x = test_x
elif key == keys.RIGHT:
test_x = piece_x + 1
if can_piece_move(test_x, piece_y, piece_rotation):
piece_x = test_x
elif key == keys.C:
while can_piece_move(piece_x, piece_y + 1, piece_rotation):
piece_y += 1
timer = timer_limit
def draw():
screen.fill((255, 255, 255))
def draw_block(block, x, y):
colors = {
' ': (222, 222, 222),
'i': (120, 195, 239),
'j': (236, 231, 108),
'l': (124, 218, 193),
'o': (234, 177, 121),
's': (211, 136, 236),
't': (248, 147, 196),
'z': (169, 221, 118),
}
color = colors[block]
block_size = 20
block_draw_size = block_size - 1
screen.draw.filled_rect(
Rect(
x * block_size, y * block_size,
block_draw_size, block_draw_size
),
color=color
)
for y in range(grid_y_count):
for x in range(grid_x_count):
draw_block(inert[y][x], x, y)
for y in range(piece_y_count):
for x in range(piece_x_count):
block = piece_structures[piece_type][piece_rotation][y][x]
if block != ' ':
draw_block(block, x + piece_x, y + piece_y)