X-Git-Url: https://git.ctpug.org.za/?p=koperkapel.git;a=blobdiff_plain;f=koperkapel%2Fscenes%2Flevel.py;h=c5a847b37de719da32810dd786ad36a7e78aa998;hp=b17beb61231f1e2d817fe411d529e8e52eb535bc;hb=8795602b8b39d5dce884310b11fc9b0a21263ddb;hpb=369d7e6130ef8fc63ae3688f3fe9e280243ca66d diff --git a/koperkapel/scenes/level.py b/koperkapel/scenes/level.py index b17beb6..c5a847b 100644 --- a/koperkapel/scenes/level.py +++ b/koperkapel/scenes/level.py @@ -7,7 +7,7 @@ from ..loaders.levelloader import levels 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 ..gamelib.items import clone_old_item, create_new_item from ..roaches import build_roach from ..vehicles.base import Vehicle from ..weapons import weapon_by_name @@ -231,8 +231,24 @@ class GameLevelScene(BaseLevelScene): @defer_to_update def _change_vehicle(self, world): - vehicle = Vehicle.random() - world.vehicles.current = vehicle + x, y = self._player_pos + + old_vehicle = world.vehicles.current + + item = self._level.item_at(x, y) + + if item and item.item_type == "vehicle": + world.vehicles.current = item.item_data["vehicle"] + self._level.remove_item(item) + self._items.remove(item) + else: + world.vehicles.current = "walking" + + if old_vehicle != "walking": + dropped_vehicle = create_new_item("vehicle", (x, y), vehicle=old_vehicle) + self._level.items.append(dropped_vehicle) + self._items.add(dropped_vehicle) + self._vehicle_changed() def update(self, world, engine, dt): @@ -316,9 +332,10 @@ class GameLevelScene(BaseLevelScene): self._add_roach() elif self._level.item_at(x, y): item = self._level.item_at(x, y) - self._level.remove_item(item) - self._items.remove(item) - self._gain_item(item) + if item.item_type != "vehicle": + 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 [