美文网首页iOS开发攻城狮的集散地ijkplayeriOS开发笔记
ijkplayer 的编译、打包 framework 和 htt

ijkplayer 的编译、打包 framework 和 htt

作者: hext123 | 来源:发表于2018-04-10 14:12 被阅读721次

ijkplayerbilibili 开源的一款优秀的播放器, 基于 FFmpeg, 支持 iOS/Android, 点播/直播, 以及多种编码. 官方并不直接提供 framework 框架包, 这样大家可以根据需要选择配置, 自己编译并打包. 但是也让很多第一次使用的小伙伴一脸懵逼, 并且默认配置只支持 http, 如果想播放 https 链接的视频, 那么需要做额外的配置

本文为 iOS 的编译打包过程, 环境为 Mac + Xcode

准备工作

安装 homebrew, git, yasm. (如果已经安装好可以跳过, 不清楚的再来一遍也无妨)

ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
brew install git
brew install yasm

获取 ijkplayer 源码

在一个合适的位置新建一个文件夹, 假设为桌面, 文件夹名为 ijkplayer.

打开终端, 输入下面的指令

# 进入到刚刚新建的文件夹内
cd ~/Desktop/ijkplayer/

# 获取ijkplayer源码
git clone https://github.com/Bilibili/ijkplayer.git ijkplayer-ios

# 进入源码目录
cd ijkplayer-ios

# 切换分支 (目前为k0.8.8, 可以自行去GitHub查看最新版本号)
git checkout -B latest k0.8.8

配置编解码器格式支持

默认为最少支持, 如果足够你使用, 可以跳过这一步. 否则可以改为以下配置:

  • module-default.sh 更多的编解码器/格式
  • module-lite-hevc.sh 较少的编解码器/格式(包括hevc)
  • module-lite.sh 较少的编解码器/格式(默认情况)
# 进入 config 目录
cd config

# 删除当前的 module.sh 文件
rm module.sh

# 可根据需要替换为`module-default.sh`, `module-lite-hevc.sh`, `module-lite.sh`
# 创建软链接 module.sh 指向 module-lite-hevc.sh
ln -s module-lite-hevc.sh module.sh

cd ..
cd ios
sh compile-ffmpeg.sh clean

获取 ffmpeg 并初始化

cd ..
./init-ios.sh

添加 https 支持

最后会生成支持 https 的静态文件 libcrypto.alibssl.a, 如果不需要可以跳过这一步

# 获取 openssl 并初始化
./init-ios-openssl.sh

cd ios

# 在模块文件中添加一行配置 以启用 openssl 组件
echo 'export COMMON_FF_CFG_FLAGS="$COMMON_FF_CFG_FLAGS --enable-openssl"' >> ../config/module.sh

./compile-ffmpeg.sh clean

编译

# 如果下一步提示错误`xcrun: error: SDK "iphoneos" cannot be located`, 请执行`sudo xcode-select --switch /Applications/Xcode.app/Contents/Developer/`, 再重新执行下一步

# 编译openssl, 如果不需要https可以跳过这一步
./compile-openssl.sh all

# 编译ffmpeg
./compile-ffmpeg.sh all

ps: 如果提示错误:

./libavutil/arm/asm.S:50:9: error: unknown directive
        .arch armv7-a
        ^
make: *** [libavcodec/arm/aacpsdsp_neon.o] Error 1

最新的 Xcode 已经弱化了对 32 位的支持, 解决方法:
compile-ffmpeg.sh 中删除 armv7 , 修改如:
FF_ALL_ARCHS_IOS8_SDK="arm64 i386 x86_64"
再重新执行出现错误的命令: ./compile-ffmpeg.sh all

打开 IJKMediaPlayer 项目

用命令:

open IJKMediaPlayer/IJKMediaPlayer.xcodeproj

或者手动用 Xcode 打开 ios 目录下的 IJKMediaPlayer 项目.

添加 openssl 相关包以支持 https

如果不使用 https, 可以跳过此步, 直接开始打包 framwork

