Skip to main content

Interface for controlling PowerPoint slideshows over WebSocket/HTTP

Project description

ppt-control

An interface for controlling PowerPoint slideshows over the network using WebSocket. With the included HTTP frontend, this package can essentially replicate PowerPoint's presenter view on any computer on the local network, with very low processing latency for commands.

This was originally designed for controlling a PowerPoint slideshow from an instance of OBS (Open Broadcaster Software) running on the same computer (removing the need for an extra monitor to show presenter view).

This package includes three main components:

  1. The daemon, which runs in the background, independently of PowerPoint, and listens for WebSocket commands and hosts an HTTP server for the frontend
  2. The HTTP frontend, written in JavaScript, which displays status information and sends commands to the daemon through WebSocket (this can be docked in one of OBS's "custom browser docks")
  3. The OBS script, which allows a mapping of keyboard shortcuts to commands within OBS in order to control the slideshow from anywhere in OBS (keyboard shortcuts are implemented in the HTTP interface but only work when this is focused in OBS)

Requirements

Due to the implementation's use of pywin32 for COM communication, this daemon only works on Windows (but the HTTP and WebSocket interfaces can be accessed from any device).

The server and the OBS script are written for Python 3.6, since at the time of writing, OBS only supports 3.6 for scripts. The source module for the built-in HTTP server from 3.9 is included in this project, since the 3.6 module does not allow for setting a custom server root (this feature was introduced in 3.7). If you are not using the OBS script (or if you don't mind dealing with multiple versions of Python on the same system), the daemon should work fine on 3.9 in theory, but this is not fully tested. When OBS eventually provides support for >=3.7, this package will be updated to use the native HTTP server module, and support for pre-3.7 will be dropped.

This package also requires pywin32, websockets and pystray (all three are required for the server, but only websockets is required for the OBS script).

Installation

pip install ppt-control

will install all three components. You can then start the daemon by running

python -m ppt_control

from a command prompt (note the underscore). On first run, Windows Defender will show a warning and attempt to block Python from starting the server. You can safely allow the program through the firewall. You can now start a PowerPoint slideshow and navigate to the server by IP address/hostname (http://localhost if on the same machine) and control the slideshow.

There are a few steps to set the package up fully:

Starting the daemon at bootup

There are several ways to start a Python program at login. Here is one method:

  1. Navigate to the directory containing the pythonw executable in Explorer (usually in C:\Program Files\Python36 - run python -c "import sys, print(sys.executable)" to check)
  2. Right click on pythonw.exe and click "Create shortcut"
  3. Windows will ask you whether to place a shortcut on the desktop - click yes. Go to the properties of this shortcut, and in the target field, append -m ppt_control (after the quotes, including an initial space). You can also change the name and icon of the shortcut if you like.
  4. Copy this shortcut into the Startup folder (%AppData%\Microsoft\Windows\Start Menu\Programs\Startup). To quickly navigate to this folder, open an Explorer window and type startup in the address bar.

Using the HTTP interface in OBS

To view the HTTP interface from within OBS, you can add a "custom browser dock" (View -> Docks -> Custom Browser Docks). The location should be the hostname and port number of the daemon (http://localhost by default). You can refresh the custom browser dock with Ctrl+R.

Global keyboard shortcuts in OBS

Keyboard shortcuts in OBS browser docks only work when the browser dock is focused by clicking in it (there is actually no indication of focus in the interface, but if you click away from the browser dock the shortcuts will not work). To resolve this, there is another Python script called ppt_control_obs.py which can be added as a custom script in OBS. This script will listen for specific keys (configured in OBS's Hotkeys settings) and send commands to the daemon directly over WebSocket (no HTTP involved). To add the custom script, go to Tools -> Scripts, then click the + and choose the script. This will be located in the package directory which can be found with

pip show ppt-control

It is a good idea to turn off the keyboard shortcuts in the HTTP interface after loading the OBS hotkey script, otherwise commands will be sent to the daemon twice when the browser dock is focused.

Configuration

Various settings can be changed in %AppData%\ppt-control\ppt-control.ini. This file is populated with the defaults for all possible settings at installation.

Todo

  • ✔️ Fix multiple-presentation support in JS & OBS clients
  • Create desktop/start menu shortcuts on installation with pip
  • Refactor/tidy JS code
  • Fix "RCP server unavailable" error on server
  • ✔️ Config documentation
  • ✔️ Re-implement last slide behaviour
  • ✔️ Re-implement black white behaviour
  • ✔️ JS client show status on last slide
  • ✔️ Shortcut to edit config in systray menu
  • Export all slides on presentation init
  • Abstract pres name in class & underscore presentation instance
  • Check assertions
  • Use __debug__ flag
  • Make constant for static dir
  • Comment sys.coinitflags
  • Die if error in run_ws or run_http

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ppt-control-0.0.4.tar.gz (76.7 kB view details)

Uploaded Source

Built Distribution

ppt_control-0.0.4-py3-none-any.whl (92.1 kB view details)

Uploaded Python 3

File details

Details for the file ppt-control-0.0.4.tar.gz.

File metadata

  • Download URL: ppt-control-0.0.4.tar.gz
  • Upload date:
  • Size: 76.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.5.0 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.6.8

File hashes

Hashes for ppt-control-0.0.4.tar.gz
Algorithm Hash digest
SHA256 b57ae1a863fdf43b2dfd7ac8a9978fefd0eb5195c0cb6674892f523c7a511172
MD5 04d1f417bc6675c2a61e212a4eb76d10
BLAKE2b-256 5202f4cf57ca2c84a9e4fac7509b559de86e0a3dcefa1459dd18eb9f2f1238ae

See more details on using hashes here.

File details

Details for the file ppt_control-0.0.4-py3-none-any.whl.

File metadata

  • Download URL: ppt_control-0.0.4-py3-none-any.whl
  • Upload date:
  • Size: 92.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.5.0 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.6.8

File hashes

Hashes for ppt_control-0.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 3b108b8a4c7c10fcd2cc613eeb287e41247a80ed28218dcf11d8ca490eee8e58
MD5 ad86397c390722d96d94793326281325
BLAKE2b-256 c1279ea310761a07261c58ad7c4bc1a7d283b778d0a5cc35729cb94f77dbffde

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page