projects
/
koperkapel.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Merge branch 'master' of ctpug.org.za:koperkapel
[koperkapel.git]
/
koperkapel
/
scenes
/
level.py
diff --git
a/koperkapel/scenes/level.py
b/koperkapel/scenes/level.py
index 3b3b315fbbbeb9ac5e11308dd2b29690cfd6b0d6..379b8bf705e79ea32127a5681155a0ec28de585e 100644
(file)
--- a/
koperkapel/scenes/level.py
+++ b/
koperkapel/scenes/level.py
@@
-10,6
+10,7
@@
from .base import (
Scene, ChangeSceneEvent, MoveViewportEvent, WorldEvent, defer_to_update)
from ..constants import TILE_SIZE, WIDTH, HEIGHT
from ..gamelib.items import clone_old_item, create_new_item
Scene, ChangeSceneEvent, MoveViewportEvent, WorldEvent, defer_to_update)
from ..constants import TILE_SIZE, WIDTH, HEIGHT
from ..gamelib.items import clone_old_item, create_new_item
+from ..hud import HudActor
from ..roaches import build_roach
from ..vehicles.base import Vehicle
from ..weapons import weapon_by_name
from ..roaches import build_roach
from ..vehicles.base import Vehicle
from ..weapons import weapon_by_name
@@
-27,6
+28,13
@@
class PlayerStats:
return "<PlayerStats health=%d smart=%d fast=%d strong=%d>" % (
self.health, self.smart, self.fast, self.strong)
return "<PlayerStats health=%d smart=%d fast=%d strong=%d>" % (
self.health, self.smart, self.fast, self.strong)
+ def __eq__(self, other):
+ if not isinstance(other, PlayerStats):
+ return NotImplemented
+ return all(
+ (self.health == other.health, self.smart == other.smart,
+ self.fast == other.fast, self.strong == other.strong))
+
def _count_attr(self, attr, roaches):
attrs = [r[attr] for r in roaches]
attrs = [a for a in attrs if a]
def _count_attr(self, attr, roaches):
attrs = [r[attr] for r in roaches]
attrs = [a for a in attrs if a]
@@
-121,6
+129,9
@@
class GameLevelScene(BaseLevelScene):
self._items = self.actors.add_layer("items", level=9)
self._generators = self.actors.add_layer("enemy generators", level=8)
self._enemies = self.actors.add_layer("enemies", level=11)
self._items = self.actors.add_layer("items", level=9)
self._generators = self.actors.add_layer("enemy generators", level=8)
self._enemies = self.actors.add_layer("enemies", level=11)
+ self._hud = self.actors.add_layer("hud", level=12)
+ self._hud.add(HudActor(
+ self._stats, anchor=("right", "bottom"), pos=(WIDTH, HEIGHT)))
self._vehicle = Vehicle.current(world)
self._mode = 'walk'
self._angle = 0 # up
self._vehicle = Vehicle.current(world)
self._mode = 'walk'
self._angle = 0 # up
@@
-325,6
+336,7
@@
class GameLevelScene(BaseLevelScene):
bullet.game_pos[1] * TILE_SIZE + (TILE_SIZE // 2))
self._check_for_bullet_hits()
self._update_player_stats(world)
bullet.game_pos[1] * TILE_SIZE + (TILE_SIZE // 2))
self._check_for_bullet_hits()
self._update_player_stats(world)
+ self._hud[0].stats = self._stats
more = self._check_held_keys(dt)
if more:
events.extend(more)
more = self._check_held_keys(dt)
if more:
events.extend(more)