如果使用 https, 那么需要手动给 IJKMediaFramework 添加 libcrypto.alibssl.a 文件, 默认不会添加

ps: 这两个依赖库的目录为: ijkplayer-ios/ios/build/universal/lib, 只有进行了上面跟 openssl 相关的操作, 才会在这个目录下有生成 libcrypto.alibssl.a

WX20180408-234339@2x.pngWX20180408-234339@2x.png

打包 framwork

大家会发现除了 IJKMediaFramework 这个 target, 还有一个叫 IJKMediaFrameworkWithSSL, 但是不推荐使用这个, 因为大部分基于 ijkplayer 的第三方框架都是使用的前者, 你把后者导入项目还是会报找不到包的错误, 就算你要支持 https 也推荐使用前者, 然后按照上一步添加 openssl 即可支持

  1. 配置 Release 模式如果下图

    WX20180408-234722@2x.pngWX20180408-234722@2x.png
    WX20180408-234922@2x.pngWX20180408-234922@2x.png
  2. 打包真机 framework

    选择你连接的手机或者 Generic iOS Device

    WX20180408-235726@2x.pngWX20180408-235726@2x.png

    如图操作,然后按键 command+b 编译即可

    如果之前的步骤删除了 compile-ffmpeg.sharmv7, 这里会报错, 我们直接注释掉就好

    WX20180408-235314@2x.pngWX20180408-235314@2x.png
    WX20180408-235507@2x.pngWX20180408-235507@2x.png
  3. 打包模拟器 framework

    WX20180408-235921@2x.pngWX20180408-235921@2x.png

    如图操作,然后 command+b 编译即可

  4. 合并 framework

    如果只需要真机运行或者模拟器运行, 可以不用合并, 直接找到对应的 framework 导入项目即可; 一般我们为了方便会合并 framework, 这样就同时支持模拟器和真机运行.

    先找到生成 framework 的目录:

    WX20180409-001503@2x.pngWX20180409-001503@2x.png
    WX20180409-001745@2x.pngWX20180409-001745@2x.png

    准备合并:

    打开终端, 先 cdProducts 目录下

    然后执行: lipo -create 真机framework路径 模拟器framework路径 -output 合并的文件路径

    lipo -create Release-iphoneos/IJKMediaFramework.framework/IJKMediaFramework Release-iphonesimulator/IJKMediaFramework.framework/IJKMediaFramework -output IJKMediaFramework
    

    合并完成:

    可以看到这里生成了一个大概两倍大小的文件, 将生成的 IJKMediaFramework 文件替换掉 真机framework 中的 IJKMediaFramework 文件,然后这个替换掉文件的 真机framework 就是我们需要的 通用的framework 了。

    WX20180409-002747@2x.pngWX20180409-002747@2x.png
    WX20180409-003815@2x.pngWX20180409-003815@2x.png

集成 framework 到项目中

  • 导入 framework

    直接将 IJKMediaFramework.framework 拖入到工程中即可

    注意记得勾选 Copy items if needed 和 对应的 target

  • 添加下列依赖到工程

    1. libc++.tbd ( 编译器选 gcc 的请导入 libstdc++.tbd )
    2. libz.tbd
    3. libbz2.tbd
    4. AudioToolbox.framework
    5. UIKit.framework
    6. CoreGraphics.framework
    7. AVFoundation.framework
    8. CoreMedia.framework
    9. CoreVideo.framework
    10. MediaPlayer.framework
    11. MobileCoreServices.framework
    12. OpenGLES.framework
    13. QuartzCore.framework
    14. VideoToolbox.framework

导入 ijkplayer 头文件运行一下项目, 如果遇到了类似这样的错误:

WX20180409-005101@2x.pngWX20180409-005101@2x.png

可能是因为导入的依赖库不全, 比如缺少 libc++.tbd, 请再次对照添加好所有的依赖库:

WX20180409-005102@2x.pngWX20180409-005102@2x.png

相关文章

