forked from josephbleau/pygame-mahjong
-
Notifications
You must be signed in to change notification settings - Fork 0
/
tile.py
77 lines (65 loc) · 2.81 KB
/
tile.py
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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
import sys
import pygame
import time
import os.path
import random
def shuffle_tiles(tiles):
# Shuffle Tiles
for tile in tiles:
r = random.choice(range(len(tiles)))
tile, tiles[r] = Tile( tiles[r].tileno, tile.x, tile.y, tile.z ), \
Tile( tile.tileno, tiles[r].x, tiles[r].y, tiles[r].z )
class Tile:
def __init__(self, tileno, x, y, z):
self.tileno = tileno
self.imgpath = os.path.abspath('res/tiles/' + str(self.tileno) + '.png')
self.img = pygame.image.load(self.imgpath)
self.x = x
self.y = y
self.z = z
def draw(self, screen, paused=False):
"Draw a tile the the screen"
if paused == True:
blank = pygame.image.load( os.path.abspath('res/tiles/template.png') )
rect = (self.x - self.z * 3, self.y - self.z * 3, 40, 60)
screen.blit(blank, rect)
return
if self.img:
rect = (self.x - self.z * 3, self.y - self.z * 3, 40, 60)
screen.blit(self.img, rect)
def is_blocked(self,tiles):
"A tile can compare itself to a list of tiles to find out whether or not it's being blocked. A tile \
being blocked is when it has both a tile on its direct left, and direct right. This is important in \
Mahjong because you cannot remove a tile if it is blocked."
left = False
right = False
for tile in tiles:
# Check against pieces obscuring us above our tile.
if (tile.z > self.z and tile.x + 20 == self.x and tile.y - 30 == self.y) or \
(tile.z > self.z and tile.x - 20 == self.x and tile.y - 30 == self.y) or \
(tile.z > self.z and tile.x + 20 == self.x and tile.y + 30 == self.y) or \
(tile.z > self.z and tile.x - 20 == self.x and tile.y + 30 == self.y):
return True
if (tile.z > self.z and tile.x + 20 == self.x and tile.y == self.y) or \
(tile.z > self.z and tile.x - 20 == self.x and tile.y == self.y) or \
(tile.z > self.z and tile.x == self.x and tile.y == self.y) or \
(tile.z > self.z and tile.y + 30 == self.y and tile.x == self.x) or \
(tile.z > self.z and tile.y - 30 == self.y and tile.x == self.x):
return True
# Check against even-level touching pieces.
if tile.z == self.z and tile.y == self.y:
if self.x+40 == tile.x:
right = True
if tile.x + 40 == self.x:
left = True
if tile.z == self.z:
if (tile.y == self.y - 30 and tile.x == self.x + 40) or \
(tile.y == self.y + 30 and tile.x == self.x + 40):
right = True
if (tile.y == self.y - 30 and tile.x == self.x - 40) or \
(tile.y == self.y + 30 and tile.x == self.x - 40):
left = True
return left and right
def byTopRight(tiles):
"Helper function used to sort tiles."
return (tiles.z, tiles.x, tiles.y)