八.FFmepg--编译静态库(iOS)

有了前面shell脚本语言的基础,
剩下的就是自己动手写脚本.
好了,开始编写我们的静态库

1.FFmepg编译环境及结构

  • 下载FFmepg
  • FFmpeg配置选项介绍
  • 下载gas-preprocessor.pl及安装
  • 编写脚本代码(执行源码)
  • 执行脚本结果一览
  • 编译中出现的问题
  • 个人总结

2.下载FFmepg

首先呢,我们先下载音视频框架
这里提供两种下载方法:

  • 一:官网下载(https://ffmpeg.org)
八.FFmepg--编译静态库(iOS)_第1张图片
FFmpeg下载.png
  • 二:执行下面的FFmpeg-down(shell脚本文件)(可以到我的github下载)


    八.FFmepg--编译静态库(iOS)_第2张图片
    ffmpeg-down.png
  • 执行结果:在终端执行文件ffmpeg-down文件,就可以进行下载FFmpeg,下图正在下载...

ffmpeg_down_结果.png

注意:把下载后的解压包放在与shell脚本同一目录下

3.查看FFmpeg配置选项介绍

首先呢,我们进入下载好的FFmpeg框架包中,打开终端,cd到目录下,执行如下命令,就可以配置选项的组成

./configure --help

选项(options)介绍:

  • Help options:FFmpeg帮助选项(帮助文档)


    八.FFmepg--编译静态库(iOS)_第3张图片
    help options.png
    • --help 帮组信息(打印此消息)
    • --quiet 抑制显示信息输出
    • --list-decoders 显示所有可用的解码器
    • --list-encoders 显示所有可用的编码器
    • --list-hwaccesl 显示所有可用的硬件加速器
    • --list-muxers 显示所有可用的视音频复用器
      视音频复用器(Muxer)即是将视频压缩数据(例如H.264)和音频压缩数据(例如AAC)合并到一个封装格式数据(例如MKV)中去。如图所示。在这个过程中并不涉及到编码和解码。


      八.FFmepg--编译静态库(iOS)_第4张图片
      视音频复用器(Muxer).jpeg
    • --list-demuxers 显示所有可用的视音频分离器
    • --list-parsers 显示所有可用的解析器
    • --list-protocols 显示所有可用的协议
    • --list-bsfs 显示所有可用的比特流过滤
    • --list-indevs 显示所有可用的输入设备
    • --list-outdevs 显示所有可用的输出设备
    • --list-filters 显示所有可用的过滤器
  • Standard options:标准选项


    八.FFmepg--编译静态库(iOS)_第5张图片
    stanard options.png
    • --logfile=FILE 记录测试并输出到ffbuild/config.log文件
    • --disable-logging 没有日志配置调试信息
    • --fatal-warnigns 致命的警告,配置警告生成
    • --prefix=PREFIX 前缀默认[/usr/local]
    • --bindir=DIR 二进制文件默认[PREFIX/bin]
    • --datadir=DIR 数据文件默认[PREFIX/share/ffmpeg]
    • --docdir=DIR doc文档默认[PREFIX/share/doc/ffmpeg]
    • --libdir=DIR 安装库到指定目录[PREFIX/lib]
    • --shlibdir=DIR 指定共享库路径[LIBDIR]
    • --incdir=DIR 指定includes路径[PREFIX/include]
    • --mandir=DIR 指定安装手册路径[PREFIX/share/man]
    • --pkgconfigdir=DIR 指定配置文件路径[LIBDIR/pkgconfig]
  • Licensing options:许可选项(侵权)


    licensing options.png
    • --enable-gpl 允许使用GPL(默认关闭)
    • --enable-version3 gpl升级到版本3(默认关闭)
    • --enable-nonfree 允许用户使用非免费代码(默认关闭)
  • Configuration options:配置备选选项


    八.FFmepg--编译静态库(iOS)_第6张图片
    configuration options.png
    • --disable-static 不能编译静态库(默认关闭)
    • --enable-shared 编译共享库(默认关闭)
    • --enable-small 启用优化文件尺寸大小(牺牲速度)
    • --disable-runtime-cpudetect 在运行时禁用cpu检测功能
    • --enable-gray 灰度支持
    • --disable-swscale-alpha 禁用在swscale alpha通道支持
    • --disable-all 禁止编译组件,库,代码
    • --disable-autodetect 禁用自动检测外部库(默认关闭)
  • program options: 程序选项


    program options.png
    • --disable-programs 不能编译命令行代码
    • --disable-ffmpeg ffmpeg禁止编译
    • --disable-ffplay ffplay禁止编译
    • --disable-ffprobe ffprobe禁止编译
    • --disable-ffserver ffserver禁止编译
  • documentation options:文件选项


    documentation options.png
    • --disable-doc 不能编译文档
    • --disable-htmlpages 不能编译html文档页面
    • --disable-manpages 不能编译操作手册文档页面
    • --disable-podpages 不能编译pod文档页面
    • --disable-txtpages 不能编译文本文档页面
  • component options:组件选项


    八.FFmepg--编译静态库(iOS)_第7张图片
    component options.png
    • --disable-avdevice 禁止 libavcodec 构造
    • --disable-avcodec 禁止 libavcore 构造
    • --disable-avformat 禁止 libavformat 构造
    • --disable-swresample 禁止 libswresample 构造
    • --disable-swscale 禁止libswscale构造
    • --disable-postproc 禁止libpostproc构造
    • --disable-avfilter 禁止libavfilter 构造
    • --enable-avresample 开启libavresample构造(默认关闭)
    • --disable-pthreads 禁用 pthreads [默认:自动]
    • --disable-w32threads 禁用 Win32 线程[默认:自动]
    • --disable-os2threads 禁用0S/2线程[默认:自动]
    • --disable-network 禁用网络支持[默认:关闭]
    • --disable-dct 禁用DCT代码
    • --disable-dwt 禁用DWT代码
    • --disable-error-resilience 禁用错误resilience 代码
    • --disable-lsp 禁用LSP代码
    • --disable-lzo 禁用LZO代码
    • --disable-mdct 禁用MDCT代码
    • --disable-rdft 禁用RDFT代码
    • --disable-fft 禁用FFT代码
    • --disable-faan 禁用浮点 AAN(I)DCT代码
  • Individual component options:个人组件选项


    八.FFmepg--编译静态库(iOS)_第8张图片
    individual component options.png
    • --disable-everything 禁止下列所有组件
    • --disable-encoder=NAME 禁止NAME的编码器
    • --enable-encoder=NAME 启用NAME的编码器
    • --disable-encoders 禁用所有编码器
    • --disable-decoder=NAME 禁用NAME的解码器
    • --enable-decoder=NAME 启用NAME的解码器
    • --disable-decoders 禁用所有的解码器
    • --disable-hwaccel=NAME 禁用NAME的硬件加速计
    • --enable-hwaccel=NAME 启用NAME的硬件加速计
    • --disable-muxer=NAME 禁用NAME的复用器
    • --enable-muxer=NAME 启用NAME的复用器
    • --disable-muxers 禁用所有的复用器
    • --disable-demuxer=NAME 禁用NAME的分离器
    • --enable-demuxer=NAME 启用NAME的分离器
    • --disable-demuxers 禁用所有的分离器
    • --enable-parser=NAME 启用NAME的解析器
    • --disable-parser=NAME 禁用NAME的解析器
    • --disable-parsers 禁用所有的解析器
    • --enable-bsf=NAME 启用NAME的比特流过滤器
    • --disable-bsf=NAME 禁用NAME的比特流过滤器
    • --disable-bsfs 禁用所有的比特流过滤器
    • --enable-protocol=NAME 启用NAME的协议
    • --disable-protocol=NAME 禁用NAME的协议
    • --disable-protocols 禁用所有的协议
    • --enable-indev=NAME 启用NAME的输入设备
    • --disable-indev=NAME 禁用NAME的输入设备
    • --disable-indevs 禁用所有输入设备
    • --enable-outdev=NAME 启用NAME的输出设备
    • --disable-outdev=NAME 禁用NAME的输出设备
    • --disable-devices 禁用所有的输出设备
    • --enable-filter=NAME 启用NAME的过滤器
    • --disable-filter=NAME 禁用NAME的过滤器
    • --disable-filters 禁用所有的过滤器
    • --disable-v412_m2m 禁用V4L2 mem2mem代码 [自动]
  • External library support:外部库支持(重点)


    八.FFmepg--编译静态库(iOS)_第9张图片
    externalLibrary Support_1.png
    • --disable-alsa 禁止ALSA支持[自动检测]
    • --disable-appkit 禁止苹果AppKit框架[自动检测]
    • --disable-avfoundation 禁止苹果AVFoundation框架[自动检测]
    • --disable-avisynth 启用读取AviSynth脚本文件[默认关闭]
    • --disable-bzlib 禁用 bzlib [自动检测]
    • --disable-coreimage 禁用苹果CoreImage框架[自动检测]
    • --enable-chromaprint Chromaprint:可提供一个客户端的公共库,能够通过特定算法计算音频文件的指纹,是AcoustID项目的核心。[默认关闭]
    • --enable-freior 启用freior视频过滤[默认关闭]
    • --enable-gcrypt 启用gcrypt,需要rtmp(t)e支持,如果openssl,librtmp,gmp没有被使用[默认关闭]
    • --enable-gmp 启用gmp,需要rtmp(t)e支持,如果openssl或者librtmp没有被使用[默认关闭]
    • --enable-gnutls 启用gnutls,需要https支持,如果opensll不能使用[默认关闭]
    • --disable-iconv 禁用iconv[自动检测]
    • --disable-jack 禁用libjack支持[自动检测]
    • --enable-jni 启用JNI支持[默认关闭]
    • --enable-ladspa 启用LADSPA 视频过滤[默认关闭]
    • --enable-libass 启用libass字幕渲染,需要字幕和ass过滤[默认关闭]
八.FFmepg--编译静态库(iOS)_第10张图片
externalLibrary Support_2.png
    • --enable-libbluray 启用蓝光,使用libbluray [默认关闭]
    • --enable-libbs2b 启用bs2b DSP库[默认关闭]
    • --enable-libcaca 启用文本显示,使用libcaca[默认关闭]
    • --enable-libcelt 启用CELT通过解码libcelt[默认关闭]
    • --enable-libcdio 启用视频CD,使用libcdio[默认关闭]
    • --enable-libdc1394 启用 IIDC-1394 ,使用libdc1394和libraw1394[默认关闭]
    • --enable-libfdk-aac 启用AAC 编码/解码通过libfdk-aac[默认关闭]
    • --enable-libflite 启用过滤器支持通过libflite
    • --enable-libfontconfig 启用libfontconfig,用于drawtext过滤器[默认关闭]
    • --enable-libfreetype 启用libfreetype,需要darwtext过滤器[默认关闭]
    • --enable-libfribidi 启用libfribidi ,优化darwtext过滤器[默认关闭]
    • --enable-libgme 启用游戏音乐通过libgme[默认关闭]
    • --enable-libgsm 启用GSM 编码/解码 通过libgsm[默认关闭]
    • --enable-libiec61883 启用 iec61883 通过使用libiec61883[默认关闭]
    • --enable-libilbc 启用iLBC 编码/解码通过libilbc[默认关闭]
    • --enable-libkvazaar 启用HEVC 编码通过使用libkvazaar[默认关闭]
    • --enable-libmodplug 启用ModPlug 通过libmodplug[默认关闭]
    • --enable-libmp3lame 启用MP3编码通过libmp3lame[默认关闭]
    • --enable-libopencore-amrnb 启用AMR-NB 编码/解码通过使用libopencore-amrnb[默认关闭]
    • --enable-libopencore-amrwb 启用AMR-WB编码通过libopencore-amrwb[默认关闭]
    • --enable-libopnecv 启用视频过滤器通过使用libopencv[默认关闭]
    • --enable-libopenh264 启用H.264编码通过OpenH264[默认关闭]
    • --enable-libopenjpeg 启用 JPEG 2000 编码/解码通过OpenJPEG[默认关闭]
    • --enable-libopenmpt 启用编码追踪文件通过libopenmpt[默认关闭]
    • --enable-libopus 启用Opus 编码/解码通过libpulse[默认关闭]
    • --enable-libpulse 启用音频脉冲输入通过使用libpulse[默认关闭]
    • --enable-librsvg 启用SVG 栅格化通过使用librsvg[默认关闭]
    • --enable-librubberband 启用拖框需要拖框过滤器[默认关闭]
    • --enable-librtmp 启用RTMP[E]支持通过使用librtmp[默认关闭]
    • --enable-libshine 启用固定点MP3编码通过使用librsvg[默认关闭]
    • --enable-libsmbclient 启用Samba协议通过使用libsmbclient[默认关闭]
    • --enable-libsnappy 启用Snappy压缩,需要hap编码[默认关闭]
    • --enable-libsoxr 启用libsoxr重采样[默认关闭]
    • --enable-libspeex 启用speex 编码/解码通过使用libspeex[默认关闭]
    • --enable-libssh 启用SFTP协议通过使用libspeex[默认关闭]
    • --enable-libtesseract 启用Tesseract,需要ocr过滤器[默认关闭]
    • --enable-libtheora 启用Theora编码通过使用libtheora[默认关闭]
    • --enable-libtwolame 启用MP2编码通过使用libtwolame[默认关闭]
    • --enable-lib412 启用libv412/v4l-utils[默认关闭]
    • --enable-libvidstab 启用基于视频图像稳定,通过使用vid.stab[默认关闭]
    • --enable-libvmaf 启用vmaf过滤器通过使用libvmaf[默认关闭]
    • --enable-libvo-amrwbenc 启用AMR-WB编码通过使用libvo-amrwbenc[默认关闭]
    • --enable-libvorbis 启用Vorbis编码/解码通过libvorbis,本地已经实现[默认关闭]
    • --enable-libvpx 启用VP8和VP9编码/解码通过使用libvpx[默认关闭]
    • --enable-libwavpack 启用wavpack编码通过使用libwavpack[默认关闭]
    • --enable-libwebp 启用WebP编码通过使用libwebp[默认关闭]
    • --enable-libx264 启用H.264编码通过使用x264[默认关闭]
    • --enable-libx265 启用HEVC编码通过使用x265[默认关闭]
    • --enable-libxavs 启用AVS编码通过使用xavs[默认关闭]
    • --enable-libxcb 启用X11抓取XCB[自动检测]
    • --enable-libxcb-shm 启用X11抓取shm交互[自动检测]
    • --enable-libxcb-xfixes 启用X11抓取mouse渲染[自动检测]
    • --enable-libxcb-shape 启用X11抓取图像渲染[自动检测]
    • --enable-libxvid 启用Xvid编码通过使用xvidcore,本地MPEG-4/Xvid编码已经存在[默认关闭]


      八.FFmepg--编译静态库(iOS)_第11张图片
      externalLibrary Support_3.png
    • --enable-libxml2 启用XML解析,使用C语言库libxml2[默认关闭]
    • --enable-libzimg 启用z.lib 需要zscale过滤器[默认关闭]
    • --enable-libzmq 启用消息传递通过使用libzmq[默认关闭]
    • --enable-libzvbi 启用点在文本支持通过使用llibzvbi[默认关闭]
    • --disable-lzma 禁用lzma[自动检测]
    • --enable-decklink 启用黑魔法 DeckLind I/O支持[默认关闭]
    • --enable-libndi_newtek 启用Newteck NDI I/O支持[默认关闭]
    • --enable-mediacodec 启用安卓媒体编解码器支持[默认关闭]
    • --enable-libmysofa 启用libmysofa,需要sofalizer过滤器[默认关闭]
    • --enable-openal 启用OpenAL 1.1 捕获支持[默认关闭]
    • --enable-onencl 启用OpenCl代码
    • --enable-opengl 启用OpenGL渲染[默认关闭]
    • --enable-openssl 启用openssl,需要https支持,如果没有使用[默认关闭]
    • --disable-sndio 禁用sndio支持[自动检测]
    • --disable-schannel 禁用 schannel SSP,需要TLS支持在Windows,如果openssl 和gnutls没有使用[自动检测]
    • --disable-sdl2 禁用sdl2[自动检测]
    • --disable-securetransport 禁用 安全传输,需要TLS支持在OSX如果openssl和gnutls没有使用[自动检测]
    • --disable-xlib 禁用xlib[自动检测]
    • --disable-zlib 禁用zlib[自动检测]
    • --disable-audiotoolbox 禁用苹果AUdioToolbox代码[自动检测]
    • --disable-cuda 禁用动态链接Nvidia CUDA代码[自动检测]
    • --enable-cuda-sdk 启用CUDA特性,需要CUDA SDK[自动检测]
    • --disable-cuvid 禁用 Nvidia CUVID 支持[自动检测]
    • --disable-d3d11va 禁用Microsof Direct3D 11 视频加速器代码[自动检测]
    • --disable-dxva2 禁用Microsof DirectX 9 视频加速器代码[自动检测]
    • --enable-libdrm 启用DRM代码(Linux)[默认关闭]
    • --enable-libmfx 启用Intel MediaSDK代码通过时会用libmfx[默认关闭]
    • --enable-libnpp 启用Nvidia性能基本代码[默认关闭]
    • --enable-mmal 启用多媒体抽象层通过使用MMAL[默认关闭]
    • --disable-nvenc 禁用Nvidi视频编码代码[自动检测]
    • --enable-omx 启用OpenMAX IL 代码[默认关闭]
    • --enable-omx-rpi 启用OpenMAX IL 代码树莓派[默认关闭]
    • --enable-rkmpp 启用媒体平台代码[默认关闭]
    • --disable-vaapi 禁用视频加速器API代码[自动检测]
    • --disable-vda 禁用苹果视频解码加速器代码[自动检测]
    • --disable-vdpau 禁用Nvidia视频解码和展示Unix代码的API[自动检测]
    • --disable-videotoolbox 禁用VideoToolbox代码[自动检测]
  • Toolchain options:工具链选项(指定需要编译平台CPU架构类型,arm64,x86,arm7等等)


    八.FFmepg--编译静态库(iOS)_第12张图片
    toolchain options.png
    • --arch=ARCH 选择体系结构
    • --cpu=CPU 选择最小需要的CPU
    • --cross-prefix=PREFIX 使用前缀为编译的工具
    • --progs-cross-compile 程序名后缀
    • --sysroot=PATH 根交叉构建树
    • --sysinclude=PATH 编译系统头文件的路径
    • --target-os=OS 编译平台系统
    • --target-exec=CMD 执行的目标文件
    • --target-path=DIR 编译母的的路径
    • --target-samples=DIR 样例目录的路径
    • --tempprefix=PATH 固定目录/前缀代替mktmep的检查
    • --toolchain=NAME 设置tool默认名
    • --nm=NM 使用nm工具NM[nm -g]
    • --ar=AR 使用归档工具AR[ar]
    • --as=AS 使用汇编程序AS
    • --ln_s=LN_S 使用特殊符号链接工具LN_S[ln -s -f]
    • --strip=STRIP 使用带工具条工具STRIP[strip]
    • --windres=WINDRES 使用windows资源编译WINDRES[windres]
    • --x86asmexe=EXE 使用nasm-compatible汇编程序EXE[nasm]
    • --cc=CC 使用C编译CC[gcc]
    • --cxx=CXX 使用C编译CXX[g++]
    • --objcc=OCC 使用ObjC编译OCC[gcc]
    • --dep-cc=DEPCC 使用依赖生成器DEPCC[gcc]
    • --nvcc=NVCC 使用Nvidia CUDA编译NVCC[nvcc]
    • --ld=LD 使用链接者LD[]
    • --pkg-config=PKGCONFIG 使用包配置工具PKGCONFIG[pkg-config]
    • --pkg-config-flags=FLAGS 通过额外的标志到pkgconf []
    • --ranlib=RANLIB 使用ranlib RANLIB[ranlib]
    • --doxygen=DOXYGEN 使用DOXYGEN生成API文档[doxygen]
    • --host-cc=HOSTCC 使用host C 编译HOSTCC
    • --host-cflags=HCFLAGS 使用HCFLAGS编译host
    • --host-cpflags= HCPPELAGS 使用HCPPELAGS编译host
    • --host-ld=HOSTLD 使用host链接HOSTLD
    • --host-ldflags=HLDFLAGS 使用HLDFLAGS 链接host
    • --host-libs=HLIBS 使用库HLIBS链接host
    • --host-os=OS 编译host系统[]
    • --extra-cflags=ECFLAGS 添加ECFLAGS到CFLAGS []
    • --extra-cxxflags=ECFLAGS 添加ECFLAGS到CXXFLAGS []
    • --extra-objcflags=FLAGS 添加FLAGS到OBJCFLAGS []
    • --extra-ldflags=ELDFLAGS 添加ELDFLAGS到LDFLAGS[]
    • --extra-ldexeflags=ELDFLAGS 添加ELDFLAGS到LDEXEFLAGS []
    • --extra-ldlibflags=ELDFLAGS 添加ELDFLAGS 到LDLIBFLAGS []
    • --extra-libs=ELIBS 添加ELIBS []
    • --extra-version=STRING 版本字符串后缀[]
    • --optflags=OPTFLAGS 重载优化相关的编译器
    • --nvccflags=OPTFLAGS 重载nvcc [-gencode arch=compute_30,code=sm_30 -02]
    • --build-suffix=SUFFIX 库名的后缀 []
    • --enable-pic 编译位置独立的代码
    • --enable-thumb 编译thumb指令集
    • --enable-lto 使用链接时优化
    • --env="ENV=override" 重载环境变量
  • Advanced options:高级选项


    八.FFmepg--编译静态库(iOS)_第13张图片
    advanced options.png
    • --malloc-prefix=PREFIX 分配内存与相关名字的前缀
    • --custom-allocator=NAME 使用受支持的自定义分配程序
    • --disable-symver 禁用符号版本控制
    • --enable-hardcoded-tables 使用硬编码表代替运行时生成
    • --disable-safe-bitstream-reader 在bitread时,禁止缓冲器边界check
    • --sws-max-filter-size=N 最大过滤size[默认256]
  • Optimization options (experts only):优化选项


    八.FFmepg--编译静态库(iOS)_第14张图片
    optimization options.png
    • --disable-asm 禁止所有优化
    • --disable-altivec 禁止单指令流多数据流优化
    • --disable-vsx 禁止VSX优化
    • --disable-power8 禁止POWER8优化
    • --disable-amd3dnow 禁止3DNow!优化
    • --disable-amd3nowext 禁止3DNow!扩展优化
    • --disable-mmx 禁止MMX优化
    • --disable-mmxext 禁止MMXEXT优化
    • --disable-sse 禁止SSE优化
    • --disable-sse2 禁止SSE2优化
    • --disable-sse3 禁止SSE3优化
    • --disable-sse4 禁止SSE4优化
    • --disable-sse42 禁止SSE4,2 优化
    • --disable-avx 禁止AVX优化
    • --disable-xop 禁止XOP优化
    • --disable-fma3 禁止FMA3优化
    • --disable-fma4 禁止FMA4优化
    • --disable-avx2 禁止AVX2优化
    • --disable-aesni 禁止AESNI优化
    • --disable-armv5te 禁止armv5te 优化
    • --disable-armv6 禁止armv6优化
    • --disable-armv6t2 禁止armv6t2优化
    • --disable-vfp 禁止VFP优化
    • --disable-neon 禁止NEON优化
    • --disable-inline-asm 禁止使用内联汇编
    • --disable-x86asm 禁止使用独立的x86汇编
    • --disable-mipsdsp 禁止MIPS DSP ASE R1优化
    • --disable-mipsdspr2 禁止MIPS DSP ASE R2 优化
    • --disable-msa 禁止MSA优化
    • --disable-mipsfpu 禁止浮点MIPS优化
    • --disable-mmi 禁止处理器SIMD优化
    • --disable-fast-unaligned 考虑未对齐的访问缓慢
  • Developer options:开发者选项


    八.FFmepg--编译静态库(iOS)_第15张图片
    developer options.png
    • --disable-debug 禁止调试
    • --enable-debug=LEVEL 设置调试等级
    • --disable-optimizations 禁止编译器优化
    • --enable-extra-warnings 启用多个编译器警告
    • --disable-stripping 删除可执行文件和共享库
    • --assert-level=level 0(默认),1或者2,断言测试的数量,2导致运行时减速
    • --enable-memory-poisoning 用任意的数据运行填充未初始化的空间,通过valgrind进行测试,以使用指定的valgrind二进制代码来检测内存泄漏和错误。
    • --valgrind=VALGRIND 运行测试通过valgrind检测内存泄漏和错误,使用指定的valgrind二进制
    • --enable-ftrapv 算术溢出
    • --samples=PATH 测试样品路径,如果在调用是时间没有设置$FATE_SAMPLES
    • --enable-neon-clobber-test 检查NEON寄存器(仅用于调试目的)
    • --enable-xmm-clobber-test 检查XMM寄存器(仅仅Win64,仅用于调试目的)
    • --enable-random 任意地启用组件
    • --disable-random 任意地禁用组件
    • --enable-random=LIST 随机启用特定组件或组件组,列表是一个以逗号分隔的名称[:PROB],PROB与组件名相关,默认值是0.5
    • --disable-random=LIST 随机禁用特定组件或组件组,列表是一个以逗号分隔的名称[:PROB],PROB与组件名相关,默认值是0.5
    • --random-seed=VALUE 根据值来启用/禁用random
    • --disable-valgrind-backtrace 不能在Valgrind下输出向后追踪
    • --enable-osfuzz 支持构建fuzzer工具
    • --libfuzzer=PATH libfuzzer的路径
    • --ignore-tests=TESTS 测试列表的结果是可以忽略
    • --enable-linux-perf 使用Linux性能监视器API

把这些options(选项)终于翻译完了,到这一步,笔者确实累了.
1.要把英文翻译过来,
2.结合技术词汇进行翻译.
这里选项大家根据自己需要各取所需,加入到自己编译shell中.

4.下载gas-preprocessor.pl及安装

  • 下载
    同样有两种办法:
一: github地址:https://github.com/libav/gas-preprocessor 
二: 到我的github下载:请查看文章底部
把gas-preprocessor.pl文件与执行sh文件放到同一目录下.
八.FFmepg--编译静态库(iOS)_第16张图片
sh_pl同一目录.png
  • 安装
    同样两种办法:
一:
1. 下载最新的gas-preprocessor.pl
2.右键点Finder->前往文件夹,输入/usr,
在里面新建local文件夹,进入local文件夹中![C compiler test failed.png]
(http://upload-images.jianshu.io/upload_images/2960658-41ad8a2bf4758ada.png?
imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
再新建bin文件夹,
拷贝下载的gas-preprocessor.pl到该目录下;
3. 打开终端,输入 chmod 777 /usr/local/bin/gas-preprocessor.pl
二:
1.下载gas-preprocessor安装包
2.复制gas-preprocessor.pl到/usr/sbin下
3.chmod 777 /usr/local/bin/gas-preprocessor.pl

5.编写脚本代码

  • 定义下载库名称
source="ffmpeg-3.4"
  • 定义".h/.mm/.c文件编译的结果目录"
cache="cache"
  • 定义.a静态库保存目录
staticdir=`pwd`/"lk-ffmpeg-iOS"
  • 添加FFmpeg配置选项->默认配置
Toolchain options:工具链选项(指定我们需要编译平台CPU架构类型)
--enable-cross-compile:交叉编译
--enable-pic:允许建立与位置无关代码
Developer options:开发者选项
--disable-debug:禁止使用调试模式
Program options选项
--disable-programs:禁用程序(不允许建立命令行程序)
Documentation options:文档选项
--disable-doc:不需要编译文档
configure_flags="--enable-cross-compile --disable-debug --disable-programs 
--disable-doc --enable-pic"
  • 定义默认CPU平台架构类型
arm64 armv7->真机->CPU架构类型
x86_64 i386->模拟器->CPU架构类型
archs="arm64 armv7 x86_64 i386"
  • 指定我们的这个库编译系统版本-iOS系统7.0以及以上版本使用这个静态库
targetversion="7.0"
  • 接受命令后输入参数
动态接受命令输入CPU平台架构类型
if [ "$*" ]
then
       #存在输入参数,也就说:外部指定需要编译CPU架构类型
       archs="$*"
fi
  • 安装汇编器->yasm
下载yasm最新版本:http://www.tortall.net/projects/yasm/releases/ 
首先判断是否存在汇编器,然后通过软件管理器,下载安装汇编器
if [  ! `which yasm` ]
then
        if [ ! `which brew` ]
        then
               echo "安装brew"
               ruby -e "$(curl -fsSL
 https://raw.githubusercontent.com/Homebrew/install/master/install)" || exit 1
        fi
        echo "安装yasm"
        brew install yasm || exit 1
fi 
  • for循环编译FFmpeg静态库
currentdir=`pwd`
for arch in #archs
do
    echo "开始编译"
    #创建目录
    mkdir -p "$cache/$arch"
    #进入这个目录
    cd "$cache/$arch"
    #配置编译CPU架构类型->指定当前编译CPU架构类型
    archflags="-arch $arch"
    #判定一下是编译的模拟器.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
                  #程序运行时,变量访问越界问题
                  EXPORT="GASPP_FIX_XCODE5=1"  
          fi
fi
  • 编译
将platform->转成大写或者小写
  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
--target-os:目录系统->darwin(mac系统早期版本)
--arch:CPU平台架构类型
--cc:指定编译器类型选项
--as:汇编程序
$configure_flags最初配置
--extra-cflags
--prefix:静态库输出目录
 TMPDIR=${TMPDIR/%\/} $currentdir/$source/configure \
          --target-os=darwin \
          --arch=$arch \
          --cc="$CC" \
          --as="$AS" \
          $configure_flags \
          --extra-cflags="$archflags" \
          --extra-ldflags="$archflags" \
          --prefix="$staticdir/$arch" \
          || exit 1
    #执行命令 安装导出静态库
    make -j3 install $EXPORT || exit 1
    #回到了我们的脚本文件目录
    cd $currentdir
done

6.执行脚本结果一览

  • 执行成功后,这里需要等待一小会时间,此时,你可以放首音乐听听,等待一下
    我们可以在文件夹中看到


    八.FFmepg--编译静态库(iOS)_第17张图片
    运行结果1.jpg
八.FFmepg--编译静态库(iOS)_第18张图片
运行结果2.jpg
八.FFmepg--编译静态库(iOS)_第19张图片
运行结果_3.png
八.FFmepg--编译静态库(iOS)_第20张图片
运行结果_4.png

7.编译过程中遇到的问题

  • 执行文件报警告


    执行shell提示.png

    这里需要您给脚本授权

一.
chmod +x 脚本名
二.
chmod 777 脚本名
  • 把我的源码下载后,编译时出错了


    编译报错.png
    • 没有这样的文件和路径


      八.FFmepg--编译静态库(iOS)_第21张图片
      此时文件夹内容.png
    • 你没有把下载的MMpage压缩包放在该目录下,可见不报错都难.
  • 语法错误
    特别注意:虽然把代码写完了,进行编译的时候老是出错,你又很难检查出错误.注意下图语法变动,正确的使用,确保你的编译通过,否则反反复复修改,还是找不到问题的关键.

八.FFmepg--编译静态库(iOS)_第22张图片
语法错误1.jpg
八.FFmepg--编译静态库(iOS)_第23张图片
语法错误2.jpg
  • GNU assembler not found, install/update gas-preprocessor
八.FFmepg--编译静态库(iOS)_第24张图片
GNU assembler not found, install:update gas-preprocessor.png
如果这一步出错,因为没有把pl文件放在同一目录下,才导致的错误.
所以您可以最新下载的pl文件,放在同一目录下进行编译.
那就需要您查看第四步操作进行下载和安装
  • C compiler test failed
八.FFmepg--编译静态库(iOS)_第25张图片
C compiler test failed.png
1.打开终端。
输入并回车
cd /Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.
platform/developer/SDKs/
然后输入 
ls 
可以查看到你当前iOS SDK的版本
2.修改iOS SDK版本。
3.再次执行脚本

8.个人总结

好了,到这里呢?

您就完成了FFmepg--静态库的编译,

容易出错的地方呢?

  • 文件未授权

  • 语法错误

  • 下载的文件并没有放在同一目录下

    • gas-preprocessor.pl
    • FFmepg解压包
      ...

当您完成这些操作,还是蛮有成就的,

编译自己想要的静态库,需要花费时间,需要静心等待,

编译出错就需要您想办法解决,

个人觉得写编译脚本不是一件困难的事,关键是遇到了编译出错的问题,你是否可以自己解决.

考验了一下个人能力时候到了,如果您觉得对您有帮助,请您来一波鲜花和赞.

以上遇到几种编译问题呢?是个人遇到的,如果您也遇到了其他的问题呢,自己解决了,也可以发给我,我把您的问题和解决方法也加上去,希望帮助更多的小伙伴.

如果有什么问题咱么可以交流一下,借用名人Dream的一句话,"有问题就要提出来,不要憋着,否则憋出内伤".

如果需要FFmepg--shell的编译及下载源代码,请到我的github下载:
https://github.com/LK26/FFmepg--shell
...
...
...
如果需要转载,请注明原著地址哦,非常感谢!!

你可能感兴趣的:(八.FFmepg--编译静态库(iOS))