【音视频连载-001】基础学习篇- SDL 介绍以及工程配置

技术开发故事会连载ios

这是音视频基础学习系列的第一篇文章,主要讲解 SDL 是什么以及为何要用到它,看似和音视频没啥卵关系,其实必不可少。git

SDL 简介

SDL 是 “Simple DirectMedia Layer” 的缩写,它是一个跨平台的多媒体库,能够在 Mac、Windows、Linux 以及更多的系统上运行。github

SDL 提供了统一的针对音频、视频、键盘、鼠标、控制杆以及 3D 硬件的低级别访问接口,咱们利用这些接口就能在不一样系统上播放出音频、视频内容,而无需懂得系统特定的音视频接口。微信

这种跨平台特性和 OpenGL 是同样的,差异在与 OpenGL 是真·跨平台,它是 Khronos Group 组织开发维护的一个接口规范,具体的实现是由驱动厂商完成。而 SDL 是把要兼容平台的相关接口都给封装好了,而后才对外提供统一的接口。函数

因而可知,高下立判。一个跨平台是写了接口就行,无论实现;另外一个是写好了实现,才能跨平台(貌似跑题了)。学习

因为 SDL 的跨平台特性,在后续学习 FFmpeg 时就能够利用 SDL 进行音视频的播放操做,而不用像在 Android 平台上搞 FFmpeg 还得编译 so、写 JNI 、写界面那么麻烦,另外 ffplay 源码里面也是用的 SDL 进行播放的,能够从中进行借鉴。spa

SDL 下载安装

在 Mac 上下载 SDL 很简单,直接命令行

brew install sdl2

注意,这里下载的是 SDL 2.0 版本,若是用以下的命令调试

brew install sdl

下载的就是 SDL 1.0 版本了,区别就是版本后面数字 2 的后缀。code

采用最新的 2.0 ,我当前使用的版本号就是 2.0.10

若是是 Windows 系统,参考下其余文章的下载配置吧,没有电脑也没办法了。

SDL 下载以后位于 MAC 系统的以下目录,这个目录后续会用到的。

/usr/local/Cellar/sdl2/2.0.10

CLion 新建工程

接下来就开始打开 CLion ,新建一个 C++ 工程。

这里用到 CLion 是由于它确实好用,自动补全、代码提示、断点调试等功能很是好用,只是没有社区免费版的,有 30 天的免费试用期,以后就得靠激活码激活了。

好在是用 CMake 进行编译的,若是下载了工程源码,而且配置好了 CMake 的关联库和头文件,直接用 CMake 命令行也能够进行编译的,这个后面会讲到。

C++ 工程关联 SDL 库

接下来就是在 C++ 工程中关联 SDL 库,便于在工程中引用 SDL 相关头文件。

以前提到 SDL 的安装路径以下:

/usr/local/Cellar/sdl2/2.0.10

该目录以下图:

其中 include 就是头文件的路径,lib 就是库的路径。

这里要用到 include_directorieslink_directories 两个命令。

其中:

include_directories 是将头文件所在文件夹添加在搜索路径中,这样就能经过 include 去加载头文件了。
link_directories 是将库所在的文件夹添加在路径中去,这样在编译时就能连接到这个库。

具体代码以下:

# 声明一个变量 SDL_DIR 为 SDL 安装路径
set(SDL_DIR "/usr/local/Cellar/sdl2/2.0.10")
# 设置要包含的头文件的路径
include_directories(${SDL_DIR}/include)
# 设置要关联的库的路径
link_directories(${SDL_DIR}/lib)

代码中声明了一个变量 SDL_DIR 做为安装路径,若是你的系统上路径有所不一样,只须要修改路径就好了。

在 MAC 上也能够把路径设置成 /usr/local,全部的库安装时在这个目录的 libinclude 目录下也有一份索引。

最后将咱们要编译的程序关联上 SDL 这个库。

你能够经过 link_directories 命令将不少库所在文件夹都添加到路径中,可是只有 target_link_libraries 命令才会最终决定关联什么库,若是你添加的文件夹路径没有对应库的话,反而要报错的。

实现代码以下:

target_link_libraries(av-beginner SDL2)

target_link_libraries 方法会优先连接动态库,也能够显示指定动态库或者静态库。MAC 上动态库的后缀是 dylib 。在上面的图片能够看到 libSDL2.dylib 实际上是一个索引,真正的库是 libSDL2-2.0.0.dylib,索引忽略了它的版本号。

完成了 SDL 库的关联,就能够开始真正编写代码了。

代码实践

代码实践主要是验证咱们的环境配置有没有问题,运行一个 SDL 函数来试试。

#include <iostream>
#include <SDL2/SDL.h>
using namespace std;

int main(){
    cout << "hello av-beginner" << endl;
    SDL_Init(SDL_INIT_EVERYTHING);
    return 0;
}

SDL_Init 是 SDL 的初始化函数,能够根据所需功能选择性的初始化也能够所有初始化。

若是程序正常输出而且正常退出,那么说明环境配置 OK 了,后面就能够进行功能开发了。

总结

以上就是音视频基础学习连载的 001 篇。

具体代码见仓库:

https://github.com/glumes/av-...

本篇文章对应的提交 tagav-beginner-001,可切换至对应源码查看。

能力有限,文中有不对之处,欢迎加我微信 ezgluems 进行交流~~

扫码关注,持续更新

相关文章
相关标签/搜索