X-Git-Url: https://git.yukkurigames.com/?p=python-bulletml.git;a=blobdiff_plain;f=bulletml-runner;h=b98e9010c3ed4f9c8811871342e1fd191b900552;hp=7ad5addd678ada824c88385ed2a08d625ea90231;hb=bf5ff1d116840e1330c80894132919ec515596e4;hpb=2e2790231b49d4a2ed9299825ac0cf8121a655e2 diff --git a/bulletml-runner b/bulletml-runner index 7ad5add..b98e901 100755 --- a/bulletml-runner +++ b/bulletml-runner @@ -1,28 +1,50 @@ #!/usr/bin/env python +import os import sys +import time import pygame import bulletml +import bulletml.bulletyaml +from bulletml.collision import collides_all + +try: + import yaml +except ImportError: + yaml = None + +try: + import psyco +except ImportError: + pass +else: + psyco.full() def main(argv): + if not argv: + raise SystemExit("Usage: %s filename ..." % sys.argv[0]) + pygame.display.init() screen = pygame.display.set_mode([600, 600], pygame.DOUBLEBUF) - bullet = pygame.Surface([3, 3]) - bullet.fill([255, 0, 0]) - filename = argv[0] + red = pygame.Surface([3, 3]) + red.fill([255, 0, 0]) + green = pygame.Surface([3, 3]) + green.fill([0, 255, 0]) + blue = pygame.Surface([3, 3]) + blue.fill([0, 0, 255]) clock = pygame.time.Clock() target = bulletml.Bullet() - file_idx = 0 + bullets = dict(red=red, green=green, blue=blue) - if not argv: - raise SystemExit + file_idx = 0 while True: - doc = bulletml.BulletML(open(argv[file_idx % len(argv)], "rU")) - source = bulletml.Bullet.FromDoc( + filename = argv[file_idx % len(argv)] + doc = bulletml.BulletML.FromDocument(open(filename, "rU")) + source = bulletml.Bullet.FromDocument( doc, x=150, y=150, target=target, rank=0.5) active = set([source]) @@ -34,6 +56,8 @@ def main(argv): paused = False newfile = False + pygame.display.set_caption(os.path.basename(filename)) + while active and not newfile: go = False @@ -53,13 +77,23 @@ def main(argv): newfile = True elif event.key == pygame.K_RETURN: newfile = True + elif event.key == pygame.K_s: + actions = [act([], 0.5) for act in doc.actions] + source = bulletml.Bullet( + x=150, y=150, target=target, + actions=actions, rank=0.5) + source.vanished = True + active.add(source) target.x, target.y = pygame.mouse.get_pos() target.x /= 2 target.y /= 2 + target.y = 300 - target.y if not paused or go: - - for obj in list(active): + lactive = list(active) + start = time.time() + count = len(active) + for obj in lactive: new = obj.step() total += len(new) active.update(new) @@ -67,11 +101,19 @@ def main(argv): or not (-50 < obj.x < 350) or not (-50 < obj.y < 350)): active.remove(obj) + if lactive: + collides_all(lactive[0], lactive) + elapsed = time.time() - start frames += 1 if frames % 100 == 0: print " Processing: %04d: %d bullets, %d active." % ( - frames, total, len(active)) + frames, total, count) + if elapsed: + seconds_per_bullet = elapsed / count + bullets_per_second = count / elapsed + print " %g seconds per bullet (60Hz max: %g)." % ( + seconds_per_bullet, bullets_per_second / 60) screen.fill([0, 0, 0]) for obj in active: @@ -85,19 +127,10 @@ def main(argv): y *= 2 x -= 1 y -= 1 - screen.blit(bullet, [x, y]) - pygame.display.flip() - + bullet = bullets.get(obj.appearance, red) + screen.blit(bullet, [x, 600 - y]) clock.tick(60) - - for event in pygame.event.get(): - if event.type == pygame.QUIT: - raise SystemExit - elif event.type == pygame.KEYDOWN: - if event.key == pygame.K_SPACE: - paused ^= True - elif event.key == pygame.K_RIGHT: - go = True + pygame.display.flip() print " Finished: %04d: %d bullets." % (frames, total)