网友评论

  • 迷曳:合并后 IJKMediaFramework.framework 大约有400M,是不是太大了
  • 天空是观众:你好,想问一下在模拟器下编译不通过
    Undefined symbols for architecture x86_64:
    "_readdir$INODE64", referenced from:
    _file_read_dir in IJKMediaFramework(file.o)
    "_opendir$INODE64", referenced from:
    _file_open_dir in IJKMediaFramework(file.o)
    ld: symbol(s) not found for architecture x86_64
    clang: error: linker command failed with exit code 1 (use -v to see invocation)
  • 肆意二货:你好,请问我如果不支持armv7,上架的时候是否会有影响?
    肆意二货:如果不支持https能否上架?就是不支持https也不支持rtsp。只需要http的直播流地址。
    肆意二货:@hext123 你不支持32位机器,上架了么?
    hext123:@肆意二货 上架后不支持32位设备
  • xx明:对于一个线上的mp4视频,如果既支持https也支持http。用ijkplayer播放其中一个,另外一个就会播放失败,这个是什么原因
    hext123:@xx明 方便给url试试吗,按理说没这个问题的
  • 自在轻梦:楼主你好、静态库神马的我都搞好了、
    但是在导入自己项目时候播放不了、打印信息如下
    ijkmediaplayer version : k0.8.8===== custom modules begin =====
    register demuxer : ijklivehook
    ===== custom modules end =====
    av_version_info: ff3.4--ijk0.8.7--20180103--001
    ijk_version_info: k0.8.8
    ijkmp_set_inject_opaque(0x170004190)
    ijkmp_set_inject_opaque()=void
    ijkmp_set_ijkio_inject_opaque(0x170004190)
    ijkmp_set_ijkio_inject_opaque()=void
    2018-07-20 15:47:12.236173+0800 AFYike[9682:3231496] libMobileGestalt MobileGestaltSupport.m:153: pid 9682 (AFYike) does not have sandbox access for frZQaeyWLUvLjeuEK43hmg and IS NOT appropriately entitled
    2018-07-20 15:47:12.236253+0800 AFYike[9682:3231496] libMobileGestalt MobileGestalt.c:550: no access to InverseDeviceID (see <rdar://problem/11744455>)
    2018-07-20 15:47:12.260367+0800 AFYike[9682:3231496] OK setup GL
    ijkmp_ios_set_view(glView=0x10143c440)
    ijkmp_ios_set_view(glView=0x10143c440)=void
    2018-07-20 15:47:12.283625+0800 AFYike[9682:3231496] invalidateRenderBuffer
    2018-07-20 15:47:12.284696+0800 AFYike[9682:3231632] IJKSDLGLView: setupDisplay not ready
    能帮忙看下嘛? 谢谢啦、急求!!!
  • 最讨厌梅雨天啦:wc,我怎么没有早点看到这个教程,😭折腾半天为了openssl的那几个.a文件
  • 不会游泳的飞鱼:是不是通过设置setoptions
  • 不会游泳的飞鱼:您好,如果我想播放在线视频需要携带请求头,应该怎么设置
  • 小小溪001:你们都咋解决的呢????我也遇见这样的问题了。。。
  • 77d299e2ecdc:最新的 Xcode 已经弱化了对 32 位的支持
    像你说的那样删除了armv7,打包成的release模式下的真机framework,在我自己的项目选择release模式的时候运行,报错了....好多错,大致意思是release模式下不能没有armv7,求解决办法
    77d299e2ecdc:我发现新版本的ijk不能播放rmvb格式视频
    77d299e2ecdc:@hext123 嗯,一开始我的思路也是armv7删除,后来发现release模式问题,然后看到了你的文章,挺不错的,现在在研究它的源码
    hext123:呃~ 确实是这样. 那现在就只有两个办法:
    1. 用Xcode9.3之前的版本打包 ijkplayer
    2. 去项目设置: target -> build settings -> architectures -> valid architectures 删除 armv7 (不过这样你的APP应该不支持32位的老机器了)

本文标题:ijkplayer 的编译、打包 framework 和 htt

本文链接:https://www.haomeiwen.com/subject/ggtnhftx.html