SZI2019SmieciarzWmi/utilities.py

69 lines
2.2 KiB
Python
Raw Normal View History

from config import GRID_WIDTH, GRID_HEIGHT
from DataModels.Road import Road
2019-05-30 21:32:56 +02:00
import platform,os,json
2019-04-10 11:18:22 +02:00
def movement(environment, x ,y):
movement = {
"right": (x + 1, y) if x + 1 < GRID_WIDTH and type(environment[x + 1][y]) == Road else (x, y),
"left": (x - 1, y) if x - 1 >= 0 and type(environment[x - 1][y]) == Road else (x, y),
"down": (x, y + 1) if y + 1 < GRID_HEIGHT and type(environment[x][y + 1]) == Road else (x, y),
"up": (x, y - 1) if y - 1 >= 0 and type(environment[x][y - 1]) == Road else (x, y)
}
forbidden_movement = {
"right": "left",
"left": "right",
"up": "down",
"down": "up"
}
return (movement, forbidden_movement)
def check_moves(environment, x,y,direction=None):
if direction == None:
return ([dir for dir in movement(environment, x, y)[0] if movement(environment, x,y)[0][dir] != (x,y)])
return ([dir for dir in movement(environment, x, y)[0] if movement(environment, x,y)[0][dir] != (x,y) and dir != movement(environment,x,y)[1][direction]])
def save_moveset(moveset):
2019-05-21 23:51:03 +02:00
if platform.system() == 'Windows':
path = '\moveset_data.json'
else:
path = '/moveset_data.json'
2019-05-22 10:55:13 +02:00
output_file = os.path.normpath(os.getcwd()) + path
2019-05-30 21:32:56 +02:00
2019-05-22 10:39:56 +02:00
results = {}
2019-05-22 10:55:13 +02:00
try:
f = open(output_file, 'r+')
except:
open(output_file, 'a').close()
finally:
f = open(output_file, 'r+')
2019-05-30 21:32:56 +02:00
2019-05-22 10:39:56 +02:00
try:
results = json.load(f)
except:
pass
2019-05-30 21:32:56 +02:00
finally:
2019-05-22 10:39:56 +02:00
if "moveset" not in results:
results = { "moveset": [] }
2019-05-30 21:32:56 +02:00
2019-05-22 10:39:56 +02:00
results["moveset"].append(moveset)
f.seek(0)
json.dump(results, f, indent=1)
2019-05-30 21:32:56 +02:00
f.close()
def parse_list(whole_result,current_x,current_y):
moves = []
print("x,y",current_x,current_y,"list",whole_result)
parser = {'[0,1]':"down",'[0,-1]':"up",'[1,0]':"right",'[-1,0]':"left"}
for x in range(len(whole_result)):
if whole_result[x]=="pick_garbage":
moves.append(whole_result[x])
else:
x_subtraction = whole_result[x][0] - current_x
y_subtraction = whole_result[x][1] - current_y
current_x = whole_result[x][0]
current_y = whole_result[x][1]
moves.append(parser[f"[{x_subtraction},{y_subtraction}]"])
print(moves)
return moves