182 lines
7.0 KiB
Python
182 lines
7.0 KiB
Python
from NN.neural_network import clear_text_area
|
|
from crop_protection_product import CropProtectionProduct
|
|
from area.constants import TILE_SIZE, DIRECTION_EAST, DIRECTION_SOUTH, DIRECTION_WEST, DIRECTION_NORTH, WIDTH
|
|
from area.field import fieldX, fieldY, tiles
|
|
import pygame
|
|
import time
|
|
|
|
|
|
class Tractor:
|
|
x = None
|
|
y = None
|
|
direction = None #direction takes values in the range of 1 to 4 (1->North, 2->East etc...)
|
|
image = None
|
|
cypermetryna = CropProtectionProduct("pests", "cereal")
|
|
diflufenikan = CropProtectionProduct("weeds", "cereal")
|
|
spirotetramat = CropProtectionProduct("pests", "fruit")
|
|
oksadiargyl = CropProtectionProduct("weeds", "fruit")
|
|
spinosad = CropProtectionProduct("pests", "vegetable")
|
|
metazachlor = CropProtectionProduct("weeds", "vegetable")
|
|
# etc
|
|
|
|
def __init__(self, x, y, direction, tractor_start, tractor_end):
|
|
self.x = x
|
|
self.y = y
|
|
|
|
self.rect = pygame.Rect(x, y, TILE_SIZE, TILE_SIZE)
|
|
|
|
self.direction = direction
|
|
self.image = pygame.image.load('resources/images/tractor_right.png').convert_alpha()
|
|
|
|
self.tractor_start = tractor_start #important for bfs - prevents from spawning obstacles on these positions
|
|
self.tractor_end = tractor_end #
|
|
|
|
if (self.direction==1):
|
|
self.image = pygame.image.load('resources/images/tractor_up.png').convert_alpha()
|
|
elif (self.direction==3):
|
|
self.image = pygame.image.load('resources/images/tractor_down.png').convert_alpha()
|
|
elif (self.direction==4):
|
|
self.image = pygame.image.load('resources/images/tractor_left.png').convert_alpha()
|
|
|
|
|
|
def work_on_field(self, screen, tile, ground, plant1):
|
|
results = []
|
|
if plant1 is None:
|
|
tile.randomizeContent()
|
|
# sprobuj zasadzic cos
|
|
print("Tarctor planted something")
|
|
results.append("Tarctor planted something")
|
|
elif plant1.growth_level == 100:
|
|
tile.plant = None
|
|
ground.nutrients_level -= 40
|
|
ground.water_level -= 40
|
|
print("Tractor collected something")
|
|
results.append("Tractor collected something")
|
|
else:
|
|
plant1.try_to_grow(50,50) #mozna dostosowac jeszcze
|
|
ground.nutrients_level -= 11
|
|
ground.water_level -= 11
|
|
if ground.pest:
|
|
# traktor pozbywa sie szkodnikow
|
|
if plant1.plant_type == self.cypermetryna.plant_type:
|
|
t = "Tractor used Cypermetryna"
|
|
elif plant1.plant_type == self.spirotetramat.plant_type:
|
|
t = "Tractor used Spirotetramat"
|
|
elif plant1.plant_type == self.spinosad.plant_type:
|
|
t = "Tractor used Spinosad"
|
|
print(t)
|
|
results.append(t)
|
|
ground.pest = False
|
|
if ground.weed:
|
|
# traktor pozbywa się chwastow
|
|
if plant1.plant_type == self.diflufenikan.plant_type:
|
|
t = "Tractor used Diflufenikan"
|
|
elif plant1.plant_type == self.oksadiargyl.plant_type:
|
|
t = "Tractor used Oksadiargyl"
|
|
elif plant1.plant_type == self.metazachlor.plant_type:
|
|
t = "Tractor used Metazachlor"
|
|
print(t)
|
|
results.append(t)
|
|
ground.weed = False
|
|
if ground.water_level < plant1.water_requirements:
|
|
ground.water_level += 20
|
|
print("Tractor watered the plant")
|
|
results.append("Tractor watered the plant")
|
|
if ground.nutrients_level < plant1.nutrients_requirements:
|
|
ground.nutrients_level += 20
|
|
print("Tractor added some nutrients")
|
|
results.append("Tractor added some nutrients")
|
|
|
|
clear_text_area(screen, WIDTH-90, 100, 400, 100)
|
|
for idx, result in enumerate(results):
|
|
display_work_results(screen, result, (WIDTH-90, 100 + idx * 30))
|
|
|
|
|
|
|
|
|
|
def move(self):
|
|
if self.direction == DIRECTION_EAST:
|
|
self.rect.x += TILE_SIZE
|
|
|
|
elif self.direction == DIRECTION_WEST:
|
|
self.rect.x -= TILE_SIZE
|
|
|
|
elif self.direction == DIRECTION_NORTH:
|
|
self.rect.y -= TILE_SIZE
|
|
|
|
elif self.direction == DIRECTION_SOUTH:
|
|
self.rect.y += TILE_SIZE
|
|
|
|
|
|
def rotate_to_right(self):
|
|
if self.direction == 4:
|
|
self.direction = 1
|
|
else:
|
|
self.direction += 1
|
|
self.image = pygame.transform.rotate(self.image, -90)
|
|
|
|
|
|
def rotate_to_left(self):
|
|
if self.direction == 1:
|
|
self.direction = 4
|
|
else:
|
|
self.direction -= 1
|
|
self.image = pygame.transform.rotate(self.image, 90)
|
|
|
|
#checks if we can move further and if we won't get out of boundaries - for bfs:
|
|
def can_it_move_node(node):
|
|
if node.get_direction() == DIRECTION_EAST and node.get_x() + TILE_SIZE < 830: #last tile on the west has y:797
|
|
return "move east"
|
|
elif node.get_direction() == DIRECTION_WEST and node.get_x() - TILE_SIZE >=fieldX:
|
|
return "move west"
|
|
elif node.get_direction() == DIRECTION_NORTH and node.get_y() - TILE_SIZE >=fieldY:
|
|
return "move north"
|
|
elif node.get_direction() == DIRECTION_SOUTH and node.get_y() + TILE_SIZE < 760: #last tile on the south has y:727
|
|
return "move south"
|
|
else:
|
|
return False
|
|
|
|
|
|
#checks if there's an obstacle on the given coordinates (important for bfs):
|
|
def is_obstacle(self, x, y):
|
|
for tile in tiles:
|
|
if tile.x == x and tile.y == y:
|
|
ground = tile.ground
|
|
if ground.obstacle and self.tractor_start != (x, y) and self.tractor_end != (x,y):
|
|
return True
|
|
return False
|
|
|
|
|
|
def draw_tractor(self, win):
|
|
|
|
imageTractor = pygame.transform.scale(self.image, (TILE_SIZE, TILE_SIZE))
|
|
win.blit(imageTractor, (self.rect.x, self.rect.y))
|
|
pygame.display.flip()
|
|
|
|
#translates move_list generated by bfs into the actual movement:
|
|
def do_actions(tractor, WIN, move_list):
|
|
trail = pygame.image.load("resources/images/background.jpg").convert_alpha()
|
|
trail = pygame.transform.scale(trail, (TILE_SIZE, TILE_SIZE))
|
|
|
|
pygame.display.update()
|
|
for move in move_list:
|
|
WIN.blit(trail, (tractor.rect.x, tractor.rect.y, TILE_SIZE, TILE_SIZE))
|
|
if move == "move":
|
|
tractor.move()
|
|
elif move == "rotate_right":
|
|
tractor.rotate_to_right()
|
|
elif move == "rotate_left":
|
|
tractor.rotate_to_left()
|
|
tractor.draw_tractor(WIN)
|
|
pygame.display.update()
|
|
time.sleep(0.5)
|
|
|
|
#displays results of the "work_on_field" function next to the field:
|
|
def display_work_results(screen, text, position):
|
|
font = pygame.font.Font(None, 30)
|
|
displayed_text = font.render(text, 1, (255,255,255))
|
|
screen.blit(displayed_text, position)
|
|
pygame.display.update()
|
|
|
|
|