This script was inspired by SmarterEveryDay's video on the rolling shutter effect, you should definitely go watch that here: https://youtu.be/dNVtMmLlnoE
This repo provides both a python script and a javascript implementation that runs in your browser at https://jd-13.github.io/rollingShutterSimulator/web/index.html
The script and web interface in this repository will create a simulation of the rolling shutter effect on any video that you provide to it.
When ran they will ask for the video file that you wish to use and several other paramters (described below), and will then generate a simulation of the rolling shutter effect.
The script runs interactively (as I imagine this will be more usefull for most), and you can adjust the speed of the effect and the direction of the sweep.
The script produces mp4 files, and can also produce a jpg of the full effect.
(For those interested, the above demo was created from: https://pixabay.com/en/videos/ferris-wheel-fair-night-2122/)
Before beginning, please note that I have only spent an hour or so working on this so far, so there will be bugs and rough edges.
To run this script you'll need:
python3
opencv (pip install opencv-python
)
numpy (pip install numpy
)
- Put the script in the same directory as the video you want to work on. This step isn't really necessary, but it makes things a little easier.
- From the directory which contains the script, run:
python3.5 rollingShutterSim.py
- The script will then ask for a series of parameters. At this time the script does not validate input, so be careful (yeah I definitely need to fix that)
- If all goes well you'll get a video or image created in the same directory that you ran the script from
Go to https://jd-13.github.io/rollingShutterSimulator/web/index.html
Some more information on the parameters which the script will ask for:
File path - The path to the video, or just the name if the video is in the same folder as the script
Frames to increment - Must be an integer, a higher number leads to a faster moving effect
Direction - You must provide one of four options: lr, rl, tb, or bt. This determines the direction of the sweep
Mode - Currently this doesn't work quite right, but this where you choose whether you want video or a single image as output