libYuv编译

简介: 安卓使用NDK编译libYuv库

前言

前面几篇写的都是Opengl ES的系列博文,并且都涉及到了YUV与RGB的转换,为了完善YUV与RGB相关的知识点,这里加写一篇关于libyuv交叉编译的博文,算是yuv这一系列的结束,后续继续Opengl ES的写了撰写。

做过音视频开发的童鞋们一定对libyuv这个库不陌生,利用这个库不但可以做yub到rgb颜色空间的互相转换,还可以进行图像的放大缩小、旋转等形变转换。

libyuv 是谷歌开源的对 YUV 数据进行缩放、旋转和转换的跨平台库,可在 Windows、Linux、Mac、Android 等操作系统,x86、x64、arm 架构上进行编译运行,支持 AVX2、NEON 等 SIMD 指令加速。

NDK编译libyuv

笔者的编译环境是MacOS M1芯片版。因为本文使用的是cmake编译,因此没有安装cmake的童鞋请先安装cmake。

libyuv的源码地址:https://chromium.googlesource.com/libyuv/libyuv

例如笔者下载解压后的文件名是libyuv-refs_heads_main,这个地址的源码下载可能需要点技巧,如果无法访问,可以到github上寻找相应的源码...

然后编写编译脚本build_yuv.sh:

#!/bin/bash
mkdir build
cd build
# 注意替换成你的NDK路径
NDK_PATH=/Users/fly/Documents/Android/SDK/ndk/21.4.7075529
TOOLCHAIN=$NDK_PATH/toolchains/llvm/prebuilt/darwin-x86_64

PREFIX=`pwd`/../androidOut/${ANDROID_ARCH_ABI}
API=21

function build_android
{
# cmake 传参
cmake ../libyuv-refs_heads_main -G"Unix Makefiles" \
    -DANDROID_NDK=${NDK_PATH} \
        -DCMAKE_CXX_COMPILER=$TOOLCHAIN/bin/$ANDROID_ARCH_COMPILER$API-clang++ \
      -DCMAKE_C_COMPILER=$TOOLCHAIN/bin/$ANDROID_ARCH_COMPILER$API-clang \
    -DCMAKE_TOOLCHAIN_FILE=${NDK_PATH}/build/cmake/android.toolchain.cmake \
    -DANDROID_ABI=${ANDROID_ARCH_ABI} \
    -DANDROID_NATIVE_API_LEVE=${API} \
    -DCMAKE_INSTALL_PREFIX=${PREFIX} \
    -DANDROID_ARM_NEON=TRUE \
    ..

# 生成库
#make clean
make
make install
}

# arm64
ANDROID_ARCH_ABI=arm64-v8a
ANDROID_ARCH_COMPILER=aarch64-linux-android
#清空上次的编译
PREFIX=`pwd`/../androidOut/${ANDROID_ARCH_ABI}
make clean
# 函数调用
build_android

echo ${PREFIX}

# 先删除build目录
cd ..
rm -rf build
mkdir build
cd build

# armeabi-v7a
ANDROID_ARCH_ABI=armeabi-v7a
ANDROID_ARCH_COMPILER=armv7a-linux-androideabi
PREFIX=`pwd`/../androidOut/${ANDROID_ARCH_ABI}
echo ${PREFIX}
echo $TOOLCHAIN/bin/$ANDROID_ARCH_COMPILER$API-clang++
# 函数调用
build_android

编写完毕赋予编译脚本运行权限,运行命令chmod +x build_yuv.sh,然后运行编译脚本./build_yuv.sh即可编译出libyuv的静态库和动态库,输出目录为源码目录libyuv-refs_heads_main的同级目录android下。

例如笔者编译完毕的完整目录是这样子的:
笔者libyuv编译完毕目录

编译成功后至于怎么引入,可以参考笔者之前的文章,原理都是一致的,这里就不再重复了。
参考:NDK21编译ffmpeg5.0.1

其他编译方式

