美文网首页
四、嵌入式之图形界面 (5) SDL

四、嵌入式之图形界面 (5) SDL

作者: wit_yuan | 来源:发表于2019-04-09 15:35 被阅读0次

1.前言

最近想着将图片、声音、视频显示在嵌入式设备上,为了做前期准备,就考虑先在SDL做做验证工作。这篇文章里面的程序执行需要安装SDL,我这里不会说怎么安装(我是使用的源码安装的)。

2.显示bmp图片

在SDL里面有显示BMP图片的API,但是我不去使用它们,我是为了更加深入的了解bmp图片格式。显示bmp图片格式其实是非常简单的。如果不是8位的图片格式,其整个文件就只包含三部分,分为:文件头,文件信息与图片数据信息。如果是8位的,会添加调色板信息。

另外注意一点的是,bmp图像在高度信息为正的时候,图片放置方式为:图片数据的第一行为实际图片数据最后一行,以此类推,然后颜色顺序为BGRA等。

我写了一个示例,可以在github上找到,链接为:传送门
使用版本:62e3d50
要注意的是,该示例只关注于24bit的图片格式,其他的不在考虑之列。

具体步骤:

$ git clone https://github.com/yuanzhaoming/show_pic.git
$ cd show_pic
$ git checkout 62e3d50

运行时,使用命令:

$ ./show_pic ../pictures/1.bmp

运行效果图如下:


bmp画图

3.显示jpeg图片

jpeg的解析比较复杂,这就需要依靠libjpeg库了。可以访问libjpeg网站:传送门
下载源码并且编译。

可以在github上下载源码测试,传送门
具体步骤:

$ git clone https://github.com/yuanzhaoming/show_pic.git
$ cd show_pic
$ git checkout 71eee0d

显示效果就不展示了。

4.显示摄像头图像

这节的代码只是初代代码,难免有很多问题,但是基本实现了pc摄像头数据在SDL上的显示。

注意,使用的是mjpeg输出,所以要使用上节提到的jpeg转换,另外,上节使用的是从文件中读取数据,这节使用的是从内存获取,所以,需要改掉一部分的jpeg接口。

不多说,程序下载地址在github上,传送门
具体步骤:

$ git clone https://github.com/yuanzhaoming/show_pic.git
$ cd show_pic
$ git checkout 9903405

5.支持wav格式音频播放

首先,简要说明一下,该示例程序能播放wav音频,但是听起来是有一部分问题的,预估是循环缓冲区没做好,不排查了。

下载地址在github上,传送门
具体步骤:

$ git clone https://github.com/yuanzhaoming/show_pic.git
$ cd show_pic
$ git checkout ff3076d

继续上一个版本,分析wav文件,读取数据块,然后使用循环缓冲区播放。
可以使用如下方法获取代码:

$ git clone https://github.com/yuanzhaoming/show_pic.git
$ cd show_pic
$ git checkout 4fd03be

相关文章

网友评论

      本文标题:四、嵌入式之图形界面 (5) SDL

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