Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/moebiussurfing/ofxsurfingtextsubtitle

Draws subtitles from an .SRT (or plain text) into a formatted styled paragraph with fading opacity and more.
https://github.com/moebiussurfing/ofxsurfingtextsubtitle

openframeworks openframeworks-addon whisper whisper-cpp

Last synced: about 2 months ago
JSON representation

Draws subtitles from an .SRT (or plain text) into a formatted styled paragraph with fading opacity and more.

Awesome Lists containing this project

README

        

## OVERVIEW

Ready to use customizable `.SRT` text subtitle (and plain text) player for `openFrameworks`.

![Screenshot](Examples/example-Simple/Capture.PNG)

## FEATURES

- Full `.SRT` file browser for exploring the dialogs.
- `Text Mode` for importing `.txt`. files. Split file in blocks then used as slides.
- Fast `FontStash` render.
- Custom `Paragraph Styles`.
- Scalable and draggable `rectangle container`.
- All `settings are persistent`.
- Animated `Fade In/Out` for transparency.
- `Transport time player` with four modes:
- **STANDALONE**
- Dialogs following the original `SRT` times and durations.
- **FORCED**
- Customizable dialogs duration. Ignoring `SRT` times. Ideal for `Text` mode.
- **EXTERNAL**
- Time is controlled by a video player or linked to one external control.
- **MANUAL**
- To work without loading any `SRT` file. Just pass the text slides manually.
- `Presets Engine` for all the settings.

## SCREENCASTS

[VIDEO](https://youtu.be/kcObeooL3Pc)

EXAMPLES / SCREENSHOTS

#### - example-Subs_ImGui

#### - example-Subs_ofxGui / ofxGui
![Screenshot](Examples_ofxGui/example-Subs_ofxGui/Capture.PNG)

#### - example-Subs_ofxGui2 / ofxGui (Video Player)
![Screenshot](Examples_ofxGui/example-Subs_ofxGui2/Capture.PNG)

#### - example-SubtitleWhisper / Whisper (Real-time audio to text) [ ADVANCED / WIP ]
![Screenshot](Examples_Advanced/example-SubtitleWhisper/Capture.PNG)
Requires this [FORK](https://github.com/moebiussurfing/ofxWhisper) of [ofxWhisper](https://github.com/roymacdonald/ofxWhisper) from [@roymacdonald](https://github.com/roymacdonald).

#### - example-SubtitleChatGPT / [ ADVANCED / WIP ]
![Screenshot](Examples_Advanced/example-SubtitleChatGPT/Capture.PNG)

[VIDEO](https://youtu.be/G8iH-0UakN4)

## USAGE

#### ofApp.h
```.cpp
#include "ofxSurfingTextSubtitle.h"

ofxSurfingTextSubtitle subs;
```

#### ofApp.cpp
```.cpp
void ofApp::setup()
{
//subs.setup("Alphaville.srt"); // Optional
}
void ofApp::draw()
{
subs.draw();

subs.drawGui();
}
```

## DEPENDENCIES
- [ofxFontStash](https://github.com/armadillu/ofxFontStash)
- [ofxSurfingBox](https://github.com/moebiussurfing/ofxSurfingBox)
- [ofxSurfingHelpers](https://github.com/moebiussurfing/ofxSurfingHelpers)
- [ofxSufingImGui](https://github.com/moebiussurfing/ofxSurfingImGui)

### OPTIONAL
- **ofxGui** / Optional (oF core)
- [ofxWhisper](https://github.com/moebiussurfing/ofxWhisper) / FORK (Only for the example)
- [ofxChatGPT](https://github.com/moebiussurfing/ofxChatGPT) / FORK (Only for the example)

### TODO
- List and load different render fonts files on runtime.
- macOS testing.

## TESTED SYSTEM
* **Windows 10** / **VS 2022** / **OF ~0.11**

## THANKS
* SRT parser: file `srtparser.h`. Taken from https://github.com/Jonathhhan/ofEmscriptenExamples. Thanks to [@Jonathhhan](https://github.com/Jonathhhan). Originally by [@saurabhshri](https://github.com/saurabhshri/simple-yet-powerful-srt-subtitle-parser-cpp).
* [ofxPlaybackGui](https://github.com/roymacdonald/ofxPlaybackGui) from [@roymacdonald](https://github.com/roymacdonald) bundled into `/libs`. Optional to use only when using **ofxGui** as GUI. (Can be removed when using **ofxSurfingImGui**.)
* [ofxWhisper](https://github.com/roymacdonald/ofxWhisper) from [@roymacdonald](https://github.com/roymacdonald). Powered by [whisper.cpp](https://github.com/ggerganov/whisper.cpp) from [@ggerganov](https://github.com/ggerganov).
* [ofxChatGPT](https://github.com/tettou771/ofxChatGPT) from [@tettou771](https://github.com/tettou771).

## LICENSE
**MIT LICENSE**