对与程序员来说README.md是一个很有用的文档,无论那个项目都应该养成先看README.md的习惯。同样在libyuv的源码中也有README.md,里面就有介绍了使用gclient对libyuv各种平台的编译介绍。
具体介绍文档是libyuv-refs_heads_main/docs/getting_started.md

使用文档

同样在README.md也介绍了详细的使用文档,具体的使用文档是libyuv-refs_heads_main/docs/rotation.md。笔者浏览起来是挺详细的,这里就不多说了。

同时也可以参考其他博客文章:android全平台编译libyuv库实现YUV和RGB的转换
https://github.com/byhook/ffmpeg4android/blob/master/readme/android%E5%85%A8%E5%B9%B3%E5%8F%B0%E7%BC%96%E8%AF%91libyuv%E5%BA%93%E5%AE%9E%E7%8E%B0YUV%E5%92%8CRGB%E7%9A%84%E8%BD%AC%E6%8D%A2.md

推荐阅读

Opengl ES之EGL环境搭建
Opengl ES之着色器
Opengl ES之三角形绘制
Opengl ES之四边形绘制
Opengl ES之纹理贴图
Opengl ES之VBO和VAO
Opengl ES之EBO
Opengl ES之FBO
Opengl ES之PBO
Opengl ES之YUV数据渲染
YUV转RGB的一些理论知识
Opengl ES之RGB转NV21

关注我,一起进步,人生不止coding!!!

目录
相关文章
|
编解码 Linux C语言
探索C++与Live555实现RTSP服务器的艺术(一)
探索C++与Live555实现RTSP服务器的艺术
1664 1
|
编解码 Linux
libfdk-aac和x264安装编译
libfdk-aac和x264安装编译
1132 0
libfdk-aac和x264安装编译
|
运维 前端开发 关系型数据库
高效调试与分析:利用ftrace进行Linux内核追踪(上)
高效调试与分析:利用ftrace进行Linux内核追踪
|
编解码 监控 网络协议
如何使用FFmpeg实现RTSP推送H.264和H.265(HEVC)编码视频
本文详细介绍了如何使用FFmpeg实现RTSP推送H.264和H.265(HEVC)编码视频。内容涵盖环境搭建、编码配置、服务器端与客户端实现等方面,适合视频监控系统和直播平台等应用场景。通过具体命令和示例代码,帮助读者快速上手并实现目标。
4099 6
|
Linux 编解码 Python
FFmpeg开发笔记(二十四)Linux环境给FFmpeg集成AV1的编解码器
AV1是一种高效免费的视频编码标准,由AOM联盟制定,相比H.265压缩率提升约27%。各大流媒体平台倾向使用AV1。本文介绍了如何在Linux环境下为FFmpeg集成AV1编解码库libaom、libdav1d和libsvtav1。涉及下载源码、配置、编译和安装步骤,包括设置环境变量以启用这三个库。
1767 3
FFmpeg开发笔记(二十四)Linux环境给FFmpeg集成AV1的编解码器
|
网络协议 Linux
TCP中两种保活方式
【4月更文挑战第7天】两种保活方式:Keep Alive和心跳包
|
编解码 C++ 流计算
探索C++与Live555实现RTSP服务器的艺术(三)
探索C++与Live555实现RTSP服务器的艺术
784 1
|
存储 编解码 算法
探索C++与Live555实现RTSP服务器的艺术(二)
探索C++与Live555实现RTSP服务器的艺术
738 1
|
Web App开发 Android开发 ice
【Android App】给App集成WebRTC实现视频发送和接受实战(附源码和演示 超详细)
【Android App】给App集成WebRTC实现视频发送和接受实战(附源码和演示 超详细)
2141 2
|
Web App开发 网络安全 数据安全/隐私保护
如何让服务端同时支持WebSocket和SSL加密的WebSocket(即同时支持ws和wss)?
要服务端同时支持ws与wss并不容易,其难点主要在于:wss通道必须在TCP连接刚建立时(收发消息前)就要先进行SSL加密,否则,后续的通信将无法正常进行。如此一来,当TCP连接刚建立时,服务器就无法具体分辨哪个是ws客户端哪个是wss客户端。那怎么办了?
6050 0