FFmpeg for iOS 3.4 编译与集成
FFmpeg是一套开源的多媒体处理方案,可以应用于流媒体或直播中,能够实现音视频的编解码以及其他音视频处理等,非常强大。这里简单介绍iOS平台的FFmpeg静态库的编译与集成。
1.下载编译脚本
点击此链接,进入github下载编译脚本:GitHub - kewlbear/FFmpeg-iOS-build-script: Shell scripts to build FFmpeg for iOS and tvOS
下载完成并解压后得到:
2.运行编译脚本
打开终端,进入文件目录,运行命令行./build-ffmpeg.sh
编译过程中可能会遇到的错误:
1、报错yasm没有安装,按提示操作安装
2、报错"xcrun -sdk iphoneos clang is unable to create an executable file.",运行命令行sudo xcode-select --switch /Applications/Xcode.app/Contents/Developer/
后重新编译
3、报错"src/libavutil/arm/asm.S:50:9: error: unknown directive .arch armv7-a",将编译脚本build-ffmpeg.sh中ARCHS="arm64 armv7 x86_64 i386"
的armv7
去掉后重新编译
编译会花费一段时间,如果终端没有报错并显示如下,说明编译成功:
编译完成这个时候目录下会生成编译后的静态库及源码,如下图:
编译完成后的目录其中,FFmpeg-iOS
即是我们需要用到的framework
3.集成FFmpeg-iOS
将整个FFmpeg-iOS文件夹拖入工程中,并引入相关的头文件,例如:
#import "libavcodec/avcodec.h"
,如果报错'libavcodec/avcodec.h' file not found
解决方法如下:
在工程的Build Settings中搜索search
,找到Header Search Paths
与Library Search Paths
,将Library Search Paths
中的ffmpeg的lib路径$(PROJECT_DIR)/FFmpegTest/FFmpeg-iOS/lib
复制粘贴到Library Search Paths
中,并将lib
改为include
如果还出现了链接报错clang: error: linker command failed with exit code 1 (use -v to see invocation),可能是因为缺少系统库,需要#import <VideoToolbox/VideoToolbox.h>
,并且需要在工程Build Phases中的Link Binary With Libraries
中Add items:libz.1.2.5.tbd
、libbz2.1.0.tbd
、libiconv.2.4.0.tbd
,成功编译。