2020-04-07 16:58:12 +02:00
|
|
|
import pygame, sys
|
|
|
|
from traktor import Traktor
|
2020-04-28 21:15:29 +02:00
|
|
|
import dijkstra as di
|
2020-04-07 16:58:12 +02:00
|
|
|
|
2020-05-12 18:25:47 +02:00
|
|
|
import matplotlib.pyplot as plt
|
|
|
|
from tensorflow.keras.preprocessing import image
|
|
|
|
from tensorflow.keras.applications import MobileNetV2
|
|
|
|
from tensorflow.keras.applications.mobilenet import preprocess_input, decode_predictions
|
|
|
|
import numpy as np
|
|
|
|
import os, random
|
|
|
|
#u mnie blad z biblioteka
|
|
|
|
os.environ['KMP_DUPLICATE_LIB_OK']='True'
|
|
|
|
|
2020-04-07 16:58:12 +02:00
|
|
|
class Game(object):
|
2020-04-28 21:15:29 +02:00
|
|
|
|
2020-04-07 16:58:12 +02:00
|
|
|
def __init__(self):
|
2020-04-28 21:15:29 +02:00
|
|
|
|
|
|
|
#lokalizacje odpowiednich punktow na planszy
|
|
|
|
lokalizacje = [[0,0],
|
|
|
|
[100, 0],
|
|
|
|
[200, 0],
|
|
|
|
[300, 0],
|
|
|
|
[400, 0],
|
|
|
|
[400, 100],
|
|
|
|
[300, 100],
|
|
|
|
[200, 100],
|
|
|
|
[100, 100],
|
|
|
|
[0, 100],
|
|
|
|
[0, 200],
|
|
|
|
[100, 200],
|
|
|
|
[200, 200],
|
|
|
|
[300, 200],
|
|
|
|
[400, 200],
|
|
|
|
[400, 300],
|
|
|
|
[300, 300],
|
|
|
|
[200, 300],
|
|
|
|
[100, 300],
|
|
|
|
[0, 300],
|
|
|
|
[0, 400],
|
|
|
|
[100, 400],
|
|
|
|
[200, 400],
|
|
|
|
[300, 400],
|
|
|
|
[400, 400]]
|
|
|
|
|
2020-05-12 18:25:47 +02:00
|
|
|
#ładowanie tablicy ze zdjeciami
|
|
|
|
imgs = []
|
|
|
|
img_dir = './imgs'
|
|
|
|
for _ in lokalizacje:
|
|
|
|
imgs.append(img_dir + '/' + random.choice(os.listdir(img_dir)))
|
|
|
|
|
|
|
|
#model do rozpoznawania
|
|
|
|
model = MobileNetV2(input_shape=None, alpha=1.0, include_top=True, weights="imagenet", input_tensor=None, pooling=None, classes=1000)
|
|
|
|
|
2020-04-07 16:58:12 +02:00
|
|
|
#inicjalizacja
|
|
|
|
pygame.init()
|
2020-04-28 21:15:29 +02:00
|
|
|
self.pole = pygame.display.set_mode((501,501))
|
|
|
|
|
2020-04-07 16:58:12 +02:00
|
|
|
self.player = Traktor(self)
|
|
|
|
|
2020-04-28 21:15:29 +02:00
|
|
|
sterowanie = int(input("Podaj czy chcesz sam sterowac traktorem - 1, czy chcesz podawac punkty - 0: "))
|
|
|
|
if sterowanie == 1:
|
|
|
|
sterowanie = True
|
|
|
|
else:
|
|
|
|
sterowanie = False
|
|
|
|
|
2020-04-07 16:58:12 +02:00
|
|
|
while True:
|
2020-05-12 18:25:47 +02:00
|
|
|
run_classifier = False
|
|
|
|
|
2020-04-07 16:58:12 +02:00
|
|
|
#obsługa zdarzń
|
|
|
|
for event in pygame.event.get():
|
|
|
|
if event.type == pygame.QUIT:
|
|
|
|
pygame.quit()
|
|
|
|
sys.exit(0)
|
2020-04-28 21:15:29 +02:00
|
|
|
#sterowanie traktorem
|
|
|
|
if sterowanie:
|
|
|
|
if event.type == pygame.KEYDOWN :
|
|
|
|
if event.key == pygame.K_UP:
|
|
|
|
self.player.y -= 100
|
|
|
|
if self.player.y < 0:
|
|
|
|
self.player.y = 0
|
|
|
|
if event.key == pygame.K_DOWN:
|
|
|
|
self.player.y += 100
|
|
|
|
if self.player.y > 400:
|
|
|
|
self.player.y = 400
|
|
|
|
if event.key == pygame.K_RIGHT:
|
|
|
|
self.player.x += 100
|
|
|
|
if self.player.x > 400:
|
|
|
|
self.player.x = 400
|
|
|
|
if event.key == pygame.K_LEFT:
|
|
|
|
self.player.x -= 100
|
|
|
|
if self.player.x < 0:
|
|
|
|
self.player.x = 0
|
2020-05-12 18:25:47 +02:00
|
|
|
|
|
|
|
#okreslanie w ktorym punkcie jesteśmy
|
|
|
|
wsp = [self.player.x, self.player.y]
|
|
|
|
self.player.punkt = lokalizacje.index(wsp)
|
|
|
|
run_classifier = True
|
|
|
|
|
2020-04-28 21:15:29 +02:00
|
|
|
else:
|
|
|
|
#po spacji wpisujemy punkty
|
|
|
|
if event.type == pygame.KEYDOWN :
|
|
|
|
if event.key == pygame.K_SPACE:
|
|
|
|
pt = 0
|
|
|
|
punkt1 = int(input("Podaj pierwszy punkt (liczba od 0 do 24): "))
|
|
|
|
punkt2 = int(input("Podaj drugi punkt (liczba od 0 do 24): "))
|
|
|
|
dist = di.dijkstra(self.player.punkt)
|
|
|
|
|
|
|
|
if dist[punkt1] < dist[punkt2]:
|
|
|
|
print("Wybralem pierwszy punkt")
|
|
|
|
pt = punkt1
|
|
|
|
else:
|
|
|
|
print("Wybralem drugi punkt")
|
|
|
|
pt = punkt2
|
|
|
|
|
|
|
|
self.player.x = lokalizacje[pt][0]
|
|
|
|
self.player.y = lokalizacje[pt][1]
|
|
|
|
self.player.punkt = pt
|
2020-05-12 18:25:47 +02:00
|
|
|
run_classifier = True
|
2020-04-28 21:15:29 +02:00
|
|
|
|
|
|
|
|
2020-04-07 16:58:12 +02:00
|
|
|
pygame.display.update()
|
|
|
|
|
|
|
|
#rysowanie
|
|
|
|
self.pole.fill((0,0,0))
|
2020-04-28 21:15:29 +02:00
|
|
|
self.krata()
|
2020-04-07 16:58:12 +02:00
|
|
|
self.rysowanie()
|
|
|
|
pygame.display.flip()
|
2020-05-12 18:25:47 +02:00
|
|
|
|
|
|
|
if run_classifier:
|
|
|
|
#wybieranie zdjecia
|
|
|
|
pt = self.player.punkt
|
|
|
|
img_path = imgs[pt]
|
|
|
|
img = image.load_img(img_path, target_size=(224, 224))
|
|
|
|
x = image.img_to_array(img)
|
|
|
|
x = np.expand_dims(x, axis=0)
|
|
|
|
x = preprocess_input(x)
|
|
|
|
|
|
|
|
#detektor roslin, 5 rezultatow
|
|
|
|
plt.imshow(img)
|
|
|
|
preds = model.predict(x)
|
|
|
|
decoded = decode_predictions(preds, top=1)
|
|
|
|
print(decoded)
|
|
|
|
plt.show()
|
2020-04-28 21:15:29 +02:00
|
|
|
|
2020-05-12 18:25:47 +02:00
|
|
|
|
2020-04-28 21:15:29 +02:00
|
|
|
def krata(self):
|
|
|
|
#wymiary
|
|
|
|
w= 500
|
|
|
|
rows = 5
|
|
|
|
sizeBtw = w // rows
|
2020-04-07 16:58:12 +02:00
|
|
|
|
2020-04-28 21:15:29 +02:00
|
|
|
x = 0
|
|
|
|
y = 0
|
|
|
|
for r in range(rows):
|
|
|
|
x = x + sizeBtw
|
|
|
|
y = y + sizeBtw
|
2020-04-07 16:58:12 +02:00
|
|
|
|
2020-04-28 21:15:29 +02:00
|
|
|
#rysownie karaty
|
|
|
|
pygame.draw.line(self.pole, (255,255,255), (x,0), (x,w))
|
|
|
|
pygame.draw.line(self.pole, (255,255,255), (0,y), (w,y))
|
|
|
|
|
2020-04-07 16:58:12 +02:00
|
|
|
|
|
|
|
def rysowanie(self):
|
2020-04-28 21:15:29 +02:00
|
|
|
#rysowanie agenta
|
2020-04-07 16:58:12 +02:00
|
|
|
self.player.rysowanie()
|
|
|
|
|
|
|
|
|
|
|
|
if __name__=="__main__":
|
|
|
|
Game()
|