libjpeg用法linux压缩,linux

一:libjpeg库的编译

下载源码,解压后

./configure   --prefix=/xxxx     CC=arm-linux-gcc -    -host=arm-linux    --enable-shared     --enable-static

---xxxx为生成动静态裤的目录

----CC为交叉编译器

-----enable-shared    ---enable-static 使能动静态库

然后make,

再make install,在xxx目录下生成相应的头文件和库

jconfig.h     jerror.h      jmorecfg.h       jpeglib.h          和   libjpeg.9.so.1.0     libjpeg.a

程序编写

例子为framebuffer  jpg图片格式转rgb(565)

test.c

#include

#include

#include

#include

#include

#include

#include

#include

/头文件

#include "libinclude/jpeglib.h"

#include "libinclude/jerror.h"

struct fb_var_screeninfo var;

unsigned short *fbp;

//定义结构体

struct jpeg_decompress_struct cinfo;

struct jpeg_error_mgr jerr;

FILE * infile;

int main(int argc ,char **argv)

{

int fd,screen_size,i,j;

unsigned short value;

int pos;

char *rdata;

char *Tbmp[]={"bmp/T1.jpg","bmp/T2.jpg","bmp/T3.jpg","bmp/T4.jpg",

"bmp/T5.jpg","bmp/T6.jpg","bmp/T7.jpg","bmp/T8.jpg","bmp/T9.jpg",

"bmp/T10.jpg","bmp/T11.jpg"};

char  Tpos = 0;

fd = open("/dev/fb0",O_RDWR);

if(fd<0)

perror(" open ");

ioctl(fd,FBIOGET_VSCREENINFO,&var);

printf("var x = %d , y = %d  bits = %d ..\n",var.xres ,var.yres,var.bits_per_pixel);

screen_size = var.xres *var.yres*var.bits_per_pixel/8;

printf("screen_size is %d\n",screen_size);

fbp =  (unsigned short *)mmap(0, screen_size, PROT_WRITE | PROT_READ,  MAP_SHARED ,  fd, 0);

if(!fbp)

goto  mmap_err;

产生相应变量

cinfo.err = jpeg_std_error(&jerr);

jpeg_create_decompress(&cinfo);

while(1)

{

///打开图片文件

if ((infile = fopen(Tbmp[Tpos], "rb")) == NULL) {

fprintf(stderr, "can't open %s\n", "tu.jpg");

exit(1);

}

Tpos ++;

if(Tpos>=11)

Tpos = 0;

/获取头信息

jpeg_stdio_src(&cinfo, infile);

jpeg_read_header(&cinfo, TRUE);

分配内存存储字节

rdata=(char*)calloc(cinfo.p_w_picpath_width*cinfo.p_w_picpath_height*cinfo.num_components,1);

开始解压

jpeg_start_decompress(&cinfo);

JSAMPROW row_pointer[1];

while (cinfo.output_scanline < cinfo.output_height)

{

row_pointer[0] = & rdata[(cinfo.output_scanline)*cinfo.p_w_picpath_width*cinfo.num_components];

jpeg_read_scanlines(&cinfo,row_pointer ,1);

}

/结束解压

jpeg_finish_decompress(&cinfo);

///framebuffer填充刚才分配的字节

pos = 0;

for(i=0;i

for(j=0;j

{

rgb888  转 rgb565

value=  ((rdata[pos]>>3)<<11) |((rdata[pos+1]>>2)<<5) |(rdata[pos+2]>>3);

*(fbp+i*var.xres+j) = value;

pos +=3;

}

sleep(3);

fclose(infile);

}

jpeg_destroy_decompress(&cinfo);

munmap(fbp, screen_size);

close(fd);

return 0;

mmap_err:

perror("mmap\n");

return -1;

}

注:jpg默认解压为rgb888

用过动态库和静态库使用

静态库

此时test.c 目录下有 test.c   libjpeg.a

jconfig.h     jerror.h      jmorecfg.h       jpeglib.h

arm-linux-gcc  test.c  -o test   -L./  -ljpeg

生成test放到开发板执行

动态库

此时test.c 目录下有test.c

jconfig.h     jerror.h      jmorecfg.h       jpeglib.h   libjpeg.9.so.1.0

arm-linux-gcc   test.c -o test   -L./   -l:libjpeg.9.so.1.0

把libjpeg.9.so.1.0改为libjpeg.9.so  放到开发板  /usr/lib 目录下

生成test放到开发板执行

libjpeg用法linux压缩,linux

一:libjpeg库的编译

下载源码,解压后

./configure   --prefix=/xxxx     CC=arm-linux-gcc -    -host=arm-linux    --enable-shared     --enable-static

---xxxx为生成动静态裤的目录

----CC为交叉编译器

-----enable-shared    ---enable-static 使能动静态库

然后make,

再make install,在xxx目录下生成相应的头文件和库

jconfig.h     jerror.h      jmorecfg.h       jpeglib.h          和   libjpeg.9.so.1.0     libjpeg.a

程序编写

例子为framebuffer  jpg图片格式转rgb(565)

test.c

#include

#include

#include

#include

#include

#include

#include

#include

/头文件

#include "libinclude/jpeglib.h"

#include "libinclude/jerror.h"

struct fb_var_screeninfo var;

unsigned short *fbp;

//定义结构体

struct jpeg_decompress_struct cinfo;

struct jpeg_error_mgr jerr;

FILE * infile;

int main(int argc ,char **argv)

{

int fd,screen_size,i,j;

unsigned short value;

int pos;

char *rdata;

char *Tbmp[]={"bmp/T1.jpg","bmp/T2.jpg","bmp/T3.jpg","bmp/T4.jpg",

"bmp/T5.jpg","bmp/T6.jpg","bmp/T7.jpg","bmp/T8.jpg","bmp/T9.jpg",

"bmp/T10.jpg","bmp/T11.jpg"};

char  Tpos = 0;

fd = open("/dev/fb0",O_RDWR);

if(fd<0)

perror(" open ");

ioctl(fd,FBIOGET_VSCREENINFO,&var);

printf("var x = %d , y = %d  bits = %d ..\n",var.xres ,var.yres,var.bits_per_pixel);

screen_size = var.xres *var.yres*var.bits_per_pixel/8;

printf("screen_size is %d\n",screen_size);

fbp =  (unsigned short *)mmap(0, screen_size, PROT_WRITE | PROT_READ,  MAP_SHARED ,  fd, 0);

if(!fbp)

goto  mmap_err;

产生相应变量

cinfo.err = jpeg_std_error(&jerr);

jpeg_create_decompress(&cinfo);

while(1)

{

///打开图片文件

if ((infile = fopen(Tbmp[Tpos], "rb")) == NULL) {

fprintf(stderr, "can't open %s\n", "tu.jpg");

exit(1);

}

Tpos ++;

if(Tpos>=11)

Tpos = 0;

/获取头信息

jpeg_stdio_src(&cinfo, infile);

jpeg_read_header(&cinfo, TRUE);

分配内存存储字节

rdata=(char*)calloc(cinfo.p_w_picpath_width*cinfo.p_w_picpath_height*cinfo.num_components,1);

开始解压

jpeg_start_decompress(&cinfo);

JSAMPROW row_pointer[1];

while (cinfo.output_scanline < cinfo.output_height)

{

row_pointer[0] = & rdata[(cinfo.output_scanline)*cinfo.p_w_picpath_width*cinfo.num_components];

jpeg_read_scanlines(&cinfo,row_pointer ,1);

}

/结束解压

jpeg_finish_decompress(&cinfo);

///framebuffer填充刚才分配的字节

pos = 0;

for(i=0;i

for(j=0;j

{

rgb888  转 rgb565

value=  ((rdata[pos]>>3)<<11) |((rdata[pos+1]>>2)<<5) |(rdata[pos+2]>>3);

*(fbp+i*var.xres+j) = value;

pos +=3;

}

sleep(3);

fclose(infile);

}

jpeg_destroy_decompress(&cinfo);

munmap(fbp, screen_size);

close(fd);

return 0;

mmap_err:

perror("mmap\n");

return -1;

}

注:jpg默认解压为rgb888

用过动态库和静态库使用

静态库

此时test.c 目录下有 test.c   libjpeg.a

jconfig.h     jerror.h      jmorecfg.h       jpeglib.h

arm-linux-gcc  test.c  -o test   -L./  -ljpeg

生成test放到开发板执行

动态库

此时test.c 目录下有test.c

jconfig.h     jerror.h      jmorecfg.h       jpeglib.h   libjpeg.9.so.1.0

arm-linux-gcc   test.c -o test   -L./   -l:libjpeg.9.so.1.0

把libjpeg.9.so.1.0改为libjpeg.9.so  放到开发板  /usr/lib 目录下

生成test放到开发板执行