How to Decrease Binary Size - tanersener/ffmpeg-kit GitHub Wiki
The size of FFmpegKit binaries is determined by the following two factors:
- External libraries enabled
- FFmpeg components enabled
FFmpegKit already defines eight packages with different external libraries enabled.
You can use a similar approach and create your own package by enabling only external libraries you need.
If you don't enable any of them, your package will have the minimum size, just as the current min package published.
Sometimes, not enabling unused external libraries is not enough, and you may want to decrease binary size further.
You can achieve that by modifying FFmpeg components enabled.
Two files, ffmpeg.sh for Android and
ffmpeg.sh for Apple platforms,
under the scripts folder defines which FFmpeg components are enabled for each platform respectively.
Current versions of these scripts do not modify default components and only disable features/devices not available on
specified platforms.
configure line located in the lower part of these files is responsible for enabling/disabling FFmpeg components.
./configure \
--cross-prefix="${HOST}-" \
--sysroot="${ANDROID_SYSROOT}" \
--prefix="${FFMPEG_LIBRARY_PATH}" \
--pkg-config="${HOST_PKG_CONFIG_PATH}" \
--enable-version3 \
--arch="${TARGET_ARCH}" \
...
Enabling/disabling a component can be done by appending options to configure line. Options starting with --enable- prefix are used to enable a component and options starting with --disable- prefix are used to disable it.
In order to scripts the smallest possible binary, you need to disable all FFmpeg components and enable only required ones.
For example, if you are using FFmpegKit to read JPEG files and create an mpeg4 video, you can use the following
options to disable all FFmpeg components and enable only necessary ones (scale, null and format filters are added for format conversion).
--disable-everything \
--enable-decoder=bmp,jpeg2000,jpegls,mjpeg,mjpegb,smvjpeg \
--enable-demuxer=bmp,jpeg2000,jpegls,mjpeg,mjpegb,smvjpeg,image2 \
--enable-muxer=mp4 \
--enable-protocol=file \
--enable-encoder=mpeg4 \
--enable-filter=scale,null,format \
Hybrid Plugins (Flutter, React Native)
Hybrid plugins of FFmpegKit use the binaries of native FFmpegKit platform (Android, iOS, macOS) releases. To decrease their size, the size of native FFmpegKit binary they depend on must be decreased.
-
Top level build scripts we have for native
FFmpegKitplatforms (android.sh,ios.sh,macos.sh,tvos.sh) must be used to build a custom nativeFFmpegKitbinary.Building section of the wiki explains how to use those scripts and the first part of this page shows how unused
ffmpegcomponents can be disabled. -
After that, the hybrid plugin must be cloned and native
FFmpegKitdependency it has must be replaced with the custom library built.