荔枝派Zero(全志V3S)驱动开发之RGB LCD屏幕显示jpg图片

2024-03-22 13:50

本文主要是介绍荔枝派Zero(全志V3S)驱动开发之RGB LCD屏幕显示jpg图片,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 前言
  • 一、jpeglib 库移植
    • 1、jpeglib 库下载
    • 2、安装 jpeglib 库
  • 二、jpeg 图片解压缩过程和压缩过程
    • 1、jpeg 解压缩过程
    • 2、jpeg 压缩过程
  • 三、编译 C 源码
    • 1、源码展示
    • 2、拷贝需要用到的头文件
    • 3、编译 C 代码
  • 四、验证测试
    • 1、拷贝相关文件到开发板
    • 2、显示图片
  • 五、资源自取
    • 方式1:github 链接
    • 方式2:百度网盘


前言

由于从上篇博文 “荔枝派Zero(全志V3S)驱动开发之RGB LCD屏幕显示bmp图片” 中只实现了显示 bmp 图片,实际上我们很常用到的图片多数是 jpg 格式图片,因此我们需要折腾一下,实现 jpg 文件的显示。


一、jpeglib 库移植

1、jpeglib 库下载

下载网址:http://www.ijg.org/files
在这里插入图片描述
这里我选择最新的一个版本,即 jpegsrc.v9e.tar.gz 这个 jpeglib 库

2、安装 jpeglib 库

源码的安装一般由3个步骤组成:配置(configure)、编译(make)、安装(make install)。
<1>、创建安装目录
在 Linux PC 机上新建一个文件夹,用于存放安装文件,并将 jpegsrc.v9e.tar.gz 拷贝到当前目录下:

mkdir /home/Gnep/licheepi_zero/tools
cd tools/
cp /home/share/jpegsrc.v9e.tar.gz ./
ls

在这里插入图片描述
<2>、解压 jpegsrc.v9e.tar.gz 到安装目录

tar -xf jpegsrc.v9e.tar.gz
ls

在这里插入图片描述
<3>、配置
进入其目录,执行:

cd jpeg-9e/
./configure --prefix=/home/Gnep/licheepi_zero/tools CC=arm-linux-gnueabihf-gcc --host=arm-linux --enable-shared --enable-static
  • 其中 --prefix 选项是配置安装的路径,如果不配置该选项,安装后可执行文件默认放在 /usr/local/bin,库文件默认放在 /usr/local/lib,配置文件默认放在/usr/local/etc,其它的资源文件放在/usr/local/share,比较凌乱。
    用 --prefix 选项的另一个好处是卸载软件或移植软件。当某个安装的软件不再需要时,只须简单的删除该安装目录,就可以把软件卸载得干干净净;移植软件只需拷贝整个目录到另外一个机器即可(相同的操作系统)。
  • 其中 CC 选项是用来选择你想使用的 C 编译器的绝对路径
  • 其中 --host 选项指需要运行的位置,默认为 build,也就是本机编译出来的程序,由本机使用;当本机编译出来的程序要在 arm 板子上运行时,就要设置为 arm-linux
  • --enable-shared:生成动态链接库
  • --enable-static:生成静态链接库

在这里插入图片描述
<4>、编译

make

在这里插入图片描述
<5>、安装

make install

在这里插入图片描述
tools 目录下的文件为现在如下:
在这里插入图片描述
后面我们需要将 lib 目录下的 libjpeg.so.9 和 libjpeg.so.9.5.0 拷贝到开发板的 /usr/lib 目录中,将 include 目录下的头文件拷贝到我们需要编译的 C 代码的目录下
在这里插入图片描述
在这里插入图片描述
以上 jpeglib 库移植完成。

二、jpeg 图片解压缩过程和压缩过程

jpeg/jpg 格式图片显示,经过有损压缩的图片文件格式,文件较小,获取颜色数据需要解压

1、jpeg 解压缩过程

  • 打开设备文件和图片文件
    • int lcd_fd = open(“/dev/fb0”, O_RDWR);
    • FILE *infile = fopen(argv[1], “r+”);
  • 为jpeg对象分配空间并初始化
    • jpeg_create_decompress(&cinfo);
  • 指定解压缩数据源
    • jpeg_stdio_src(&cinfo, infile);
  • 为解压缩设定参数,包括图像大小,颜色空间
    • cinfo.scale_num = 1; //分子
    • cinfo.scale_denom = n; //分母
  • 开始解压缩
    • jpeg_start_decompress(&cinfo);
  • 取出数据(做相关的应用)
    • jpeg_read_scanlines(&cinfo, (JSAMPARRAY)&buffer, 1);
    • 将每行数据显示到LCD
  • 解压缩完毕
    • jpeg_finish_decompress(&cinfo);
  • 释放资源
    • jpeg_destroy_decompress(&cinfo);
    • munmap(p, lcd_wlcd_hlcd_b);
    • close(lcd_fd);
    • fclose(infile);
    • free(buffer);

