poprawiony ruch smieciarki

This commit is contained in:
Adam Osiowy 2020-04-17 13:56:29 +02:00
parent 9a9cf3e8cb
commit 28c415bf6a
2 changed files with 74 additions and 63 deletions

31
game.py
View File

@ -5,7 +5,6 @@ import random
import os import os
import shutil import shutil
pygame.init() pygame.init()
# kolory # kolory
@ -40,6 +39,11 @@ smieciarka = modele.Smieciarka(10, 10)
plansza[10, 10].setKolor(BLUE) plansza[10, 10].setKolor(BLUE)
plansza[10, 10].setObiekt(smieciarka) plansza[10, 10].setObiekt(smieciarka)
# tworzenie wyswietlanego okna
obraz = pygame.display.set_mode(WINDOW_SIZE)
smieciarka.setObraz(obraz)
pygame.display.set_caption("Inteligentna śmieciarka")
# kontenery # kontenery
if os.path.exists('resources/smieci w kontenerach'): if os.path.exists('resources/smieci w kontenerach'):
shutil.rmtree("resources/smieci w kontenerach") shutil.rmtree("resources/smieci w kontenerach")
@ -76,11 +80,9 @@ plansza[4, 4].setJestKontenerem(True)
plansza[4, 4].setObiekt(kontener_szklo) plansza[4, 4].setObiekt(kontener_szklo)
# domy # domy
doms_array = ['resources/plansza/domy/dom1.png', 'resources/plansza/domy/dom2.png', doms_array = ['resources/plansza/domy/dom1.png', 'resources/plansza/domy/dom2.png',
'resources/plansza/domy/dom3.png', 'resources/plansza/domy/dom4.png', 'resources/plansza/domy/dom5.png'] 'resources/plansza/domy/dom3.png', 'resources/plansza/domy/dom4.png', 'resources/plansza/domy/dom5.png']
wspolrzedne_domow = modele.generujWspolrzedneDomow(10)
domy_lista = pygame.sprite.Group() domy_lista = pygame.sprite.Group()
smieci_lista = [os.path.join(path, filename) smieci_lista = [os.path.join(path, filename)
@ -123,6 +125,7 @@ def liczSmieci(domy):
return text_metal, text_papier, text_plastik, text_szklo, text_pozostale, text_odwiedzone_domy return text_metal, text_papier, text_plastik, text_szklo, text_pozostale, text_odwiedzone_domy
wspolrzedne_domow = modele.generujWspolrzedneDomow(10)
for i in range(len(wspolrzedne_domow)): for i in range(len(wspolrzedne_domow)):
dom = modele.Dom(wspolrzedne_domow[i][0], wspolrzedne_domow[i][1]) dom = modele.Dom(wspolrzedne_domow[i][0], wspolrzedne_domow[i][1])
dom.setImage(pygame.image.load(random.choice(doms_array))) dom.setImage(pygame.image.load(random.choice(doms_array)))
@ -154,15 +157,8 @@ all_sprites_list.add(kontener_plastik, kontener_metal, kontener_organiczne, kont
def game(): def game():
obraz = pygame.display.set_mode(WINDOW_SIZE)
# Tytul okienka
pygame.display.set_caption("Inteligentna śmieciarka")
# Petla az uzytkownik zamknie program # Petla az uzytkownik zamknie program
done = False done = False
fpsClock = pygame.time.Clock()
# -------- Glowna petla programu ----------- # -------- Glowna petla programu -----------
while not done: while not done:
@ -178,10 +174,8 @@ def game():
# Zamiana pozycji na konkretne koordy # Zamiana pozycji na konkretne koordy
kolumna = pozycja_myszki[0] // (WIDTH + MARGIN) kolumna = pozycja_myszki[0] // (WIDTH + MARGIN)
wiersz = pozycja_myszki[1] // (HEIGHT + MARGIN) wiersz = pozycja_myszki[1] // (HEIGHT + MARGIN)
print("Click ", pozycja_myszki, print("Click ", pozycja_myszki,
"Grid coordinates: ", wiersz, kolumna) "Grid coordinates: ", wiersz, kolumna)
elif event.type == pygame.KEYDOWN: elif event.type == pygame.KEYDOWN:
if event.key == pygame.K_LEFT: if event.key == pygame.K_LEFT:
smieciarka.w_lewo() smieciarka.w_lewo()
@ -192,12 +186,12 @@ def game():
if event.key == pygame.K_DOWN: if event.key == pygame.K_DOWN:
smieciarka.w_dol() smieciarka.w_dol()
# Odswiezanie 5 klatek na sekunde smieciarka.rand_move()
fpsClock.tick(5) pygame.quit()
# czarny kolor w tle
def rysowaniePlanszy():
obraz.fill(BLACK) obraz.fill(BLACK)
# rysowanie planszy # rysowanie planszy
for i in range(ILOSC_WIERSZY): for i in range(ILOSC_WIERSZY):
for j in range(ILOSC_KOLUMN): for j in range(ILOSC_KOLUMN):
@ -218,8 +212,6 @@ def game():
plansza[7, 10].setJestPrzeszkoda(True) plansza[7, 10].setJestPrzeszkoda(True)
plansza[7, 11].setJestPrzeszkoda(True) plansza[7, 11].setJestPrzeszkoda(True)
all_sprites_list.draw(obraz) all_sprites_list.draw(obraz)
smieciarka.rand_move()
text_metal, text_papier, text_plastik, text_szklo, text_pozostale, text_odwiedzone_domy = liczSmieci( text_metal, text_papier, text_plastik, text_szklo, text_pozostale, text_odwiedzone_domy = liczSmieci(
lista_domow) lista_domow)
obraz.blit(text_pozostalo, obraz.blit(text_pozostalo,
@ -231,5 +223,4 @@ def game():
obraz.blit(text_pozostale, (1020, 440)) obraz.blit(text_pozostale, (1020, 440))
obraz.blit(text_odwiedzone_domy, (1020, 480)) obraz.blit(text_odwiedzone_domy, (1020, 480))
pygame.display.flip() pygame.display.update()
pygame.quit()

View File

@ -25,6 +25,7 @@ class Smieciarka(pygame.sprite.Sprite):
self.x = x self.x = x
self.y = y self.y = y
self.image = pygame.image.load('resources/plansza/smieciarka.png') self.image = pygame.image.load('resources/plansza/smieciarka.png')
self.obraz = None
self.ruch = 0 self.ruch = 0
self.plastik = [] self.plastik = []
self.szklo = [] self.szklo = []
@ -37,6 +38,9 @@ class Smieciarka(pygame.sprite.Sprite):
self.rect = pygame.Rect(self.x * WIDTH + MARGIN * self.x + MARGIN, self.y * HEIGHT + MARGIN * self.y, WIDTH, self.rect = pygame.Rect(self.x * WIDTH + MARGIN * self.x + MARGIN, self.y * HEIGHT + MARGIN * self.y, WIDTH,
HEIGHT) HEIGHT)
def setObraz(self, obraz):
self.obraz = obraz
def rand_move(self): def rand_move(self):
rand_int = random.randint(0, 3) rand_int = random.randint(0, 3)
if rand_int == 0: if rand_int == 0:
@ -54,14 +58,18 @@ class Smieciarka(pygame.sprite.Sprite):
if game.plansza[self.x - 1, self.y].jestDomem is True: if game.plansza[self.x - 1, self.y].jestDomem is True:
if [self.x - 1, self.y] not in self.wspolrzedne_odwiedzonych_domow: if [self.x - 1, self.y] not in self.wspolrzedne_odwiedzonych_domow:
self.wspolrzedne_odwiedzonych_domow.append([self.x - 1, self.y]) self.wspolrzedne_odwiedzonych_domow.append([self.x - 1, self.y])
#print(self.wspolrzedne_odwiedzonych_domow)
self.zwiekszIloscOdwiedzonychDomow() self.zwiekszIloscOdwiedzonychDomow()
self.x -= 1
game.plansza[self.x, self.y].setKolor(BLUE)
self.rect.x = MARGIN + self.x * WIDTH + self.x * MARGIN
if self.ruch == 2: if self.ruch == 2:
self.image = pygame.image.load( self.image = pygame.image.load(
'resources/plansza/smieciarka.png') 'resources/plansza/smieciarka.png')
for i in range((WIDTH + MARGIN) // 1):
self.rect.x -= 1
self.obraz.blit(self.image, (self.rect.x, self.rect.y))
game.rysowaniePlanszy()
self.x -= 1
game.plansza[self.x, self.y].setKolor(BLUE)
self.ruch = 1 self.ruch = 1
def w_prawo(self): def w_prawo(self):
@ -70,13 +78,17 @@ class Smieciarka(pygame.sprite.Sprite):
if game.plansza[self.x + 1, self.y].jestDomem is True: if game.plansza[self.x + 1, self.y].jestDomem is True:
if [self.x + 1, self.y] not in self.wspolrzedne_odwiedzonych_domow: if [self.x + 1, self.y] not in self.wspolrzedne_odwiedzonych_domow:
self.wspolrzedne_odwiedzonych_domow.append([self.x + 1, self.y]) self.wspolrzedne_odwiedzonych_domow.append([self.x + 1, self.y])
#print(self.wspolrzedne_odwiedzonych_domow)
self.zwiekszIloscOdwiedzonychDomow() self.zwiekszIloscOdwiedzonychDomow()
self.x += 1
game.plansza[self.x, self.y].setKolor(BLUE)
self.rect.x = MARGIN + self.x * WIDTH + self.x * MARGIN
if self.ruch == 1: if self.ruch == 1:
self.image = pygame.transform.flip(self.image, True, False) self.image = pygame.transform.flip(self.image, True, False)
for i in range((WIDTH + MARGIN) // 1):
self.rect.x += 1
self.obraz.blit(self.image, (self.rect.x, self.rect.y))
game.rysowaniePlanszy()
self.x += 1
game.plansza[self.x, self.y].setKolor(BLUE)
self.ruch = 2 self.ruch = 2
def w_gore(self): def w_gore(self):
@ -85,11 +97,15 @@ class Smieciarka(pygame.sprite.Sprite):
if game.plansza[self.x, self.y - 1].jestDomem is True: if game.plansza[self.x, self.y - 1].jestDomem is True:
if [self.x, self.y - 1] not in self.wspolrzedne_odwiedzonych_domow: if [self.x, self.y - 1] not in self.wspolrzedne_odwiedzonych_domow:
self.wspolrzedne_odwiedzonych_domow.append([self.x, self.y - 1]) self.wspolrzedne_odwiedzonych_domow.append([self.x, self.y - 1])
#print(self.wspolrzedne_odwiedzonych_domow)
self.zwiekszIloscOdwiedzonychDomow() self.zwiekszIloscOdwiedzonychDomow()
for i in range((WIDTH + MARGIN) // 1):
self.rect.y -= 1
self.obraz.blit(self.image, (self.rect.x, self.rect.y))
game.rysowaniePlanszy()
self.y -= 1 self.y -= 1
game.plansza[self.x, self.y].setKolor(BLUE) game.plansza[self.x, self.y].setKolor(BLUE)
self.rect.y = self.y * HEIGHT + self.y * MARGIN
def w_dol(self): def w_dol(self):
if self.y < 14: if self.y < 14:
@ -97,11 +113,15 @@ class Smieciarka(pygame.sprite.Sprite):
if game.plansza[self.x, self.y + 1].jestDomem is True: if game.plansza[self.x, self.y + 1].jestDomem is True:
if [self.x, self.y + 1] not in self.wspolrzedne_odwiedzonych_domow: if [self.x, self.y + 1] not in self.wspolrzedne_odwiedzonych_domow:
self.wspolrzedne_odwiedzonych_domow.append([self.x, self.y + 1]) self.wspolrzedne_odwiedzonych_domow.append([self.x, self.y + 1])
#print(self.wspolrzedne_odwiedzonych_domow)
self.zwiekszIloscOdwiedzonychDomow() self.zwiekszIloscOdwiedzonychDomow()
for i in range((WIDTH + MARGIN) // 1):
self.rect.y += 1
self.obraz.blit(self.image, (self.rect.x, self.rect.y))
game.rysowaniePlanszy()
self.y += 1 self.y += 1
game.plansza[self.x, self.y].setKolor(BLUE) game.plansza[self.x, self.y].setKolor(BLUE)
self.rect.y = self.y * HEIGHT + self.y * MARGIN
def dodajPlastik(self, smiec): def dodajPlastik(self, smiec):
self.plastik.append(smiec) self.plastik.append(smiec)