projects
/
python-bulletml.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Bullet: Track previous X/Y.
[python-bulletml.git]
/
bulletml
/
impl.py
diff --git
a/bulletml/impl.py
b/bulletml/impl.py
index
a0ef92c
..
4dde9fb
100644
(file)
--- a/
bulletml/impl.py
+++ b/
bulletml/impl.py
@@
-18,7
+18,7
@@
class Action(object):
def __init__(self, owner, parent, actions, params, rank):
self.actions = actions
self.parent = parent
def __init__(self, owner, parent, actions, params, rank):
self.actions = actions
self.parent = parent
- self.repeat =
0
+ self.repeat =
1
self.wait_frames = 0
self.speed = 0
self.speed_frames = 0
self.wait_frames = 0
self.speed = 0
self.speed_frames = 0
@@
-40,10
+40,17
@@
class Action(object):
if parent:
self.copy_state(parent)
if parent:
self.copy_state(parent)
+ def __repr__(self):
+ return "%s(pc=%r, actions=%r)" % (
+ type(self).__name__, self.pc, self.actions)
+
+ @property
+ def finished(self):
+ return self.pc is None
+
def vanish(self):
if self.parent:
self.parent.vanish()
def vanish(self):
if self.parent:
self.parent.vanish()
- self.repeat = 0
self.pc = None
def copy_state(self, other):
self.pc = None
def copy_state(self, other):
@@
-64,6
+71,7
@@
class Action(object):
if self.speed_frames > 0:
self.speed_frames -= 1
self.owner.speed += self.speed
if self.speed_frames > 0:
self.speed_frames -= 1
self.owner.speed += self.speed
+
if self.direction_frames > 0:
self.direction_frames -= 1
if self.direction_frames <= 0:
if self.direction_frames > 0:
self.direction_frames -= 1
if self.direction_frames <= 0:
@@
-71,6
+79,7
@@
class Action(object):
self.owner.direction += self.owner.aim
else:
self.owner.direction += self.direction
self.owner.direction += self.owner.aim
else:
self.owner.direction += self.direction
+
if self.accel_frames > 0:
self.accel_frames -= 1
self.owner.mx += self.mx
if self.accel_frames > 0:
self.accel_frames -= 1
self.owner.mx += self.mx
@@
-85,13
+94,14
@@
class Action(object):
while True:
self.pc += 1
while True:
self.pc += 1
+
if self.pc >= len(self.actions):
self.repeat -= 1
if self.repeat <= 0:
self.pc = None
if self.parent is not None:
self.parent.copy_state(self)
if self.pc >= len(self.actions):
self.repeat -= 1
if self.repeat <= 0:
self.pc = None
if self.parent is not None:
self.parent.copy_state(self)
- self.owner.replace(self, self.parent)
+
self.owner.replace(self, self.parent)
break
else:
self.pc = 0
break
else:
self.pc = 0
@@
-229,8
+239,8
@@
class Bullet(object):
if rank is None:
rank = parent.rank if parent else 0.5
for action, params in actions:
if rank is None:
rank = parent.rank if parent else 0.5
for action, params in actions:
- self.actions.append(
-
Action(self, parent
, action, params, rank))
+ # New bullets reset the parent hierarchy.
+
self.actions.append(Action(self, None
, action, params, rank))
def __repr__(self):
return ("%s(%r, %r, accel=%r, direction=%r, speed=%r, "
def __repr__(self):
return ("%s(%r, %r, accel=%r, direction=%r, speed=%r, "
@@
-246,11
+256,14
@@
class Bullet(object):
return self.direction
else:
return math.degrees(
return self.direction
else:
return math.degrees(
- math.atan2(self.target.x - self.x, self.
target.y - self
.y))
+ math.atan2(self.target.x - self.x, self.
y - self.target
.y))
@property
def finished(self):
@property
def finished(self):
- return self.vanished and not self.actions
+ for action in self.actions:
+ if not action.finished:
+ return False
+ return self.vanished
def vanish(self):
"""Vanish this bullet and stop all actions."""
def vanish(self):
"""Vanish this bullet and stop all actions."""
@@
-270,14
+283,14
@@
class Bullet(object):
def step(self):
created = []
def step(self):
created = []
- self.actions = filter(None, self.actions)
-
for action in self.actions:
created.extend(action.step())
direction = math.radians(self.direction)
for action in self.actions:
created.extend(action.step())
direction = math.radians(self.direction)
+ self.px = self.x
+ self.py = self.y
self.x += self.mx + math.sin(direction) * self.speed
self.x += self.mx + math.sin(direction) * self.speed
- self.y += self.my
+
math.cos(direction) * self.speed
+ self.y += self.my
-
math.cos(direction) * self.speed
return created
return created