WMICraft/common/helpers.py

88 lines
3.3 KiB
Python
Raw Normal View History

2022-03-09 16:59:58 +01:00
import pygame
2022-05-25 19:47:08 +02:00
from common.constants import GRID_CELL_PADDING, GRID_CELL_SIZE, COLUMNS, ROWS, CLASSES, CLASS_TO_ID
import csv
import os
2022-03-09 16:59:58 +01:00
def draw_text(text, color, surface, x, y, text_size=30, is_bold=False):
if is_bold:
font = pygame.font.Font('resources/fonts/Poppins-SemiBold.ttf', text_size)
else:
font = pygame.font.Font('resources/fonts/Poppins-Regular.ttf', text_size)
textobj = font.render(text, 1, color)
textrect = textobj.get_rect()
textrect.topleft = (x, y)
surface.blit(textobj, textrect)
2022-04-11 00:01:57 +02:00
2022-05-18 10:29:05 +02:00
def createCSV():
train_data_path = './data/train'
test_data_path = './data/test'
2022-05-18 10:29:05 +02:00
if os.path.exists(train_data_path):
train_csvfile = open('./data/train_csv_file.csv', 'w', newline="")
writer = csv.writer(train_csvfile)
writer.writerow(["filepath", "type"])
2022-05-25 19:47:08 +02:00
for class_name in CLASSES:
2022-05-18 10:29:05 +02:00
class_dir = train_data_path + "/" + class_name
for filename in os.listdir(class_dir):
f = os.path.join(class_dir, filename)
if os.path.isfile(f):
2022-05-25 19:47:08 +02:00
writer.writerow([f, CLASS_TO_ID[class_name]])
2022-05-18 10:29:05 +02:00
train_csvfile.close()
else:
print("Brak plików do uczenia")
2022-05-25 19:47:08 +02:00
if os.path.exists(test_data_path):
2022-05-18 10:29:05 +02:00
test_csvfile = open('./data/test_csv_file.csv', 'w', newline="")
writer = csv.writer(test_csvfile)
writer.writerow(["filepath", "type"])
2022-05-25 19:47:08 +02:00
for class_name in CLASSES:
2022-05-18 10:29:05 +02:00
class_dir = test_data_path + "/" + class_name
for filename in os.listdir(class_dir):
f = os.path.join(class_dir, filename)
if os.path.isfile(f):
2022-05-25 19:47:08 +02:00
writer.writerow([f, CLASS_TO_ID[class_name]])
2022-05-18 10:29:05 +02:00
test_csvfile.close()
else:
print("Brak plików do testowania")
2022-04-11 00:01:57 +02:00
def print_numbers():
display_surface = pygame.display.get_surface()
font = pygame.font.SysFont('Arial', 16)
for row_index in range(ROWS):
for col_index in range(COLUMNS):
x = (GRID_CELL_PADDING + GRID_CELL_SIZE) * col_index + GRID_CELL_PADDING + 7
y = (GRID_CELL_PADDING + GRID_CELL_SIZE) * row_index + GRID_CELL_PADDING + 16
display_surface.blit(font.render(f'[{col_index}, {row_index}]', True, (255, 0, 0)), (x, y))
pygame.display.update()
# parse array index to screen x or y coordinate
def parse_cord(cord):
return (GRID_CELL_PADDING + GRID_CELL_SIZE) * cord + GRID_CELL_PADDING + 7
2022-04-11 12:56:22 +02:00
def castle_neighbors(map, castle_bottom_right_row, castle_bottom_right_col):
neighbors = []
for row_add in range(-2, 2):
new_row = castle_bottom_right_row + row_add
if 0 <= new_row <= len(map) - 1:
for col_add in range(-2, 2):
new_col = castle_bottom_right_col + col_add
if 0 <= new_col <= len(map) - 1:
if (new_col == castle_bottom_right_col - 1 and new_row == castle_bottom_right_row - 1) \
or (new_col == castle_bottom_right_col and new_row == castle_bottom_right_row - 1) \
or (new_col == castle_bottom_right_col - 1 and new_row == castle_bottom_right_row) \
or (new_col == castle_bottom_right_col and new_row == castle_bottom_right_row):
continue
neighbors.append((new_col, new_row))
return neighbors