behold the working snake implimentation
This commit is contained in:
parent
26de90f0e3
commit
d30da1b546
139
snake.py
139
snake.py
|
@ -1,72 +1,79 @@
|
||||||
#!/bin/python
|
|
||||||
|
|
||||||
import random
|
import random
|
||||||
|
|
||||||
class Game:
|
class Snake:
|
||||||
"""
|
def __init__(self, bx=5, by=5):
|
||||||
this class describes a 5x5 grid, with a snake and
|
self.snake = [
|
||||||
apple inside.
|
(2, 2),
|
||||||
|
(2, 1),
|
||||||
|
(2, 0)
|
||||||
|
]
|
||||||
|
self.gamestate = "playing"
|
||||||
|
self.boarddimensions = (bx, by)
|
||||||
|
self.directions = [
|
||||||
|
(-1, 0, "left"),
|
||||||
|
(0, -1, "down"),
|
||||||
|
(1, 0, "right"),
|
||||||
|
(0, 1, "up")
|
||||||
|
]
|
||||||
|
self.apple = (random.randrange(0, self.boarddimensions[0]),
|
||||||
|
random.randrange(0, self.boarddimensions[0]))
|
||||||
|
def moveset(self):
|
||||||
|
tmp = []
|
||||||
|
for i, j, text in self.directions:
|
||||||
|
tmp.append(
|
||||||
|
(self.snake[0][0] + i,
|
||||||
|
self.snake[0][1] + j,
|
||||||
|
text)
|
||||||
|
)
|
||||||
|
|
||||||
coordinates are akin to a quadrant I cartesian plane, e.g.
|
for i, j, text in tmp:
|
||||||
^
|
if (i, j) == self.snake[1]:
|
||||||
5|
|
tmp.remove((i, j, text))
|
||||||
4|
|
|
||||||
y 3|
|
|
||||||
2|
|
|
||||||
1|
|
|
||||||
+----->
|
|
||||||
12345
|
|
||||||
|
|
||||||
x
|
for i, j, text in tmp:
|
||||||
"""
|
if i < 0 or i > self.boarddimensions[0] - 1:
|
||||||
def __init__(self):
|
tmp.remove((i, j, text))
|
||||||
self.snake = []
|
break
|
||||||
self.apple = (0, 0)
|
if j < 0 or j > self.boarddimensions[1] - 1:
|
||||||
for i in range(3):
|
tmp.remove((i, j, text))
|
||||||
self.snake.append((3, i + 1))
|
break
|
||||||
self.snake.reverse()
|
return tmp
|
||||||
self.newapple()
|
def nodir(self):
|
||||||
def newapple(self):
|
tmp = []
|
||||||
candidate = (random.randint(1, 5), random.randint(1, 5))
|
for i, j, _ in self.moveset():
|
||||||
if candidate in self.snake:
|
tmp.append((i, j))
|
||||||
candidate = self.newapple()
|
return tmp
|
||||||
return candidate
|
def move(self, direction):
|
||||||
def subtracttuple(self, a, b):
|
for i in self.directions:
|
||||||
return (a[0] - b[0], a[1] - b[1])
|
if direction == i[2]:
|
||||||
def addtuple(self, a, b):
|
considered = (self.snake[0][0] + i[0],
|
||||||
return (a[0] + b[0], a[1] + b[1])
|
self.snake[0][1] + i[1])
|
||||||
def returndirections(self):
|
if considered in self.snake:
|
||||||
permute = []
|
self.gamestate = "gameover"
|
||||||
directions = []
|
if considered in self.nodir():
|
||||||
permute.append((self.snake[0][0], self.snake[0][0] + 1))
|
self.snake.insert(0, considered)
|
||||||
permute.append((self.snake[0][0], self.snake[0][0] - 1))
|
if self.apple != considered:
|
||||||
permute.append((self.snake[0][0], self.snake[0][1] + 1))
|
self.snake.pop()
|
||||||
permute.append((self.snake[0][0], self.snake[0][1] - 1))
|
|
||||||
for i in permute:
|
|
||||||
if not i[0] < 0 and \
|
|
||||||
not i[0] > 5 and \
|
|
||||||
not i[1] < 0 and \
|
|
||||||
not i[1] > 5:
|
|
||||||
directions.append(self.subtracttuple(i, self.snake[0]))
|
|
||||||
return directions
|
|
||||||
def cycle(self, direction):
|
|
||||||
if direction in self.returndirections():
|
|
||||||
self.snake.insert(0, self.addtuple(self.snake[0], direction))
|
|
||||||
if not self.snake[0] == self.apple:
|
|
||||||
self.snake.pop(-1)
|
|
||||||
self.newapple()
|
|
||||||
if self.snake[0] in self.snake[1:]:
|
|
||||||
return 'game end'
|
|
||||||
else:
|
else:
|
||||||
return 'invalid'
|
c = (random.randrange(0, self.boarddimensions[0] - 1), random.randrange(0, self.boarddimensions[1] - 1))
|
||||||
def render(self): # very inefficent, fix later
|
while c in self.snake:
|
||||||
for y in range(5):
|
c = (random.randrange(0, self.boarddimensions[0] - 1), random.randrange(0, self.boarddimensions[1] - 1))
|
||||||
line = []
|
self.apple = c
|
||||||
for x in range(5):
|
|
||||||
if (x + 1, y + 1) in self.snake:
|
def render(self):
|
||||||
line.append("x")
|
tmp = []
|
||||||
elif (x + 1, y + 1) == self.apple:
|
for j in range(self.boarddimensions[0] - 1, -1, -1):
|
||||||
line.append("a")
|
tmp.append([])
|
||||||
|
current = tmp[-1]
|
||||||
|
for i in range(0, self.boarddimensions[1]):
|
||||||
|
if (i, j) in self.snake:
|
||||||
|
if (i, j) == self.snake[0]:
|
||||||
|
current.append('X')
|
||||||
else:
|
else:
|
||||||
line.append("-")
|
current.append('x')
|
||||||
print(' '.join(line))
|
elif (i, j) == self.apple:
|
||||||
|
current.append('a')
|
||||||
|
else:
|
||||||
|
current.append('_')
|
||||||
|
return tmp
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue