This is a stream overlay that shows heart rate and calorie burn information sent from an Apple Watch running the Health Data Server app.
Video of the overlay in action
- Download the latest release executable
- Double click the downloaded file to run it
- On macOS/linux you will need to open the terminal and change into the directory of the executable
- For example, if the executable is in the Downloads folder run
cd Downloads
- For example, if the executable is in the Downloads folder run
- On macOS, run
chmod 777 HDS-Overlay-macos
in the terminal - On linux, run
chmod 777 HDS-Overlay-linux
in the terminal
- On macOS/linux you will need to open the terminal and change into the directory of the executable
- Windows will give you some prompts that you have to deal with
- For the Winows Smartscreen prompt, click on "More info" and then "Run anyway"
- For the Windows Firewall prompt, make sure to check both the boxes and then click "Allow access"
- MacOS will not let you open the overlay the first time. After you try to open the overlay, go to
System Preferences > Security & Privacy > General
and click on "Open Anyway" - Open a browser and go to
localhost:8080
You should see the overlay, but no numbers yet since the watch hasn't sent any.
- Make sure the Apple Watch and device running the overlay application are on the same network. If the watch is connected to an iPhone, you just need to make sure the iPhone is connected to the same network.
- Install the Health Data Server application on your Apple Watch
- THE APP REQUIRES WATCHOS 6+. The App Store will let you purchase it even if your watch can't run watchOS 6+, so make sure before buying.
- Open the application
- Type the IP address of the machine running the overlay application
- The overlay application will list possible IP addresses of your machine on startup. If none of those work, you may have to find the IP address manually.
- If you need help finding the IP address of your machine, read this. It probably looks something like this:
192.168.xxx.xxx
- There is an input method in watchOS 6 that allows you to type in text fields from your iPhone. This is by far the easiest way to input the information into the watch application.
- If you want to send data to an external server, you will need to input the full websocket URL ex:
ws://hostname:port/other/stuff
- Click the start button
You should soon see numbers in the webpage you opened earlier. This is the health data the watch is sending over your local network.
The iPhone app includes a config file editor to make this easier.
Images simply need to be placed in the same folder as the overlay executable. The file extension does not matter as long as it is an image/gif file. The base names of the images files must be hrImage
for the heart rate image and calImage
for the calories image.
If you want a heart beat sound, put a sound file with a base name of beatSound
in the same folder as the overlay executable. Sounds will only work in OBS since browsers block auto playing sounds.
If you need to change either of the ports you will need to create a config file. Create a file named config.json
in the same folder as the application:
{
"httpPort": 8080,
"websocketPort": 3476,
"discordRichPresenceEnabled": "false"
}
You only need to speficy the config options that you want to change. Make sure to not leave a trailing comma or the application will crash. If you change the websocketPort, you will have to append it to the IP address in the watch app ex: 192.168.xxx.xxx:3476
.
The iPhone app includes a Custom CSS editor to make this easier.
If you need complex styling of the overlay, you can use the Custom CSS field on an OBS browser source. Use styles.css as a reference of what can be changed.
Some Custom CSS examples can be found in the wiki
If you want to use this as a stream overlay, simply add the url used to see the data in a web browser as a browser source in your favorite streaming application.
If you are using an IP address instead of "localhost" in OBS, then you will have to include "http://" before it or it won't work: http://192.168.xxx.xxx:8080
Try these troubleshooting steps before asking for help
- Ask for help in the support Discord server
- Create an issue
Many people only leave reviews when they have a problem with an app. Even if many users don't have an issue, these negative reviews can turn off potential new users. If you enjoy this application, please consider leaving a review on the App Store page. Even a simple review helps a lot!
Most users won't need to do this, but here is how to build the application manually.
npm install
./buildscript.sh
- The generated files will be in the
output
folder