2021-04-03 00:16:53 +02:00
|
|
|
import definitions
|
2021-03-21 12:40:13 +01:00
|
|
|
class Plant:
|
2021-03-27 21:31:22 +01:00
|
|
|
def __init__(self, name, state):
|
2021-04-03 11:24:39 +02:00
|
|
|
self.name = name #nazwa rośliny np. "wheat"
|
|
|
|
self.state = state #etap rozwoju rośliny
|
2021-03-27 21:31:22 +01:00
|
|
|
def get_name(self):
|
|
|
|
return self.name
|
|
|
|
def set_name(self, name):
|
|
|
|
self.name = name
|
2021-03-23 17:14:46 +01:00
|
|
|
def get_state(self):
|
|
|
|
return self.state
|
|
|
|
def set_state(self, state):
|
2021-04-03 00:16:53 +02:00
|
|
|
self.state = state
|
2021-04-10 19:16:34 +02:00
|
|
|
@staticmethod
|
|
|
|
def get_closest_mature_plant(map1, tractor1):
|
|
|
|
x = -1
|
|
|
|
y = -1
|
|
|
|
min = definitions.WIDTH_AMOUNT + definitions.HEIGHT_AMOUNT + 1
|
|
|
|
for i in range(definitions.WIDTH_AMOUNT):
|
|
|
|
for j in range(definitions.HEIGHT_AMOUNT):
|
|
|
|
field = map1.get_fields()[i][j]
|
|
|
|
if field.get_plant().get_name() == "beetroot" and field.get_plant().get_state() == definitions.BEETROOTS_MAXIMUM_STATE: #and abs(tractor1.get_x() - i) + abs(tractor1.get_y() - j) < min:
|
|
|
|
x = i
|
|
|
|
y = j
|
|
|
|
min = abs(tractor1.get_x() - i) + abs(tractor1.get_y() - j)
|
|
|
|
elif field.get_plant().get_name() == "carrot" and field.get_plant().get_state() == definitions.CARROTS_MAXIMUM_STATE: #and abs(tractor1.get_x() - i) + abs(tractor1.get_y() - j) < min:
|
|
|
|
x = i
|
|
|
|
y = j
|
|
|
|
min = abs(tractor1.get_x() - i) + abs(tractor1.get_y() - j)
|
|
|
|
elif field.get_plant().get_name() == "potato" and field.get_plant().get_state() == definitions.POTATOES_MAXIMUM_STATE: #and abs(tractor1.get_x() - i) + abs(tractor1.get_y() - j) < min:
|
|
|
|
x = i
|
|
|
|
y = j
|
|
|
|
min = abs(tractor1.get_x() - i) + abs(tractor1.get_y() - j)
|
|
|
|
elif field.get_plant().get_name() == "wheat" and field.get_plant().get_state() == definitions.WHEAT_MAXIMUM_STATE: #and abs(tractor1.get_x() - i) + abs(tractor1.get_y() - j) < min:
|
|
|
|
x = i
|
|
|
|
y = j
|
|
|
|
min = abs(tractor1.get_x() - i) + abs(tractor1.get_y() - j)
|
|
|
|
if x == -1 and y == -1:
|
|
|
|
return False
|
|
|
|
else:
|
|
|
|
return x, y
|
2021-04-03 00:16:53 +02:00
|
|
|
@staticmethod
|
2021-04-03 11:24:39 +02:00
|
|
|
def grow_plants(map1): #metoda statyczna, która zwiększa pole state (etap rozwoju rośliny) dla danej rośliny na danym polu o 1
|
2021-04-03 00:16:53 +02:00
|
|
|
for i in range(definitions.WIDTH_AMOUNT):
|
|
|
|
for j in range(definitions.HEIGHT_AMOUNT):
|
|
|
|
field = map1.get_fields()[i][j]
|
|
|
|
if field.get_plant().get_name() == "beetroot" and field.get_plant().get_state() > 0 and field.get_plant().get_state() < definitions.BEETROOTS_MAXIMUM_STATE:
|
|
|
|
field.get_plant().set_state(field.get_plant().get_state() + 1)
|
|
|
|
elif field.get_plant().get_name() == "carrot" and field.get_plant().get_state() > 0 and field.get_plant().get_state() < definitions.CARROTS_MAXIMUM_STATE:
|
|
|
|
field.get_plant().set_state(field.get_plant().get_state() + 1)
|
|
|
|
elif field.get_plant().get_name() == "potato" and field.get_plant().get_state() > 0 and field.get_plant().get_state() < definitions.POTATOES_MAXIMUM_STATE:
|
|
|
|
field.get_plant().set_state(field.get_plant().get_state() + 1)
|
|
|
|
elif field.get_plant().get_name() == "wheat" and field.get_plant().get_state() > 0 and field.get_plant().get_state() < definitions.WHEAT_MAXIMUM_STATE:
|
|
|
|
field.get_plant().set_state(field.get_plant().get_state() + 1)
|