This application displays the photos for my annual yearbook project.
- Built with Next.js
- Media stored in S3 in multiple sizes -- allows the best size to be used depending on the case (e.g. 1000px for the main grid, 3000px for the lightbox)
- Images are loaded in batches as the user scrolls to keep initial load time fast.
- Hosted on Vercel
- Read EXIF data from images to display photo captions
- Improve grid layout so portrait images aren't chopped so much at the top and bottom
cd $LOCAL_PHOTO_DIRECTORY
aws s3 sync . s3://yearbook-assets/ --delete --acl public-read --profile default --exclude "*" --include "*.jpg" --include "*.webp" --include "*.gif" --size-only
for i in *.mov; do ffmpeg -ss 00:00:00.000 -i "$i" -vcodec libwebp -q 50 -r 12 -vf 'scale=1000:1000:force_original_aspect_ratio=decrease' -loop 0 -t 00:00:12.000 "${i%.*}_50.webp"; done
- converts a folder of video -> webp
- longest side 1000px
- first 12 secs
- 12 frames/sec
- quality 50
for i in *.MOV; do ffmpeg -ss 00:00:00.000 -i "$i" -pix_fmt rgb24 -r 12 -vf 'scale=600:600:force_original_aspect_ratio=decrease' -t 00:00:10.000 "${i%.*}.gif"; done
- converts a folder of video -> gif
- longest side 600px
- first 10 secs
- 12 frames/sec
alternatively
ffmpeg -ss 00:00:00.000 -i IMG_5407.MOV -pix_fmt rgb24 -r 15 -s 300x553 -t 00:00:10.000 output4.gif
..this is a 10 sec clip of the movie at a 15/sec frame rate .. downsized to 300x553