This project helps create a "1 second everyday"-style video using your existing media.
Thanks to Fig Vids for the footage! Go check out their YouTube Channel
If you've recorded lots of videos (e.g. with your phone), you use this code to turn all of that into a compilation video, for example showing 1 second of your life every day.
- Configure the relevant values in
default.json
- Run
npm install && make migrate
- Run the following:
make build
node src/server/server.js
# or to develop:
# make start
- Then open up
http://localhost:3000
The web interface allows you to (optionally) select which media to use in your final compilation videos. If you don't select anything, you can rely on the defaults.
-
When you're happy with your selection, click
consolidate media
in the web app. -
You will then end up with a folder consisting of ~1 second videos:
0001.mp4 0002.mp4 0003.MOV
...and so on. You can then drag these into your video tool of choice, and join them all toegther. As an example, if using Screenflow:
- Drag all files (
0001.mp4, 0002.mp4
etc.) into screenflow - Select all clips
- Arrange > Scale > Scale to Fit
- File > Export
- Doocument the process of stitching together consolidated media + burning in subtitles (and resize to fit)
- If
MP4Box
fails, use ffmpeg instead for shorter segments. Edit: Should I Use FFMPEG regardless? MP4Box is not very accurate. Need to benchmark the overall times - Add support for a Job Queue, stored in the DB, which can sequentially process videos even after the web server has started up
- Provide a /jobs page which shows pending/in-progress/completed jobs
- allow selecting multiple videos/images for a given day (shift + click?) and have them either condensed into a 1-2 second timeframe, or just allow each of them to occupy the usual time amount
- try
video-segment-duration-seconds
of 1sec and make sure things work - ensure working state is clean, and everything is committed, handle config files
main-config.js
has some hardcoded server paths, share this in a more intuitive way across the codebase- Remove absolute paths from config files
- Use node.js recursive delete instead of rimraf (https://nodejs.org/api/fs.html#fs_fs_rmdirsync_path_options)
- Add timelapse support/speed up videos
- Overlay text on significant videos
- Document webapp and include a getting started guide
- Support images
- Refactor code + modularise
- add a test folder with test media and use
md5 0003.MOV md5 0004.mp4
and so on to verify the output media, to to a demo vid/gif from the readme
- Get an array of all top-level folders in the
video-segment-folder
, namedallTopLevelSegmentFolders
- For each media source item on the filesystem
- Check the DB record. If
defaultVideoSegmentDuration
differs from config value, then delete thedefaultVideoSegment
file (not folder as other segments may have been generated), e.g. so deleteVID-20190902-WA0004.mp4/VID-20190902-WA0004_15_18.mp4
on the filesystem - Maybe the config didn't even change, it which case check the file
- Create/generate the video segment using the usual technique
- Remove the current media source item from
allTopLevelSegmentFolders
- At the end of looping through all top level media source items, as a cleanup task, delete any remaining items in
allTopLevelSegmentFolders
# takes less than a second to execute, but includes black frames at the start
ffmpeg -ss 00:01:00 -i ~/Downloads/tmp/VID_20191020_113153.mp4 -t 3 -c copy -avoid_negative_ts 1 ./dist/test.mp4
# takes 1 min, but is a correctly formatted video file
ffmpeg -ss 00:01:00 -t 2 -i ~/Downloads/tmp/VID_20191020_113153.mp4 ./dist/foo.mp4
# Similar (slow but accurate and working), not sure what the difference is
ffmpeg -i ~/Downloads/tmp/VID_20191020_113153.mp4 -ss 10 -strict -2 -t 2 ./dist/foo.mp4
# finally, using mp4box works!
/Applications/GPAC.app/Contents/MacOS/MP4Box -splitx 10:12 ~/Downloads/tmp/VID_20191020_115217.mp4
# after this, it'll need resizing
ffmpeg -i VID_20191020_115217_14_17.mp4 -vf scale=640:-1 output.mp4
# these 1-2 second MP4 might be slow to watch, so how about displaying a sped up version either by:
# changing the vid.playbackRate in JS, or, using ffmpeg:
ffmpeg -i $1 -r 10 -vcodec png out-static-%05d.png
# command to overlay text on a video
ffmpeg -i 0009.mp4 -vf drawtext="fontfile=~/Library/Fonts/FiraCode-Bold.ttf: text='some text!':fontsize=80:fontcolor=white:x=100:y=100" 0009-text.mp4
# This command will concatenate videos of the same format/size
ffmpeg -f concat -i mp4s.txt -fflags +genpts mp4s.mp4
# mp4box concat is super fast...but only if files are the same resolution
/Applications/GPAC.app/Contents/MacOS/MP4Box -cat scaled/1.mp4 -cat scaled/2.mp4 -cat scaled/3.mp4 -cat scaled/4.mp4 -cat scaled/5.mp4 -new mp4box.mp4
# scaling videos working - run this on all videos, then do a ffmpeg concat https://superuser.com/a/547406
ffmpeg -i footage/6.MOV -filter:v "scale=iw*min(1920/iw\,1080/ih):ih*min(1920/iw\,1080/ih), pad=1920:1080:(1920-iw*min(1920/iw\,1080/ih))/2:(1080-ih*min(1920/iw\,1080/ih))/2" -c:a copy scaled/6.mp4