Skip to content

Commit

Permalink
Merge pull request #816 from otizonaizit/feature/tk-fullscreen
Browse files Browse the repository at this point in the history
Add a CLI option to run the pelita window in fullscreen
  • Loading branch information
Debilski authored Aug 8, 2024
2 parents 7ae3dd5 + 91f046d commit 232ad80
Show file tree
Hide file tree
Showing 5 changed files with 37 additions and 11 deletions.
14 changes: 9 additions & 5 deletions pelita/game.py
Original file line number Diff line number Diff line change
Expand Up @@ -34,17 +34,19 @@


class TkViewer:
def __init__(self, *, address, controller, geometry=None, delay=None, stop_after=None):
self.proc = self._run_external_viewer(address, controller, geometry=geometry, delay=delay, stop_after=stop_after)
def __init__(self, *, address, controller, geometry=None, delay=None, stop_after=None, fullscreen=False):
self.proc = self._run_external_viewer(address, controller, geometry=geometry, delay=delay, stop_after=stop_after, fullscreen=fullscreen)

def _run_external_viewer(self, subscribe_sock, controller, geometry, delay, stop_after):
def _run_external_viewer(self, subscribe_sock, controller, geometry, delay, stop_after, fullscreen):
# Something on OS X prevents Tk from running in a forked process.
# Therefore we cannot use multiprocessing here. subprocess works, though.
viewer_args = [ str(subscribe_sock) ]
if controller:
viewer_args += ["--controller-address", str(controller)]
if geometry:
viewer_args += ["--geometry", "{0}x{1}".format(*geometry)]
if fullscreen:
viewer_args += ["--fullscreen"]
if delay:
viewer_args += ["--delay", str(delay)]
if stop_after is not None:
Expand Down Expand Up @@ -236,12 +238,14 @@ def setup_viewers(viewers=None, options=None, print_result=True):
proc = TkViewer(address=zmq_publisher.socket_addr, controller=viewer_state['controller'].socket_addr,
stop_after=options.get('stop_at'),
geometry=options.get('geometry'),
delay=options.get('delay'))
delay=options.get('delay'),
fullscreen=options.get('fullscreen'))
else:
proc = TkViewer(address=zmq_publisher.socket_addr, controller=None,
stop_after=options.get('stop_at'),
geometry=options.get('geometry'),
delay=options.get('delay'))
delay=options.get('delay'),
fullscreen=options.get('fullscreen'))

else:
raise ValueError(f"Unknown viewer {viewer}.")
Expand Down
3 changes: 3 additions & 0 deletions pelita/scripts/pelita_main.py
Original file line number Diff line number Diff line change
Expand Up @@ -246,6 +246,8 @@ def long_help(s):
viewer_settings = parser.add_argument_group('Viewer settings')
viewer_settings.add_argument('--geometry', type=geometry_string, metavar='NxM',
help='Set initial size of the game window.')
viewer_settings.add_argument('--fullscreen', const=True, action='store_const',
help='Make the game window run fullscreen')
viewer_settings.add_argument('--fps', type=float, default=40,
help='Set (approximate) number of frames per second in a graphical viewer.')

Expand Down Expand Up @@ -359,6 +361,7 @@ def main():
stop_at = args.stop_at

viewer_options = {
"fullscreen" : args.fullscreen,
"geometry": geometry,
"delay": delay,
"stop_at": stop_at
Expand Down
3 changes: 3 additions & 0 deletions pelita/scripts/pelita_tkviewer.py
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,8 @@ def geometry_string(s):
help='controller address')
parser.add_argument('--geometry', type=geometry_string,
help='geometry')
parser.add_argument('--fullscreen', const=True, action='store_const',
help='fullscreen')
parser.add_argument('--delay', type=int,
help='delay')
parser.add_argument('--stop-after', type=int, metavar="N",
Expand All @@ -55,6 +57,7 @@ def main():
'address': args.subscribe_sock,
'controller_address': args.controller_address,
'geometry': args.geometry,
'fullscreen' : args.fullscreen,
'delay': args.delay,
'stop_after': args.stop_after
}
Expand Down
14 changes: 13 additions & 1 deletion pelita/ui/tk_canvas.py
Original file line number Diff line number Diff line change
Expand Up @@ -141,7 +141,7 @@ class UI:

class TkApplication:
def __init__(self, window, controller_address=None,
geometry=None, delay=1, stop_after=None):
geometry=None, delay=1, stop_after=None, fullscreen=False):
self.window = window
self.window.configure(background="white")

Expand All @@ -159,6 +159,8 @@ def __init__(self, window, controller_address=None,

self.mesh_graph = None
self.geometry = geometry
self.fullscreen = fullscreen
self._fullscreen_enabled = fullscreen

self._default_font = tkinter.font.nametofont("TkDefaultFont")
self._default_font_size = self._default_font.cget('size')
Expand Down Expand Up @@ -333,6 +335,7 @@ def __init__(self, window, controller_address=None,

self.running = True

self.window.bind('f', lambda event: self.toggle_fullscreen())
self.window.bind('q', lambda event: self.quit())
self.window.bind('<numbersign>', lambda event: self.toggle_grid())
self.window.bind('<greater>', lambda event: self.delay_dec())
Expand Down Expand Up @@ -578,6 +581,15 @@ def toggle_grid(self):
self._check_grid_toggle_state()
self.update()

def toggle_fullscreen(self):
self._fullscreen_enabled = not self._fullscreen_enabled
self.size_changed = True
if self._fullscreen_enabled:
self.window.attributes('-fullscreen',True)
else:
self.window.attributes('-fullscreen',False)
self.update()

def _check_grid_toggle_state(self):
if self._grid_enabled:
self.ui.button_game_toggle_grid.config(text="debug")
Expand Down
14 changes: 9 additions & 5 deletions pelita/ui/tk_viewer.py
Original file line number Diff line number Diff line change
Expand Up @@ -71,11 +71,12 @@ class TkViewer:
app : The TkApplication class
"""
def __init__(self, address, controller_address=None, geometry=None, delay=1, stop_after=None):
def __init__(self, address, controller_address=None, geometry=None, delay=1, stop_after=None, fullscreen=False):
self.address = address
self.controller_address = controller_address
self.delay = delay
self.geometry = geometry if geometry else (900, 580)
self.fullscreen = fullscreen
self.stop_after = stop_after

self.context = zmq.Context()
Expand All @@ -101,15 +102,18 @@ def run(self):
controller_socket.connect(self.controller_address)
controller_socket.send_json({"__action__": "exit"})
sys.exit(-1)
root_geometry = str(self.geometry[0])+'x'+str(self.geometry[1])
# put the root window in some sensible position
self.root.geometry(root_geometry+'+40+40')
if self.fullscreen:
self.root.attributes('-fullscreen',True)
else:
root_geometry = str(self.geometry[0])+'x'+str(self.geometry[1])
# put the root window in some sensible position
self.root.geometry(root_geometry+'+40+40')

self.app = TkApplication(window=self.root,
controller_address=self.controller_address,
geometry=self.geometry,
delay=self.delay,
stop_after=self.stop_after)
stop_after=self.stop_after, fullscreen=self.fullscreen)
# schedule next read
self.root.after_idle(self.read_queue)
try:
Expand Down

0 comments on commit 232ad80

Please sign in to comment.