X-Git-Url: https://git.ctpug.org.za/?a=blobdiff_plain;f=koperkapel%2Fscenes%2Flevel.py;h=50ec80864287ebb325b47439d973520ec1c8f164;hb=e8bb29ef4dd7789bf9c20aebfb87f3911bb0d7b9;hp=e26d11dbe5e1b8858be77d3d8ef8b2f2186afdba;hpb=15f8404d39a46ec6243f2e75a0c03ba4e6294800;p=koperkapel.git diff --git a/koperkapel/scenes/level.py b/koperkapel/scenes/level.py index e26d11d..50ec808 100644 --- a/koperkapel/scenes/level.py +++ b/koperkapel/scenes/level.py @@ -4,10 +4,13 @@ from pgzero.constants import keys from pygame import Surface import pygame.locals as pgl from ..loaders.levelloader import levels -from .base import Scene, ChangeSceneEvent, MoveViewportEvent, WorldEvent, defer_to_update +from .base import ( + Scene, ChangeSceneEvent, MoveViewportEvent, WorldEvent, defer_to_update) from ..constants import TILE_SIZE, WIDTH, HEIGHT +from ..gamelib.items import clone_old_item from ..roaches import build_roach from ..vehicles.base import Vehicle +from ..weapons import weapon_by_name class BaseLevelScene(Scene): @@ -97,7 +100,8 @@ class GameLevelScene(BaseLevelScene): self._enemies = self.actors.add_layer("enemies", level=7) self._vehicle = Vehicle.current(world) self._mode = 'walk' - self._angle = 0 + self._angle = 0 # up + self._angle_dp = (0, -1) # up self._init_items() self._init_friendly_roaches() self._init_generators() @@ -115,8 +119,9 @@ class GameLevelScene(BaseLevelScene): def exit(self, world): for generator in self._generators: - # We don't want these running while we're on other levels, but we don't want to delete them - # here either (because of the vehicle management view) + # We don't want these running while we're on other levels, but we + # don't want to delete them here either (because of the vehicle + # management view) generator.pause() def _init_generators(self): @@ -143,14 +148,17 @@ class GameLevelScene(BaseLevelScene): def _can_move(self, x, y): if self._mode == 'walk': - return self._level.can_walk(x, y, self._level_layer) + if not self._level.enemy_at(x, y): + return self._level.can_walk(x, y, self._level_layer) + return False elif self._mode == 'fly': return self._level.can_fly(x, y, self._level_layer) elif self._mode == 'crawl': return self._level.can_crawl(x, y, self._level_layer) - def _set_angle(self, angle): + def _set_angle(self, angle, dp): self._angle = angle + self._angle_dp = dp self._avatar.angle = angle @defer_to_update @@ -160,13 +168,46 @@ class GameLevelScene(BaseLevelScene): self._avatar = self._vehicle.get_avatar(world) self._avatar.pos = (WIDTH // 2, HEIGHT // 2) self._roaches.add(self._avatar) - self._set_angle(self._angle) + self._set_angle(self._angle, self._angle_dp) @defer_to_update def _add_roach(self, world): world.roaches.append(build_roach(world)) self._vehicle_changed() + @defer_to_update + def _gain_item(self, world, item): + if item.item_type == "serum": + world.serums.append(item.item_data["serum"]) + elif item.item_type == "weapon": + old_weapon = world.weapons.current + world.weapons.current = item.item_data["weapon"] + if old_weapon != "spit": + clone = clone_old_item(item, weapon=old_weapon) + self._level.items.append(clone) + self._items.add(clone) + self._vehicle_changed() + + def _hit_enemy(self, enemy, weapon): + enemy.health -= weapon.damage + if enemy.health <= 0: + self._level.remove_enemy(enemy) + self._enemies.remove(enemy) + + @defer_to_update + def _fire_weapon(self, world): + weapon = weapon_by_name(world.weapons.current) + if weapon.bullet_range > 0: + # ranged, fire bullet + print("Pew.") + else: + # melee + pos, dp = self._player_pos, self._angle_dp + pos = (pos[0] + dp[0], pos[1] + dp[1]) + enemy = self._level.get_enemy(pos[0], pos[1]) + if enemy: + self._hit_enemy(enemy, weapon) + @defer_to_update def _change_vehicle(self, world): vehicle = Vehicle.random() @@ -182,11 +223,22 @@ class GameLevelScene(BaseLevelScene): for item in self._items: item.pos = self.calc_offset( item.game_pos[0] * TILE_SIZE, item.game_pos[1] * TILE_SIZE) + self._check_enemies() + for enemy in self._enemies: + enemy.pos = self.calc_offset( + enemy.game_pos[0] * TILE_SIZE, enemy.game_pos[1] * TILE_SIZE) more = self._check_held_keys(dt) if more: events.extend(more) return events + def _check_enemies(self): + if len(self._level.enemies) != len(self._enemies): + # New nemy has spawned + for enemy in self._level.enemies: + if enemy not in self._enemies: + self._enemies.add(enemy) + def _check_held_keys(self, dt): for key in self._held_keys: self._last_key_down += dt @@ -204,17 +256,18 @@ class GameLevelScene(BaseLevelScene): (keys.RIGHT, (1, 0), -90), ): if key == k: - if self._angle == angle and self._last_key_down > self._key_rate: + if (self._angle == angle and + self._last_key_down > self._key_rate): nx, ny = x + dp[0], y + dp[1] if self._can_move(nx, ny): self._set_pos(nx, ny) offset = (TILE_SIZE * dp[0], TILE_SIZE * dp[1]) - self._set_angle(angle) + self._set_angle(angle, dp) self._last_key_down = 0 return [MoveViewportEvent(offset)] else: # just turn - self._set_angle(angle) + self._set_angle(angle, dp) def _activate_key(self): x, y = self._player_pos @@ -239,6 +292,7 @@ class GameLevelScene(BaseLevelScene): item = self._level.item_at(x, y) self._level.remove_item(item) self._items.remove(item) + self._gain_item(item) elif self._level.is_exit(x, y): next_level = self._level.get_exit_level() return [ @@ -248,7 +302,7 @@ class GameLevelScene(BaseLevelScene): def _fire_key(self, dt): if self._last_key_down > self._key_rate: self._last_key_down = 0 - print('Boom') + self._fire_weapon() def _vehicle_management_key(self): from .roach_management import RoachesScene @@ -259,7 +313,8 @@ class GameLevelScene(BaseLevelScene): if key in (keys.DOWN, keys.UP, keys.LEFT, keys.RIGHT): self._held_keys.clear() self._held_keys.add(key) - # We do this so pressing the key has an instant effect, and can then be held + # We do this so pressing the key has an instant effect, and can + # then be held self._last_key_down = self._key_rate + 0.01 return self._movement_key(key, 0.01) elif key == keys.C: