利用开源库libjpeg库解析jpeg格式图片

利用libjpeg库解压jpeg文件的步骤:

1. 分配并初始化一个jpeg解压对象

```

struct jpeg_decompress_struct dinfo; //定义了一个jpeg的解压对象

struct jpeg_error_mgr jerr; //定义一个错误变量
dinfo.err = jpeg_std_error(&jerr);

jpeg_create_decompress(&dinfo); //初始化这个解压对象

2. 指定要解压缩的图像文件

    **FILE *infile;
    infile = fopen("xxx.jpg", "r");
    if (infile == NULL)
    {}
    jpeg_stdio_src(&dinfo, infile);** //为解压对象dinfo指定要解压的文件
    或

    **jpeg_mem_src(&dinfo, buf, len);**


3. 调用jpeg_read_header()获取图像信息

    **jpeg_read_header(&dinfo, TRUE);**


4. 设置jpeg解压缩对象dinfo的一些参数,可采用默认参数

5.调用jpeg_start_decompress()启动解压过程
    jpeg_start_decompress(&dinfo); 
    调用jpeg_start_decompress(&dinfo);函数之后,JPEG解压对象dinfo中下面这几个成员变量
    将会比较有用:
    output_width:  图像的输出宽度, 单位为像素点
    output_height: 图像的输出高度, 单位为行
    output_component: 每个像素的分量数,也即字节数,3/4字节


    在调用jpeg_start_decompress(&dinfo); 之后
    往往需要为解压后的扫描线上的所有像素点分配存储空间,
    output_width * output_components(一行的字节数,output_height行)

    //分配一个空间,用来存放解压一行后的数据
    char *buffer = malloc(dinfo.output_width * dinfo.output_component);

6. 读取一行或者多行扫描线数据并处理,通常的代码是这样的:


**//output_scanline表示扫描的总行数
//output_height表示图像的总行数
while (dinfo.output_scanline < dinfo.output_height)
{
//jpeg_read_scanlines指定读取多少行去解压
jpeg_read_scanlines(&dinfo, &buffer, 1);
/deal with scanlines . RGB/ARGB/
}**


    对扫描线的读取是按照从上到下的顺序进行的,也就是说图像最上方的扫描线最先被jpeg_read_scanlines()
    读入到存储空间中,紧接着是第二个扫描线,最后是图像的底边的扫描线被读入存储空间中。

7. 调用 jpeg_finish_decompress()完成解压过程


8.调用jpeg_destroy_decompress()释放jpeg解压对象dinfo
    jpeg_destroy_decompress(&dinfo);


****例子****
    解析一张jpg图片过程
#include <stdio.h>
#include <errno.h>
#include <stdlib.h>
#include "LCD_display.h"
#include "jpeglib.h"
int jpg_display(char * path)// **指定图片的路径就可以调用这个jpg的解析。**
{
//LCD_init();
/*
1. 分配并初始化一个jpeg解压对象
*/
struct jpeg_decompress_struct dinfo; //定义了一个jpeg的解压对象

struct jpeg_error_mgr jerr; //定义一个错误变量
dinfo.err = jpeg_std_error(&jerr);

jpeg_create_decompress(&dinfo); //初始化这个解压对象

/*
2. 指定要解压缩的图像文件
*/
FILE *infile;
infile = fopen(path, "r");
if (infile == NULL)
{
perror("fopen error");
return -1;
}

jpeg_stdio_src(&dinfo, infile); //为解压对象dinfo指定要解压的文件
/*
3. 调用jpeg_read_header()获取图像信息

*/
jpeg_read_header(&dinfo, TRUE);

/*
4. 设置jpeg解压缩对象dinfo的一些参数,可采用默认参数
*/
/*
5.调用jpeg_start_decompress()启动解压过程
jpeg_start_decompress(&dinfo); 
调用jpeg_start_decompress(&dinfo);函数之后,JPEG解压对象dinfo中下面这几个成员变量
将会比较有用:
output_width:  图像的输出宽度
output_height: 图像的输出高度
output_component: 每个像素的分量数,也即字节数,3/4字节
在调用jpeg_start_decompress(&dinfo); 之后往往需要为解压后的扫描线上的所有像素点分配存储空间,
output_width * output_components(一行的字节数,output_height行)

*/

jpeg_start_decompress(&dinfo); 


unsigned char *buffer = malloc(dinfo.output_width * dinfo.output_components);

/*
6. 读取一行或者多行扫描线数据并处理,通常的代码是这样的:

//output_scanline表示扫描的总行数
//output_height表示图像的总行数
while (dinfo.output_scanline < dinfo.output_height)
{
jpeg_read_scanlines(&dinfo, &buffer, 1);

//deal with scanlines . RGB/ARGB
}
*/

//output_scanline表示扫描的总行数
//output_height表示图像的总行数
while (dinfo.output_scanline < dinfo.output_height)
{
jpeg_read_scanlines(&dinfo, &buffer, 1); //dinfo.output_scanline + 1

//deal with scanlines . RGB/ARGB
int x; //一行的像素点数量

char *p = buffer;
for (x = 0; x < 800; x++)
{
unsigned char r, g, b, a = 0;
int color;
if (dinfo.output_components == 3)
{
    r = *p++;
    g = *p++;
    b = *p++;
} else if (dinfo.output_components == 4)
{
    a = *p++;
    r = *p++;
    g = *p++;
    b = *p++;
}
color = (a << 24) | (r << 16) | (g << 8) |(b) ;
LCD_DrawPoint(x, dinfo.output_scanline - 1 ,  color); 
    }
}
/*
7. 调用 jpeg_finish_decompress()完成解压过程
*/
jpeg_finish_decompress(&dinfo);
/*
8.调用jpeg_destroy_decompress()释放jpeg解压对象dinfo
jpeg_destroy_decompress(&dinfo);
*/
jpeg_destroy_decompress(&dinfo);
//LCD_unint();
return 0;
}
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值