data:image/s3,"s3://crabby-images/43c96/43c96015b78ebacfb14c3b57409aade6b210e63c" alt="Ffmpeg gif smaller"
data:image/s3,"s3://crabby-images/aae4e/aae4e723ba78ef664ccb916009deb814e8e6d7e8" alt="ffmpeg gif smaller ffmpeg gif smaller"
data:image/s3,"s3://crabby-images/bf762/bf76259876e99fc402d1477dae989b54a1251316" alt="ffmpeg gif smaller ffmpeg gif smaller"
Using a nifty tool in the repo called graph2dot, I generated a plot of each step in the process: The FFmpeg codebase is large and complex, and the filter above is fairly complicated as well. What was strange, however, was that non-transparent pixels were being affected. This indicated something was going wrong when processing transparent pixels. This bug only affected Stickers, which are GIFs with some transparent pixels. The buggy renditions were traced back to an FFmpeg command that we use to re-scale GIFs while retaining the original color palette: ffmpeg -i in.gif -filter_complex "scale=100:-1, split palettegen paletteuse" out.gif Unwilling to let the world go without pixel-perfect poop, I started hunting down the bug.
data:image/s3,"s3://crabby-images/2d320/2d320eaefb77fb478a65dcc90bf2d412b14af242" alt="ffmpeg gif smaller ffmpeg gif smaller"
Notice that some parts of the image get stuck (eg, the top of this GIF)
data:image/s3,"s3://crabby-images/43c96/43c96015b78ebacfb14c3b57409aade6b210e63c" alt="Ffmpeg gif smaller"