X-Git-Url: http://git.tomasm.cz/imago.git/blobdiff_plain/702d0af1ff46776307fd8792e39bdd7c9f8273a9..c98a7fb2507b7ba3ee5f539bb6a7e356000a7f9c:/timer.py?ds=sidebyside diff --git a/timer.py b/timer.py index e1e247b..bc8a5c3 100755 --- a/timer.py +++ b/timer.py @@ -6,19 +6,45 @@ import os import sys import time import argparse +import subprocess import pygame class Timer: - def __init__(self): + def __init__(self, main_time, byop, byot): self._last = 0 self._elapsed = 0. + self._main_t = main_time + self.byost = "main time" + self._byop = byop + 1 + self._byot = byot + self._byo = False def get_time(self): - if self._last > 0: - return time.time() - self._last + self._elapsed - else: - return self._elapsed + if self._last > 0: # when running: + r_time = self._main_t - (time.time() - self._last + self._elapsed) + if (r_time - int(r_time)) < 0.75: + sep = ":" + else: + sep = " " + else: # not running: + if self._byo and self._byop > 0: + self._elapsed = 0 + r_time = self._main_t - self._elapsed + sep = ":" + if r_time < 0: + self._byo = True + self._main_t = self._byot + self._byop -= 1 + if self._byop > 0: + self._elapsed = 0 + self._last = time.time() + self.byost = "(" + str(self._byop) + ")" + return self.get_time() + else: + r_time = 0 + self.byost = "lost on time" + return "{0:0>2}".format(int(r_time / 60)) + sep + "{0:0>2}".format(int(r_time % 60)) def start(self): self._last = time.time() @@ -33,30 +59,61 @@ class Timer: else: return False +parser = argparse.ArgumentParser(description=__doc__) +parser.add_argument('-m', type=int, default=10, + help="main time in minutes (default is 10)") +parser.add_argument('-b', type=int, nargs=2, default=[5, 20], + help="japanese byoyomi: number of periods, period length in" + " seconds (default is 5 periods, 20 seconds)") +parser.add_argument('-c', '--camera', dest='cam', action='store_true', + help="camera on") +parser.add_argument('-d', type=int, default=0, + help="video device id") +parser.add_argument('-r', type=int, nargs=2, default=[640, 480], + help="set camera resolution") +args = parser.parse_args() + + pygame.init() -pygame.display.set_mode((400, 100)) +pygame.display.set_mode((600, 130)) pygame.display.set_caption("Go timer") screen = pygame.display.get_surface() clock = pygame.time.Clock() -font = pygame.font.Font(None, 50) +font = pygame.font.Font(pygame.font.match_font('monospace'), 80) +font2 = pygame.font.Font(None, 25) done = False first = True -timers = (Timer(), Timer()) +main_time = args.m * 60 -while not done: +timers = (Timer(main_time, args.b[0], args.b[1]), Timer(main_time, args.b[0], args.b[1])) +if args.cam: + capture = subprocess.Popen(['python', 'capture.py', '-c', '-d', str(args.d), '-r', + str(args.r[0]), + str(args.r[1])], stdin=subprocess.PIPE) +last = 0 + +while not done: for event in pygame.event.get(): if event.type == pygame.QUIT: done = True elif event.type == pygame.KEYDOWN: + if time.time() - last < 0.7: + continue + last = time.time() if first: timers[0].start() first = False + if args.cam: + print >> capture.stdin, "stop" + print >> capture.stdin, "take" continue + if args.cam: + print >> capture.stdin, "take" for timer in timers: if timer.is_running(): timer.stop() @@ -64,9 +121,16 @@ while not done: timer.start() screen.fill([0, 0, 0]) - text1 = font.render("{0:>6.2f}".format(timers[0].get_time()), True, [128, 255, 128]) + text1 = font.render(timers[0].get_time(), True, [128, 255, 128]) screen.blit(text1, [10, 10]) - text2 = font.render("{0:>6.2f}".format(timers[1].get_time()), True, [128, 255, 128]) - screen.blit(text2, [200, 10]) + text2 = font.render(timers[1].get_time(), True, [128, 255, 128]) + screen.blit(text2, [300, 10]) + text3 = font2.render(timers[0].byost, True, [128, 255, 128]) + screen.blit(text3, [10, 90]) + text4 = font2.render(timers[1].byost, True, [128, 255, 128]) + screen.blit(text4, [300, 90]) pygame.display.flip() clock.tick(15) + +if args.cam: + print >> capture.stdin, "exit"