Ijkplayer默认支持的编解码格式较少,且不支持https协议。若想获得更多的编解码和功能支持,就需要通过编译源码来实现。虽然网上相关的资料也有不少,但这些资料的质量参差不齐,一路走来踩坑不断。故总结此篇,以作备忘,也希望能为需要的童鞋提供一些帮助。
注:文末附有so文件的下载链接,不想自行编译的小伙伴们,也可直接下载使用。
一、编译环境
- ubuntu-18.04.1 (教程: Win10使用VMware14安装Ubuntu系统)
- android-ndk-r10e (提取码: cue8)
- android-sdk_r24.4.1 (提取码: krys)
- jdk1.8.0_181 (提取码: 78rd )
- ijkplayer-android k0.8.8
注: ndk最低支持r10e,且目前不支持r15c,推荐使用r10e版本;
二、编译环境搭建
1. 安装相关工具:
1. 更新: sudo apt-get update
2. 安装git: sudo apt-get install git
3. 安装yasm: sudo apt-get install yasm
4. 提供C/C++编译环境: sudo apt-get install build-essential
2. 配置JDK、SDK、NDK环境变量:
在Ubuntu终端执行命令:
sudo gedit /etc/profile
此时会打开/etc/profile文件的编辑页面,在文件末尾添加JDK、SDK、NDK的环境变量,参考如下:
#set jdk environment 校验:java -version
export JAVA_HOME=/home/guan/Android/jdk1.8.0_181
export JRE_HOME=${JAVA_HOME}/jre
export CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib
export PATH=${JAVA_HOME}/bin:${JRE_HOME}/bin:$PATH
#set ndk environment 校验:ndk-build -v
export ANDROID_NDK=/home/guan/Android/android-ndk-r10e
export PATH=$ANDROID_NDK:$PATH
#set sdk environment 校验:adb version
export ANDROID_HOME=/home/guan/Android/android-sdk-linux
export PATH=${ANDROID_HOME}/tools:${ANDROID_HOME}/platform-tools:$PATH
保存文件修改后,回到终端执行如下命令,使配置的环境变量立即生效:
source /etc/profile
校验:分别执行java -version
、ndk-build -v
、adb version
来检验JDK、NDK和SDK配置的环境变量是否生效。若出现如下图所示的信息,则说明对应的配置生效:
注意:相比Windows版本的SDK,Linux版本的SDK会缺少一些工具,这些工具需要我们手动去下载。执行android avd
命令,打开SDK Manager,下载最新的 Android SDK Tools
、Android SDK Platform-tools
和 Android SDK Build-tools
,然后再下载一个最新的 Android SDK Platform
即可~
3. 使用bash代替dash来执行shell脚本:
执行命令:sudo dpkg-reconfigure dash
,弹出如下弹框时选择:<否>
三、编译ijkplayer-android
- 拉取代码:
git clone https://github.com/Bilibili/ijkplayer.git ijkplayer-android
//进入根目录
cd ijkplayer-android
//切换到稳定分支
git checkout -B latest k0.8.8
- 修改编译配置文件 (可选项,若不修改则默认使用
module-lite.sh
) :
官方给我们提供了三个模板module-default.sh
、module-lite.sh
和module-lite-hevc.sh
,默认使用module-lite.sh
进行编译,它支持的编解码格式较少,so文件也较小 (5M左右),module-default.sh
支持的编解码格式最全,so文件也最大(12M左右)。也可在module.sh
文件中,通过更改enable/disenable
自行修改。
- If you prefer more codec/format
cd config
rm module.sh
ln -s module-default.sh module.sh
cd ..
- If you prefer less codec/format for smaller binary size (include hevc function)
cd config
rm module.sh
ln -s module-lite-hevc.sh module.sh
cd ..
- If you prefer less codec/format for smaller binary size (by default)
cd config
rm module.sh
ln -s module-lite.sh module.sh
cd ..
注意:若使用module-default.sh
替代module.sh
文件,则执行./compile-ffmpeg.sh all
编译时会报错:fatal error: linux/perf_event.h: No such file or directory
解决方案是在module.sh文件末尾添加一行:export COMMON_FF_CFG_FLAGS="$COMMON_FF_CFG_FLAGS --disable-linux-perf"
- 初始化,拉取ffmpeg:
./init-android.sh
- 拉取openssl Android源码,使其支持Https:
./init-android-openssl.sh
- 编译各个平台的编译openssl和ffmpeg:
cd android/contrib
//编译各平台的openssl
./compile-openssl.sh clean
./compile-openssl.sh all
//编译ffmpeg软解码库
./compile-ffmpeg.sh clean
./compile-ffmpeg.sh all
- 编译ijkplayer native code:
cd ..
./compile-ijk.sh all
编译完成后,即可在相应的CPU架构目录下找到对应的so库文件,如下图:
附so文件下载链接:
默认配置module-lite.sh
对应的so文件(提取码:73nz);
支持较全格式module-default.sh
对应的so文件(提取码:kwyy);