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 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.
See Releases. An installer is not yet provided. Feel free to contribute!
(untested)
- OpenCV 4.5.2
- Poppler
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.
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:
slideo lecture1.pdf video1.mp4 --non-interactive && slideo lecture2.pdf video2.mp4 --non-interactive
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!
- Use wry to build a proper web GUI.
- Use rustcv to get rid of the OpenCV dependency.
A big Thank You to all my sponsors on GitHub!