首页 > 其他分享 >【音视频连载-004】基础学习篇-SDL 加载图片并显示

【音视频连载-004】基础学习篇-SDL 加载图片并显示

时间:2022-10-13 16:34:52浏览次数:66  
标签:CMake image Surface 音视频 link 004 SDL


公众号回复:OpenGL,领取学习资源大礼包

【音视频连载-004】基础学习篇-SDL 加载图片并显示_加载

音视频学习入门技术文章连载:

在前面的文章中已经介绍完 SDL 显示窗口、消息循环和事件响应这些基础内容,有了这些基础就可以进行功能性开发了。

本篇的主要内容是利用 SDL 加载并显示一张图片,然后再去进行更多的音视频操作。

SDL2_Image 配置

之前写过两篇 libpng 和 libjpeg-turbo 编译与实践的文章:

有需要的可以去翻阅一下。

在 SDL 中加载 png 或者 jpeg 图片用不到上面两个库了,需要用到 SDL 特定的图片库 SDL_Image ,执行以下命令去下载:

brew install sdl2_image

我用的版本是 ​​2.0.5​​ ,也是目前最新的版本,之后我们要在 CMake 中去配置它。

CMake 工程配置

对 ​​av-beginner​​​ 项目的 CMake 配置做了一些改动,创建了一个 ​​cmake_utils​​​ 的目录,在该目录下创建了一个 ​​CMakeLists.txt​​ ,里面存放一些自定义的函数,专门用来做开源库的链接加载工作,如下图红框内容所示:

【音视频连载-004】基础学习篇-SDL 加载图片并显示_工程配置_02

定义了一个 ​​init_path​​ 的宏,宏的功能和函数是有些类似的,在里面定义了不同开源库的路径变量,后续只要引用这些变量就好了。如果你的电脑上路径不同,修改这里的宏定义就行。

如果对 CMake 的操作不熟悉的话,建议阅读之前写过的文章,涵盖了很多基础操作。

​Android NDK 开发之 CMake 必知必会​

当下载了 SDL_Image 之后,找到它的路径,把它的库加载到 CMake 链接目录中来,也就是要调用 ​​link_directories​​ 方法,这里同样可以定义一个宏:

macro(link_sdl_image)
message("link sdl image library and path is ${sdl_image_dir}")
include_directories(${sdl_image_dir}/include/SDL2)
link_directories(${sdl_image_dir}/lib)
endmacro()

之后就需要把目标执行文件或者目标库与 SDL_Image 开源库关联起来,也就是 ​​target_link_libraries​​ 方法,同样定义一个宏:

macro(target_link_sdl_image name)
message("${name} link sdl image")
target_link_libraries(${name}
SDL2_image
)
endmacro()

这个宏有个参数 ​​name​​ ,它就是要链接的目标文件 target 。

对于 SDL 库或者其他库,也可以创建类似的宏,具体在源码中能看到。

在完成了 SDL_Image 的 CMake 配置之后,就需要在工程的主 ​​CMakeLists.txt​​​ 文件中把它包含进去,现在还只是在 ​​cmake_utils​​ 目录中,这样是引用不到宏的。

通过 ​​add_subdirectory​​ 方法将定义的功能添加进来,接下来就可以使用了。

【音视频连载-004】基础学习篇-SDL 加载图片并显示_加载_03

同时,对于 SDL 项目代码,单独创建一个文件夹去存放,再根据每个小项又划分文件夹:

【音视频连载-004】基础学习篇-SDL 加载图片并显示_工程配置_04

如上图所示,针对每个小项又有单独的 ​​CMakeLists.txt​​ 配置文件,在里面按需执行动态库的关联就好了。

经过以上的工程配置整改,对于后续的开发模块划分是很有帮助的,不仅便于添加各种开源库,更利于去单个编译项目。

后续添加的库都会按照这个模式进行添加。

SDL_Image 加载 图片并显示

完成了配置之后,就可以进行 SDL_Image 的开发了,整个开发流程比较简单。

前面的文章中我们创建并展示了 ​​SDL_Window​​​,SDL_Window 内有一个叫做 ​​SDL_Surface​​ 的结构,实际上它才是最终渲染展示的。

