From a241ad8e874a2220d81254c2ebfbe69d0470fd9b Mon Sep 17 00:00:00 2001 From: standenboy Date: Fri, 19 Apr 2024 10:31:01 +0100 Subject: added a few bits --- comp/work/29/bg.png | Bin 0 -> 22176 bytes comp/work/29/game.py | 92 ++++++++++++++++++++++++++++++++++++++++++++++++ comp/work/29/player.png | Bin 0 -> 3370 bytes 3 files changed, 92 insertions(+) create mode 100644 comp/work/29/bg.png create mode 100644 comp/work/29/game.py create mode 100644 comp/work/29/player.png (limited to 'comp/work/29') diff --git a/comp/work/29/bg.png b/comp/work/29/bg.png new file mode 100644 index 0000000..ce9a4b9 Binary files /dev/null and b/comp/work/29/bg.png differ diff --git a/comp/work/29/game.py b/comp/work/29/game.py new file mode 100644 index 0000000..54e5b40 --- /dev/null +++ b/comp/work/29/game.py @@ -0,0 +1,92 @@ +import pygame + + +class entity: + def __init__(self, x, y, img, radius, color): + self.rotation = 0 + + self.radius = radius + self.pos = pygame.Vector2(x, y) + self.hitbox = pygame.Rect(x, y, radius*2, radius*2) + self.color = color + self.hitbox.x = x + self.hitbox.y = y + + self.sprite = pygame.image.load(img) + self.sprite = pygame.transform.scale(self.sprite, + (radius * 2, radius * 2)) + + self.hitbox.x = self.pos.x - self.radius + self.hitbox.y = self.pos.y - self.radius + + def move(self): + keys = pygame.key.get_pressed() + if keys[pygame.K_w]: + self.pos.y -= 300 * dt + if keys[pygame.K_s]: + self.pos.y += 300 * dt + if keys[pygame.K_a]: + self.pos.x -= 300 * dt + if keys[pygame.K_d]: + self.pos.x += 300 * dt + + while self.pos.x > 1280: + self.pos.x = self.pos.x - 1 + while self.pos.x < 0: + self.pos.x = self.pos.x + 1 + while self.pos.y > 720: + self.pos.y = self.pos.y - 1 + while self.pos.y < 0: + self.pos.y = self.pos.y + 1 + self.hitbox.x = self.pos.x - self.radius + self.hitbox.y = self.pos.y - self.radius + + def update(self, things, rot): + pass + def draw(self, debug): + screen.blit(self.sprite, self.pos) + if debug == 1: + pygame.draw.rect(screen, self.color, self.hitbox) + + def __collide(self, things): + for i in things: + if self.hitbox.colliderect(i.hitbox): + return i + + +pygame.init() +screen = pygame.display.set_mode((1280, 720)) +clock = pygame.time.Clock() +running = True +dt = 0 + +bg = pygame.image.load("./bg.png") +bg = pygame.transform.scale(bg, (1280, 720)) + +player = entity(screen.get_width() / 2, screen.get_height() / 2, + "./player.png", 40, "red") + +enemys = [] +for i in range(3): + enemys.append(entity(100, 100, "./player.png", 40, "blue")) + +while running: + for event in pygame.event.get(): + if event.type == pygame.QUIT: + running = False + + screen.blit(bg, (0, 0)) + + player.update(enemys, 1) + + player.move() + + player.draw(1) + for i in enemys: + i.draw(0) + + pygame.display.flip() + + dt = clock.tick(30) / 1000 + +pygame.quit() diff --git a/comp/work/29/player.png b/comp/work/29/player.png new file mode 100644 index 0000000..d258592 Binary files /dev/null and b/comp/work/29/player.png differ -- cgit v1.2.3