135 lines
4.4 KiB
Python
135 lines
4.4 KiB
Python
import pygame as pg
|
|
import numpy as np
|
|
import random
|
|
from math import hypot
|
|
import itertools as it
|
|
from UI.grid import Grid, Node
|
|
from Logic.Apath import a_path
|
|
|
|
|
|
class Window():
|
|
def __init__(self, grid: Grid,start: (int,int),end: (int,int)):
|
|
|
|
self.start = start
|
|
self.end = end
|
|
self.grid = grid
|
|
|
|
# assign to variables for brevity
|
|
cols = self.grid.cols
|
|
rows = self.grid.rows
|
|
width = Node.r_width
|
|
height = Node.r_height
|
|
margin = Node.r_margin
|
|
|
|
|
|
screen_width = cols * (width + margin) + 2 * margin
|
|
screen_height = rows * (height + margin) + 2 * margin
|
|
|
|
self.screen = pg.display.set_mode([screen_width, screen_height])
|
|
self.end = False
|
|
self.clock = pg.time.Clock()
|
|
|
|
|
|
def random_trash(grid: Grid):
|
|
for x in range(len(grid.table)*2):
|
|
grid.generate_trash(random.randint(1,len(grid.table)-1),random.randint(1,len(grid.table)-1))
|
|
|
|
|
|
#generate trash
|
|
random_trash(grid)
|
|
grid.change_field(start[0], start[1], 1)
|
|
grid.change_field(end[0], end[1], 2)
|
|
|
|
garbage = grid.garbage_to_collect()
|
|
|
|
#all obstacles, remove from list objects to collect
|
|
obs = [3,5,6,7,8]
|
|
for x in garbage:
|
|
obs.remove(x)
|
|
|
|
#list of garbage to collect
|
|
to_collect = []
|
|
for x in garbage:
|
|
to_collect.extend(grid.get_trash_possition(x))
|
|
print("\n",(len(to_collect)-1)," garbage to collect.\n")
|
|
|
|
#sort list of tuples to get minimum distance betwen all of them
|
|
#fajnie jakby sie udalo to zrobic wydajniej ale narazie niech bedzie tak
|
|
|
|
|
|
|
|
#change to diagonal distance
|
|
def dist(x,y):
|
|
return max(abs(x[0] - y[0]), abs(x[1] - y[1]))
|
|
|
|
to_collect_sorted = []
|
|
visited = []
|
|
for p in to_collect:
|
|
path_distances =[]
|
|
#poprzednik
|
|
if(len(to_collect_sorted) == 0):
|
|
s = (0,0)
|
|
else:
|
|
s = to_collect_sorted[len(to_collect_sorted)-1]
|
|
for upoint in to_collect:
|
|
if upoint in visited :
|
|
path_distances.append(100000)
|
|
elif dist(s,upoint) >= dist(end,upoint):
|
|
path_distances.append(50000)
|
|
else:
|
|
path_distances.append(dist(s,upoint))
|
|
min_index = np.argmin(path_distances)
|
|
visited.append(to_collect[min_index])
|
|
to_collect_sorted.append(to_collect[min_index])
|
|
|
|
|
|
|
|
#window init
|
|
pg.init() # pylint: disable=no-member
|
|
# setup window
|
|
pg.display.set_caption('Inteligentna śmieciarka')
|
|
|
|
#draw starting map
|
|
self.grid.draw_map(self.screen)
|
|
|
|
|
|
#move of the truck
|
|
def move_truck(path):
|
|
for index, t in enumerate(path):
|
|
x,y =t
|
|
if index != 0:
|
|
self.grid.change_field(path[index-1][0],path[index-1][1],4)
|
|
self.grid.change_field(x, y, 1)
|
|
self.grid.draw_node(self.screen, path[index-1][0],path[index-1][1])
|
|
self.grid.draw_node(self.screen, x, y)
|
|
pg.time.delay(500)
|
|
if(x != end[0] and y != end[1]):
|
|
print("collected:",grid.table[x][y].house.trash[2],"on possition: (",x,",",y,") ", grid.table[x][y].house.trash_file)
|
|
|
|
|
|
#visit all points from to_collect
|
|
|
|
for ind, x in enumerate(to_collect_sorted):
|
|
|
|
if ind == 0:
|
|
array = [[self.grid.table[col][row] for row in range(cols)] for col in range(rows)]
|
|
path = a_path(array,(start[0],start[1]),(x[0],x[1]),obs)
|
|
#print("Path:",path)
|
|
else:
|
|
array = [[self.grid.table[col][row] for row in range(cols)] for col in range(rows)]
|
|
path = a_path(array,(to_collect_sorted[ind-1][0],to_collect_sorted[ind-1][1]),(x[0],x[1]),obs)
|
|
#print("Path:",path)
|
|
|
|
|
|
#draw movement of garbage truck
|
|
move_truck(path)
|
|
|
|
|
|
#last move
|
|
array = [[self.grid.table[col][row] for row in range(cols)] for col in range(rows)]
|
|
path = a_path(array,(to_collect_sorted[len(to_collect)-1][0],to_collect_sorted[len(to_collect)-1][1]),(end[0],end[1]),obs)
|
|
#print("Path:",path)
|
|
move_truck(path)
|
|
|
|
pg.quit() # pylint: disable=no-member
|