Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hediet/slideo
This tool uses OpenCV to automatically synchronize slides with videos that show these slides.
https://github.com/hediet/slideo
Last synced: 9 days ago
JSON representation
This tool uses OpenCV to automatically synchronize slides with videos that show these slides.
- Host: GitHub
- URL: https://github.com/hediet/slideo
- Owner: hediet
- License: gpl-3.0
- Created: 2021-03-05T15:25:34.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2021-10-18T20:43:08.000Z (about 3 years ago)
- Last Synced: 2024-10-25T22:32:56.809Z (16 days ago)
- Language: Rust
- Homepage:
- Size: 44.5 MB
- Stars: 99
- Watchers: 3
- Forks: 5
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE.md
Awesome Lists containing this project
- awesome-github-repos - hediet/slideo - This tool uses OpenCV to automatically synchronize slides with videos that show these slides. (Rust)
README
# Slideo: Synchronize Slides With Video
[![](https://img.shields.io/static/v1?style=social&label=Sponsor&message=%E2%9D%A4&logo=GitHub&color&link=%3Curl%3E)](https://github.com/sponsors/hediet)
[![](https://img.shields.io/static/v1?style=social&label=Donate&message=%E2%9D%A4&logo=Paypal&color&link=%3Curl%3E)](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=ZP5F38L4C88UY&source=url)
[![](https://img.shields.io/twitter/follow/hediet_dev.svg?style=social)](https://twitter.com/intent/follow?screen_name=hediet_dev)This tool matches video frames against PDF pages by using computer vision.
It also ships a web app in which you can click on a PDF page to play the video from the first frame showing the page.
Its primary use-case is to quickly play a recorded lecture from a given slide.Works best if the PDF page in the video is captured through screen recording and video is 1080p, but it might work in other scenarios too (rotation, shifting, scaling, obstruction and additional on-screen content is supported).
**See [Background](./BACKGROUND.md) for building instructions and how the matching algorithm works.**
_This is tool is more a proof of concept rather than a polished product. Please reach out if you want to make a nice open source product out of it._
![](./docs/demo.gif)
## Installation
See [Releases](https://github.com/hediet/slideo/releases).
An installer is not yet provided. Feel free to contribute!### Windows Requirements
- [Microsoft Visual C++ Redistributable für Visual Studio 2019](https://visualstudio.microsoft.com/de/downloads/#microsoft-visual-c-redistributable-for-visual-studio-2019)
### Linux, Mac Requirements
(untested)
- OpenCV 4.5.2
- Poppler## Usage
### Synchronize a Set of PDFs With a Set of Videos
Any given lecture slide can appear in any given video.
For performance and accuracy, keep the amount of pdf files small and prefer seperate invocations.
Synchronizing an entire lecture (<1000 slides) should work well though.```sh
slideo lecture1.pdf lecture2.pdf video1.mp4 video2.mp4
```When you know that video1 does not contain any slides of lecture2, you can do this to improve accuracy:
```sh
slideo lecture1.pdf video1.mp4 --non-interactive && slideo lecture2.pdf video2.mp4 --non-interactive
```### View a Synchronized PDF
```
slideo lecture1.pdf
```This will spawn a webserver on port 63944 and print an url that you can open in your favorite browser to open the viewer.
**You can drag&drop any processed PDF into the viewer!**
## TODO
- Use wry to build a proper web GUI.
- Use rustcv to get rid of the OpenCV dependency.# Other Stuff You Might Like
- ## [Browser Extension: Improved GitHub Issue Editor](https://github.com/hediet/browser-ext-github-monaco)
- ## Draw.io for [VS Code](https://github.com/hediet/vscode-drawio) and [IntelliJ](https://github.com/docToolchain/diagrams.net-intellij-plugin)
- ## [Debug Visualizer for VS Code](https://github.com/hediet/vscode-debug-visualizer)A big **Thank You** to all my sponsors on GitHub!