Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ratwithacompiler/OBS-captions-plugin
Closed Captioning OBS plugin using Google Speech Recognition
https://github.com/ratwithacompiler/OBS-captions-plugin
Last synced: 3 months ago
JSON representation
Closed Captioning OBS plugin using Google Speech Recognition
- Host: GitHub
- URL: https://github.com/ratwithacompiler/OBS-captions-plugin
- Owner: ratwithacompiler
- License: gpl-2.0
- Created: 2019-07-13T18:57:10.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2024-07-14T02:23:57.000Z (7 months ago)
- Last Synced: 2024-10-23T13:35:17.839Z (3 months ago)
- Language: C++
- Homepage:
- Size: 2.47 MB
- Stars: 1,051
- Watchers: 27
- Forks: 70
- Open Issues: 66
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- starred - ratwithacompiler/OBS-captions-plugin - Closed Captioning OBS plugin using Google Speech Recognition (C++)
README
## Closed Captioning OBS Plugin
Provides closed captioning via Google Cloud Speech Recognition API as a standalone OBS plugin, no other tools required.
It's fully optional to viewers and uses Twitch's built in caption support which works on livestreams and in VODs on PC, Android and iOS, no Twitch extension required.#### Features:
* Completely optional for viewers on all platforms
* Captions only when the microphone source is unmuted and active to ensure safety
* Works live and in VODs, no Twitch extension required
* Requires no extra tools or website open
* Supports many common languages with western character sets
* Supports OBS delay
* Open Caption support via OBS Text Sources for sites that don't support closed captions
* Saving captions transcripts as SRT Subtitle files (.srt)
* Text filtering with custom word and phrase removal and replacement
* Supports captioning all stream audio instead of just a single source##### Notes:
* The caption delay is usually less than half a second and should not be noticeable to viewers.
* The plugin only captions the selected audio source when it's not muted and when it's used on the current active scene to ensure safety and avoid any captioning when the mic is muted for the stream.
* Only tested on `Twitch.tv`, other streaming services with native caption support might work but not very likely.
* You can enable and disable the caption preview dock in OBS under `View -> Docks -> Captions`
* Some video players like MPV can show embedded captions on downloaded VODs but very few support that.
* The quality of Google's Speech Recognition heavily depends on the speaker and what is being said. The results are usually be pretty good in normal conversational settings like talking to chat but the recognition quality can go down noticeably when using ingame terms or other specialized vocabulary or during hectic speaking.
* SRT transcript files are generally recommended for saving captions for local recordings. They are supported by many video players, websites and tools and are easy to edit.![Example Image](./github/images/twitch_page.png)
##### [Example VOD here](https://www.twitch.tv/videos/441407980?t=20s)##### Known Issues/Downsides:
Does NOT work with Streamlabs OBS (SLOBS), it doesn't support 3rd party plugins like this.
Does NOT support native caption output for languages with foreign character sets like Japanese or Russian, that isn't possible the way Twitch and OBS captions work. Transcripts and Open Captions do work.
Does NOT appear to work with the AMD Hardware encoder in OBS on Windows (other hardware encoders like NVEnc and even AMD on MacOS seem fine)
This uses the built in captions support of Twitch's video player so viewers only get the limited amount of positioning options that the player provides. Viewers can choose between top/bottom and left/center/right for the captions box but can't freely move or resize it or put it into a corner. It's also not possible for streamers to pick a good custom default position for it, the default will be center bottom for all viewers that have captions enabled.
Embedded Captions in local recordings currently aren't very useful. They only work with certain file formats (ts, mp4, mov) and only very few video players can correctly play them.
MPV can play them normally with .ts files, almost no common video players play them in mp4 and mov files. Saving transcripts to separate .srt subtitle files is generally much more useful.Captions should be off by default for most viewers but Twitch does sometimes have them enabled for some viewers for unknown reasons so occasionally some will be confused on how to turn them off and might need it explained.
* **On PC** viewers can turn captions on and off using the CC button on the bottom right of the player.
![PC CC Setting](./github/images/CC_button.png)
* **On iOS** it's a system wide setting: `Settings -> General -> Accessibility -> Subtitles & Captioning -> Closed Captions + SHD`
* If it's already off but viewers still see captions they have to turn it on and off again (appears to be a bug on some iOS versions)
* **On Android** it's `Closed Captions` under the player settings options right beneath the quality selection. The option will only show up once the streamer has talked.### Installation (Windows):
* Close OBS if running
* Download latest Closed_Captions_Plugin.zip version for Windows [from the releases section](https://github.com/ratwithacompiler/OBS-captions-plugin/releases)
* Extract the zip
* it contains a folder named `obs-plugins`
* Go to your OBS installation folder
* The default OBS install path is usually `C:\Program Files\obs-studio\` or `C:\Program Files (x86)\obs-studio\`
* Copy-Paste the `obs-plugins` folder into the main OBS folder
* The main OBS folder should already contain `obs-plugins` `bin` and `data` folders
* Windows will ask to confirm the copy and replace, click yes a few times
* This will just add the plugin files to the existing `obs-plugins` folder
* That's it. Start OBS.
* There should now be a `Cloud Closed Captions` option on the bottom of `Tools` menu
* Click on `Settings` in the new `Captions Preview` window and select your audio source for captioning under `Caption Source`
* Select the OBS source that is only your microphone for best captioning results
* If you don't have a OBS source that is only your microphone but instead use a more complicated audio setup see below for more info![Installation Windows](./github/images/win_install.png)
#### Plugin:
![Example of Plugin in OBS](./github/images/obs_base_3.png)### Installation (Mac OS):
* Download latest Closed_Captions_Plugin___MacOS.zip version for MacOS [from the releases section](https://github.com/ratwithacompiler/OBS-captions-plugin/releases)
* Extract the zip
* (should just auto extract when opened/clicked)
* it contains a file/plugin-package named `cloud-closed-captions.plugin`
* Copy-Paste that `cloud-closed-captions.plugin` file into the `plugins` folder in the `obs-studio` settings folder
* To find the settings Folder, in the OBS menu click `File -> Show Settings Folder` and it should open automatically
* Alternatively if that doesn't work:
* Open Finder and in the `Go` menu press `Go to Folder` (or press Cmd+Shift+G)
* Paste `~/Library/Application Support/obs-studio/` and hit enter to go to your `obs-studio` folder
* Your `obs-studio` folder may contain a folder called `plugins` already, if not then create one
* Paste the `cloud-closed-captions.plugin` file/plugin-package folder into the `plugins` folder
* That's it. Restart/Start OBS.
* There should now be a `Cloud Closed Captions` option on the bottom of `Tools` menu
* Click on `Settings` in the new `Captions Preview` window and select your audio source for captioning under `Caption Source`
* Select the OBS source that is only your microphone for best captioning results
* If you don't have a OBS source that is only your microphone but instead use a more complicated audio setup see below for more info![Installation Mac](./github/images/mac_install_28.png)
### Installation (Linux):
* Download latest Closed_Captions_Plugin.zip version for Linux [from the releases section](https://github.com/ratwithacompiler/OBS-captions-plugin/releases)
* Put `libobs_google_caption_plugin.so` into your OBS plugins folder
* Plugin folder location can vary a lot depending on distribution and/or installation source.
* Usually also works in `$HOME/.config/obs-studio/plugins`
* In that folder it needs to be in the required obs plugin folder structure, the final path would be:
* `$HOME/.config/obs-studio/plugins/libobs_google_caption_plugin/bin/64bit/libobs_google_caption_plugin.so`#### Settings for more unusual audio setups that don't use a mic only source in OBS (like 2 PC + audio mixer setups):
If your OBS setup does not use a audio source that's only the microphone but instead gets a already mixed audio source (that has the microphone mixed with other sounds/game/voices already like from a mixer or GoXLR) you can still make it work as long as your streaming PC has access to only the microphone by itself as well. Steps:
* If you don't already have a OBS source that's only your mic then create one:
* Create a new Audio Input Capture source in OBS somewhere using the device that's only the microphone, calling it `Microphone only` for example, and mute it (so stream doesn't hear the mic twice)
* In caption settings set `Caption Source` to the mic only OBS source that's muted
* Set `Caption When` to `Mute Source is heard on stream`
* Set `Mute Source` to your mixed audio OBS source that stream hears![Mixed Source Setup Instructions](./github/images/mutesource3.png)
This way it will use the `Microphone only` source to get clean mic audio for captioning but it will still only caption it when the other selected source is unmuted and active so it's still safe. When the mixed source for stream is muted in OBS the captions also get muted.