版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_27339239/article/details/83339679
ffmpeg的那点小事儿--编译ffmpeg同时支持libx264(视频编码)和libfdk(音频编码)
主要是shell脚本编写上的问题,直接上脚本代码
#!/bin/bash
#1、首先:定义下载的库名称
source="ffmpeg-4.0.2"
#2、其次:定义".h/.m/.c"文件编译的结果目录
#目录作用:用于保存.h/.m/.c文件编译后的结果.o文件
cache="cache"
#3、定义".a"静态库保存目录
#pwd命令:表示获取当前目录
staticdir=`pwd`/"ffmpeg-iOS"
#4、添加FFmpeg配置选项->默认配置
configure_flags="--enable-cross-compile --disable-debug --enable-x86asm --disable-programs --disable-doc --enable-pic"
configure_flags="$configure_flags --enable-avdevice --enable-avcodec --enable-avformat --enable-libx264 --enable-decoder=h264 --enable-demuxer=h264 --enable-parser=h264 --enable-decoder=aac --enable-decoder=aac_latm --enable-nonfree"
#5、定义默认CPU平台架构类型
#arm64 armv7->真机->CPU架构类型
#x86_64 i386->模拟器->CPU架构类型
archs="arm64 armv7 x86_64 i386"
#6、指定我们的这个库编译系统版本->iOS系统下的7.0以及以上版本使用这个静态库
targetversion="8.0"
#7、接受命令后输入参数
#我是动态接受命令行输入CPU平台架构类型(输入参数:编译指定的CPU库)
if [ "$*" ]
then
#存在输入参数,也就说:外部指定需要编译CPU架构类型
archs="$*"
fi
#8、安装汇编器->yasm
if [ ! `which yasm` ]
then
#Homebrew:软件管理器
if [ ! `which brew` ]
then
echo "安装brew"
ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)" || exit 1
fi
echo "安装yasm"
#成功了
#下载安装这个汇编器
#exit 1->安装失败了,那么退出程序
brew install yasm || exit 1
fi
echo "star build"
#9、for循环编译FFmpeg静态库
currentdir=`pwd`
for arch in $archs
do
echo "begin"
#9.1、创建目录
#在编译结果目录下-创建对应的平台架构类型
mkdir -p "$cache/$arch"
#9.2、进入这个目录
cd "$cache/$arch"
#9.3、配置编译CPU架构类型->指定当前编译CPU架构类型
archflags="-arch $arch"
#9.4、判定一下你到底是编译的是模拟器.a静态库,还是真机.a静态库
if [ "$arch" = "i386" -o "$arch" = "x86_64" ]
then
#模拟器
platform="iPhoneSimulator"
#支持最小系统版本->iOS系统
archflags="$archflags -mios-simulator-version-min=$targetversion"
else
#真机(mac、iOS都支持)
platform="iPhoneOS"
#支持最小系统版本->iOS系统
archflags="$archflags -mios-version-min=$targetversion -fembed-bitcode"
#注意:优化处理(可有可无)
#如果架构类型是"arm64",那么
if [ "$arch" = "arm64" ]
then
#GNU汇编器(GNU Assembler),简称为GAS
#GASPP->汇编器预处理程序
#解决问题:分段错误
#通俗一点:就是程序运行时,变量访问越界一类的问题
EXPORT="GASPP_FIX_XCODE5=1"
fi
fi
#10、正式编译
#tr命令可以对来自标准输入的字符进行替换、压缩和删除
XCRUN_SDK=`echo $platform | tr '[:upper:]' '[:lower:]'`
#编译器->编译平台
CC="xcrun -sdk $XCRUN_SDK clang"
#架构类型->arm64
if [ "$arch" = "arm64" ]
then
#音视频默认一个编译命令
#preprocessor.pl帮助我们编译FFmpeg->arm64位静态库
AS="gas-preprocessor.pl -arch aarch64 -- $CC"
else
#默认编译平台
AS="$CC"
fi
TMPDIR=${TMPDIR/%\/} $currentdir/$source/configure \
--target-os=darwin \
--arch=$arch \
--cc="$CC" \
--as="$AS" \
$configure_flags \
--enable-gpl \
--disable-encoders \
--enable-libx264 \
--enable-encoder=libx264 \
--enable-encoder=mjpeg \
--enable-encoder=png \
--enable-libfdk-aac \
--enable-encoder=libfdk_aac \
--enable-decoder=libfdk_aac \
--extra-cflags="$archflags" \
--extra-ldflags="$archflags" \
--extra-cflags="-I/Users/avalanching/Desktop/FFmpeg/thin-x264/arm64/include" \
--extra-ldflags="-L/Users/avalanching/Desktop/FFmpeg/thin-x264/arm64/lib" \
--extra-cflags="-I/Users/avalanching/Desktop/FFmpeg/thin-fdkaac/arm64/include" \
--extra-ldflags="-L/Users/avalanching/Desktop/FFmpeg/thin-fdkaac/arm64/lib" \
--prefix="$staticdir/$arch" \
|| exit 1
make -j3 install $EXPORT || exit 1
cd $currentdir
echo "build was success"
done
需要注意的地方:
--enable-gpl \
--disable-encoders \
--enable-libx264 \
--enable-encoder=libx264 \
--enable-encoder=mjpeg \
--enable-encoder=png \
--enable-libfdk-aac \
--enable-encoder=libfdk_aac \
--enable-decoder=libfdk_aac \
--extra-cflags="$archflags" \
--extra-ldflags="$archflags" \
--extra-cflags="-I/Users/avalanching/Desktop/FFmpeg/thin-x264/arm64/include" \
--extra-ldflags="-L/Users/avalanching/Desktop/FFmpeg/thin-x264/arm64/lib" \
--extra-cflags="-I/Users/avalanching/Desktop/FFmpeg/thin-fdkaac/arm64/include" \
--extra-ldflags="-L/Users/avalanching/Desktop/FFmpeg/thin-fdkaac/arm64/lib"
#--desable-encoders 这里是禁用了其他的编码器,如果需要使用其他的编码器,可以删除这一句
#enable-libx264 和 --enable-libfdk-acc都是去指定音视频的编码器,分别为h264和aac
#avalanching 是我的主机名,在编写的时候,记得去换成你们的路径
github地址:https://github.com/Avanlanching/Avalanching_shell_for_ffmpeg
目录下包含:ffmpeg4.0.2的源码,编译过的libx264和libfdk-aac,还用已经支持h264和aac的ffmpeg,不想编译的可以直接使用FFmpeg-iOS的下资源,另外需要thin-x264和thin-fdkaac下面的头文件和库