2、jpeg 压缩过程

  • 为jpeg对象分配空间并初始化
  • 指定图像输出目标
  • 为压缩设定参数,包括图像大小,颜色空间
  • 开始压缩
  • 写入数据(做相关的应用)
  • 压缩完毕
  • 释放资源

三、编译 C 源码

1、源码展示

imageshow.c

#include <stdio.h>
#include <errno.h>
#include <string.h>
#include <time.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <unistd.h>
#include <pwd.h>
#include <grp.h>
#include <stdlib.h>
#include <dirent.h>
#include <fcntl.h>
#include <sys/mman.h>
#include <linux/fb.h>
#include <sys/ioctl.h>
#include <stdbool.h>
#include "jpeglib.h"
int main(int argc, char const *argv[])
{if (argc != 2){printf("./可执行文件 <jpeg格式图片文件>\n");return -1;}//打开液晶屏int lcd_fd = open("/dev/fb0", O_RDWR);if (lcd_fd == -1){perror("open");return -1;}//获取液晶屏信息struct fb_var_screeninfo vinfo;ioctl(lcd_fd, FBIOGET_VSCREENINFO, &vinfo); // 获取可变属性int lcd_w = vinfo.xres;int lcd_h = vinfo.yres;int lcd_b = vinfo.bits_per_pixel/8;printf("该液晶屏宽:%d,高:%d, 每个像素点%d个字节\n", lcd_w, lcd_h, lcd_b);//进行内存映射int *p = mmap(NULL, lcd_w * lcd_h * lcd_b, PROT_WRITE | PROT_READ, MAP_SHARED, lcd_fd, 0);if (p == (void *)-1){perror("mmap");return -2;}// 刷黑屏幕memset(p, 0x00, 800 * 480 * 4); //(1)为jpeg对象分配空间并初始化struct jpeg_decompress_struct cinfo;	//解压jpeg的对象结构体struct jpeg_error_mgr jerr;				//定义错误结构体cinfo.err = jpeg_std_error(&jerr);		//错误处理结构体绑定jpeg_create_decompress(&cinfo);			//初始化jpeg的对象结构体//(2)指定解压缩数据源FILE *infile = fopen(argv[1], "r+");if (infile == NULL){perror("fopen jpeg");return -3;}jpeg_stdio_src(&cinfo, infile);//指定解压缩数据源//(3)获取文件信息jpeg_read_header(&cinfo, true);//(4)为解压缩设定参数,包括图像大小,颜色空间int n = 1;			//缩小倍数while(cinfo.image_width/n>lcd_w || cinfo.image_height/n>lcd_h){n *= 2;}//设定的缩小倍数cinfo.scale_num = 1;		//分子cinfo.scale_denom = n;		//分母// cinfo.out_color_space = JCS_GRAYSCALE;	//颜色空间printf("width1:%d height1:%d\n", cinfo.image_width, cinfo.image_height);//设定之前的宽高//(5)开始解压缩jpeg_start_decompress(&cinfo);printf("width:%d height:%d\n", cinfo.output_width, cinfo.output_height);//设定解压缩之后的宽高//(6)取出数据(做相关的应用),安装一行一行去读取的//output_components像素点大小//申请能够存放一行数据的缓冲区int row_size = cinfo.output_width*cinfo.output_components;char *buffer = (char *)malloc(row_size);//output_scanline当前读取行数while(cinfo.output_scanline < cinfo.output_height){//按行读取数据jpeg_read_scanlines(&cinfo, (JSAMPARRAY)&buffer, 1);//将读取到的一行数据进行显示int i = 0, j = 0;for (;j< cinfo.output_width; i+=3, j++){//内存映射的方式*(p+(cinfo.output_scanline-1)*lcd_w + j) = buffer[i+0]<<16| buffer[i+1]<<8| buffer[i+2];}}//(7)解压缩完毕jpeg_finish_decompress(&cinfo);//(8)释放资源jpeg_destroy_decompress(&cinfo);munmap(p, lcd_w*lcd_h*lcd_b);close(lcd_fd);fclose(infile);free(buffer);return 0;
}

2、拷贝需要用到的头文件