我们加载一张图片,并将图片转换成 ​​SDL_Surface​​ ,然后把图片对应的 SDL_Surface 转换到 SDL_Window 对应的 SDL_Surface ,再更新一下 SDL_Window 的 SDL_Surface 内容,渲染到屏幕就好了。

核心代码如下所示:

    // 得到 SDL_Window 的 SDL_Surface
SDL_Surface *pWindowSurface = SDL_GetWindowSurface(pWindow);
// 根据图片创建一个 SDL_Surface
SDL_Surface *pImageSurface = IMG_Load(image_path.c_str());
bool bQuit = false;
SDL_Event windowEvent;
while (!bQuit){
while (SDL_PollEvent(&windowEvent)){
switch (windowEvent.type){
case SDL_QUIT:
bQuit = true;
break;
default:
break;
}
}
// 将 pImageSurface 的内容传输到 上
SDL_BlitSurface(pImageSurface, nullptr,pWindowSurface,nullptr);
// 上屏操作,将 Surface 内容显示到屏幕上
SDL_UpdateWindowSurface(pWindow);
}

最终结果如下:

【音视频连载-004】基础学习篇-SDL 加载图片并显示_加载_05

总结

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

完成了 SDL 加载图片并显示的流程,整体代码比较简单,很多东西都是之前文章提到过的,反而重点更侧重于工程的 CMake 配置,有兴趣的可以看看代码。

具体代码见仓库:

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

本篇文章对应的提交 ​​tag​​​ 为 ​​av-beginner-004​​,可切换至对应源码查看。

能力有限,文中有不对之处,

【音视频连载-004】基础学习篇-SDL 加载图片并显示_工程配置_06


扫码关注公众号【音视频开发进阶】,一起学习多媒体音视频开发~~~

【音视频连载-004】基础学习篇-SDL 加载图片并显示_加载_07


喜欢就点个吧 ▽



标签:CMake,image,Surface,音视频,link,004,SDL
From: https://blog.51cto.com/u_12127193/5753712

相关文章

  • 【音视频连载-009】第二季 FFmpeg 打造简易播放器
    公众号回复:OpenGL,领取学习资源大礼包音视频学习入门技术文章连载:​​技术开发故事会连载​​​​【音视频连载-001】基础学习篇-SDL介绍以及工程配置​​​​【音视频连载-......
  • 声网、新东方、伴鱼英语的音视频技术解读
    编辑:InfoQ薛梁互动直播、线上会议、在线医疗和在线教育是音视频技术应用的重要场景,而这些场景对高可用、高可靠、低延时有着苛刻的要求,很多团队在音视频产品开发过程中会遇......
  • 004——剪辑视频前 , 该如何正确的导入素材
    剪辑视频前,该如何正确的导入素材常用的导入格式导入方式直接拖入从菜单栏中选择………………………………......
  • P1004 [NOIP2000 提高组] 方格取数
    P1004[NOIP2000提高组]方格取数题目描述设有\(N\timesN\)的方格图\((N\le9)\),我们将其中的某些方格中填入正整数,而其他的方格中则放入数字\(0\)。如下图所示(......
  • 中小学教育管理(选修) 00458
    1.课前导入第一章2.3.4.5.6.7.8.9.10.11.......
  • SDL应用之三种字库
    SFont库sfont用大小写英文字母和符号进行内容显示,资源即是字体图片。sfont下载:​​http://www.linux-games.com/sfont​​我下载SFont2.03后,解压并make,产生了许多的文......
  • 22_播放器之使用SDL显示YUV视频
    简介使用SDL实现简单的YUV播放器。这里还需要使用到像素格式和计算图片大小,这两个我们直接使用ffmpeg来实现,因此需要使用ffmpeg的libavutil/avutil.h和libavutil/imgut......
  • Java Web 004
    DML:对数据进行增删改添加:insertinto表名(列名1,列名2...)values(值1,值2...);--给指定列添加数据insertinto表名values(值1,...值n);--给所有列添加数据......
  • 「CTSC2004」最优切割
    题目大意[CTSC2004]最优切割-HydroOJ给定一个平面直角坐标系上的木模板和一个目标零件(均为凸多边形),保证零件位于模板内部,且任意不相邻的两边延长线的交点在模板外。你......
  • 004 二分法
    //二分法判断一个数是否存在(有序数组)publicstaticBooleanBSExist(int[]arr,intnum){if(arr==null||arr.length==0){returnfal......