data:image/s3,"s3://crabby-images/c05d4/c05d436b4d62b1da7eaeb106b4d52d0fda936d7a" alt="Is ffmpeg mp4 lossless"
data:image/s3,"s3://crabby-images/69102/6910221c1af3b4f8d37a11326d3ef58d2a38a866" alt="is ffmpeg mp4 lossless is ffmpeg mp4 lossless"
The -probesize is there to give the encoder enough initial data to allow it to analyse the input streams. It is the -crf 0 option that makes the capture lossless. Using MP4 as the container seems to be faster, so for high-res screen-only demos, this is the best choice. c:v libx264rgb -crf 0 -preset ultrafast \ Lossless H.264 video: ffmpeg -hide_banner \ The capture file will be largish (around 20MB per minute), and will require some further encoding once the capture/editing is completed to reduce the file sizes. It is also one of the best supported codecs for compatibility.
data:image/s3,"s3://crabby-images/4ad34/4ad347fa49dfc9d1b4e3edfd71e9df830c726cc8" alt="is ffmpeg mp4 lossless is ffmpeg mp4 lossless"
Of the lossless codecs tested it had the best combination of file size (way smaller than HuffYUV) and speed (can mostly keep up with the capture even on my old laptop).
data:image/s3,"s3://crabby-images/4384b/4384b2afb2a8cd968d82f93b83f3ca5cab0802c6" alt="is ffmpeg mp4 lossless is ffmpeg mp4 lossless"
Some quick testing suggests H.264 in lossless mode seems to be the the best option. The aim here is to capture at the highest quality possible with minimal CPU usage (so that the capture can keep up without dropping frames, and to leave some head room for other processes).
data:image/s3,"s3://crabby-images/948b7/948b706806f719299dd658d72609dae40bb4da67" alt="is ffmpeg mp4 lossless is ffmpeg mp4 lossless"
Using FFplay to display the difference between two videos.Hardware accelerated capture via VAAPI (Linux).
data:image/s3,"s3://crabby-images/c05d4/c05d436b4d62b1da7eaeb106b4d52d0fda936d7a" alt="Is ffmpeg mp4 lossless"