Add grid drawing, scaling, camera movements

This commit is contained in:
shiva404
2026-02-14 00:57:26 +03:00
parent d7184ddab1
commit d596101bd2
3 changed files with 40 additions and 24 deletions

View File

@@ -12,38 +12,47 @@ class Cell:
#creature_obj: any #creature_obj: any
is_target: bool = False is_target: bool = False
def draw(self, screen, bord_color, x, y, size, bord_size): @dataclass
pygame.draw.rect(screen, bord_color, pygame.Rect(x, y, size, size), bord_size)
class Map: class Map:
def __init__(self, name, cell_color = "gray57", active_cell_color = "gray57"): name: str
self.name = name cells: dict = None
color: str = "gray57"
target_color: str = "gold"
size: int = 150
bord: int = 5
scale: float = 1
cam_x: int = 0
cam_y: int = 0
cell_dist: int = 2
def __post_init__(self):
self.cells = {} self.cells = {}
with open(self.name, 'r') as file: with open(self.name, 'r') as file:
buff = json.load(file) buff = json.load(file)
for line in range(len(buff)): for line in range(len(buff)):
self.cells[line] = [] self.cells[line] = []
for cell in buff[str(line)]: for cell in buff[str(line)]:
final_cell = Cell(cell_classes[cell["type"]](**cell["cell"]["terrain_obj"])) final_cell = Cell(cell_classes[cell["type"]](**cell["cell"]["terrain_obj"]))
self.cells[line].append(deepcopy(final_cell)) self.cells[line].append(deepcopy(final_cell))
self.cell_color = cell_color
def draw(self, scale_size):
for line in range(len(self.cells)):
for cell in line:
pass
def draw(self, screen):
for l in range(len(self.cells)):
for i, cell in enumerate(self.cells[l]):
x = int((i * self.size + self.cam_x) * self.scale)
y = int((l * self.size + self.cam_y) * self.scale)
w = int(self.size * self.scale - self.cell_dist)
h = int(self.size * self.scale - self.cell_dist)
pygame.draw.rect(screen, self.color, pygame.Rect(x, y, w, h), self.bord)
class Engine: class Engine:
def __init__(self, width, height, scale_size = 5, camera_pos = pygame.Vector2(0, 0)): def __init__(self, width, height, scale_size = 5, camera_pos = pygame.Vector2(0, 0)):
self.width = width self.width = width
self.height = height self.height = height
self.scale_size = scale_size self.scale_size = scale_size
self.camera_pos = camera_pos
def main_loop(self):
def main_loop(self):
''' '''
#o = eb_terrain.Ground(1, 1, 1) #o = eb_terrain.Ground(1, 1, 1)
#c = eb_creatures.Unit(1, 1, 1) #c = eb_creatures.Unit(1, 1, 1)
@@ -52,8 +61,7 @@ class Engine:
#print(isinstance(c, eb_objects.Terrain)) #print(isinstance(c, eb_objects.Terrain))
''' '''
easy_map = Map("def_map.json", "gray57") easy_map = Map("def_map.json")
print(1)
# pygame setup # pygame setup
pygame.init() pygame.init()
@@ -61,6 +69,8 @@ class Engine:
clock = pygame.time.Clock() clock = pygame.time.Clock()
running = True running = True
dt = 0 dt = 0
camera_step = 10
scale_step = 0.1
player_pos = pygame.Vector2(screen.get_width() / 2, screen.get_height() / 2) player_pos = pygame.Vector2(screen.get_width() / 2, screen.get_height() / 2)
@@ -74,19 +84,24 @@ class Engine:
# fill the screen with a color to wipe away anything from last frame # fill the screen with a color to wipe away anything from last frame
screen.fill("chartreuse4") screen.fill("chartreuse4")
#pygame.draw.circle(screen, "gray57", player_pos, 40) easy_map.draw(screen)
keys = pygame.key.get_pressed() keys = pygame.key.get_pressed()
if keys[pygame.K_w]: if keys[pygame.K_w]:
player_pos.y -= 300 * dt easy_map.cam_y -= camera_step
if keys[pygame.K_s]: if keys[pygame.K_s]:
player_pos.y += 300 * dt easy_map.cam_y += camera_step
if keys[pygame.K_a]: if keys[pygame.K_a]:
player_pos.x -= 300 * dt easy_map.cam_x -= camera_step
if keys[pygame.K_d]: if keys[pygame.K_d]:
player_pos.x += 300 * dt easy_map.cam_x += camera_step
if keys[pygame.K_q]:
easy_map.scale += scale_step
if keys[pygame.K_e]:
easy_map.scale -= scale_step
# flip() the display to put your work on screen # flip() the display to put your work on screen
#pygame.time.wait(20)
pygame.display.flip() pygame.display.flip()
# limits FPS to 60 # limits FPS to 60
@@ -94,4 +109,5 @@ class Engine:
# independent physics. # independent physics.
dt = clock.tick(60) / 1000 dt = clock.tick(60) / 1000
pygame.quit() pygame.quit()

View File

@@ -1,13 +1,13 @@
import eb_engine import eb_engine
def main(): def main():
e = eb_engine.Engine(1280, 720) e = eb_engine.Engine(1600, 900)
e.main_loop() e.main_loop()
if __name__ == "__main__": if __name__ == "__main__":
# pydantic instead of dataclasses? # pydantic instead of dataclasses?
# Отрисовка голой сетки, прокрутка # Отрисовка голой сетки, прокрутка, масштаб +
# Отрисовка спрайтов, масштаб # Отрисовка спрайтов
# Начало гуя - кнопка, строка ввода, клик # Начало гуя - кнопка, строка ввода, клик
# Поиск пути # Поиск пути
# Редактор карты # Редактор карты