C 代码中包含了 jpeglib.h 头文件(#include “jpeglib.h”),因此我们需要拷贝库安装目录下的四个头文件(jconfig.h jerror.h jmorecfg.h jpeglib.h,路径:/home/Gnep/licheepi_zero/tools/include/),到自己应用程序的目录下。

cp /home/Gnep/licheepi_zero/tools/include/* ./

在这里插入图片描述

3、编译 C 代码

编译应用程序时,要增加动态库的链接-ljpeg 选项

arm-linux-gnueabihf-gcc imageshow.c -o imageshow -L /home/Gnep/licheepi_zero/tools/lib/ -ljpeg

在这里插入图片描述

四、验证测试

1、拷贝相关文件到开发板

①、将 imageshow、libjpeg.so.9、libjpeg.so.9.5.0拷贝到 tftpboot 目录中

cp imageshow /tftpboot/
cp /home/Gnep/licheepi_zero/tools/lib/*.so.* /tftpboot/

在这里插入图片描述
②、将 imageshow 、777.jpg、888.jpeg 拷贝到开发板上,将库安装目录下的 lib 目录下的 libjpeg.so.9 和 libjpeg.so.9.5.0 拷贝到开发板的 /usr/lib 目录中

tftp -g -l 777.jpg 192.168.25.25
tftp -g -l 888.jpeg 192.168.25.25
tftp -g -l imageshow 192.168.25.25
tftp -g -l libjpeg.so.9 192.168.25.25
tftp -g -l libjpeg.so.9.5.0 192.168.25.25
cp libjpeg.so.9 /usr/lib
cp libjpeg.so.9.5.0 /usr/lib

在这里插入图片描述

2、显示图片

①、雪山照(800 * 480)

./imageshow 777.jpg 

在这里插入图片描述
在这里插入图片描述
②、风景照(480* 272)

./imageshow 888.jpeg

在这里插入图片描述
在这里插入图片描述

五、资源自取

方式1:github 链接

https://github.com/Gnepuil79/licheepi.git

方式2:百度网盘

链接:https://pan.baidu.com/s/1GWuML5BpRJZ0MneXq9u2Gw
提取码:td2e


我的qq:2442391036,欢迎交流!


这篇关于荔枝派Zero(全志V3S)驱动开发之RGB LCD屏幕显示jpg图片的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/835410

相关文章

基于Python开发电脑定时关机工具

《基于Python开发电脑定时关机工具》这篇文章主要为大家详细介绍了如何基于Python开发一个电脑定时关机工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 简介2. 运行效果3. 相关源码1. 简介这个程序就像一个“忠实的管家”,帮你按时关掉电脑,而且全程不需要你多做

C#中图片如何自适应pictureBox大小

《C#中图片如何自适应pictureBox大小》文章描述了如何在C#中实现图片自适应pictureBox大小,并展示修改前后的效果,修改步骤包括两步,作者分享了个人经验,希望对大家有所帮助... 目录C#图片自适应pictureBox大小编程修改步骤总结C#图片自适应pictureBox大小上图中“z轴

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

使用Python将长图片分割为若干张小图片

《使用Python将长图片分割为若干张小图片》这篇文章主要为大家详细介绍了如何使用Python将长图片分割为若干张小图片,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. python需求的任务2. Python代码的实现3. 代码修改的位置4. 运行结果1. Python需求

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

在 VSCode 中配置 C++ 开发环境的详细教程

《在VSCode中配置C++开发环境的详细教程》本文详细介绍了如何在VisualStudioCode(VSCode)中配置C++开发环境,包括安装必要的工具、配置编译器、设置调试环境等步骤,通... 目录如何在 VSCode 中配置 C++ 开发环境:详细教程1. 什么是 VSCode?2. 安装 VSCo

使用 Python 和 LabelMe 实现图片验证码的自动标注功能

《使用Python和LabelMe实现图片验证码的自动标注功能》文章介绍了如何使用Python和LabelMe自动标注图片验证码,主要步骤包括图像预处理、OCR识别和生成标注文件,通过结合Pa... 目录使用 python 和 LabelMe 实现图片验证码的自动标注环境准备必备工具安装依赖实现自动标注核心

C#图表开发之Chart详解

《C#图表开发之Chart详解》C#中的Chart控件用于开发图表功能,具有Series和ChartArea两个重要属性,Series属性是SeriesCollection类型,包含多个Series对... 目录OverviChina编程ewSeries类总结OverviewC#中,开发图表功能的控件是Char

Java操作xls替换文本或图片的功能实现

《Java操作xls替换文本或图片的功能实现》这篇文章主要给大家介绍了关于Java操作xls替换文本或图片功能实现的相关资料,文中通过示例代码讲解了文件上传、文件处理和Excel文件生成,需要的朋友可... 目录准备xls模板文件:template.xls准备需要替换的图片和数据功能实现包声明与导入类声明与

鸿蒙开发搭建flutter适配的开发环境

《鸿蒙开发搭建flutter适配的开发环境》文章详细介绍了在Windows系统上如何创建和运行鸿蒙Flutter项目,包括使用flutterdoctor检测环境、创建项目、编译HAP包以及在真机上运... 目录环境搭建创建运行项目打包项目总结环境搭建1.安装 DevEco Studio NEXT IDE