皮皮网

【宁波到重庆源码】【postcss源码分析】【游戏插件源码】libjpeg源码分析

2024-12-24 10:58:21 来源:e语言浏览器源码

1.音视频探索(5):JPEG格式与Libjpeg库编译移植
2.如何使用libjpeg
3.kali里边怎么安装libjpeg-turbo8这个库?急急急

libjpeg源码分析

音视频探索(5):JPEG格式与Libjpeg库编译移植

       音视频探索(5):JPEG格式与Libjpeg库编译移植

       libJPEG-turbo是码分一个强大的JPEG图像处理库,广泛应用于Android系统图像压缩,码分尤其在保证图像质量和色彩丰富的码分场景。然而,码分为适应低版本Android手机,码分系统内部的码分宁波到重庆源码压缩算法并未采用全速的哈夫曼编码,因为这会占用过多CPU资源。码分本文将采用Cmake工具编译libJPEG-turbo源码,码分并利用JNI/NDK技术,码分定制哈夫曼编码接口,码分提升Android中的码分压缩性能。

       哈夫曼编码是码分一种高效的无损压缩方式,它根据字符出现概率分配不同长度的码分码字,出现频率高的码分字符编码较短。在图像压缩中,码分postcss源码分析通过扫描图像数据确定像素概率,构造赫夫曼树,生成对应码表。例如,构建一颗赫夫曼树,其带权路径长度可通过叶子结点的权重和路径长度计算得出。

       在libjpeg库中,游戏插件源码压缩JPEG过程涉及分配结构体、设置输出、参数设置、按行处理数据等步骤。而解码则包括初始化对象、指定数据源、读取头部参数和解压数据等操作。SRCNN源码调试源码分析显示,压缩和解压的核心结构体包含图像信息、参数配置和工作空间指针等关键部分。

       要编译移植libjpeg-turbo,首先在Android工程中配置CmakeLists.txt,然后编译生成对应的libjpeg.so文件。在使用时,OA控制源码需将库头文件和动态库引入到项目中,并在Java层编写JNI方法,实现Java与C/C++的交互,从而实现JPEG图像的高效编码和解码。

如何使用libjpeg

       æœ¬æ–‡åªä»‹ç»jpeg压缩的相关内容,刚开始我贪图省事,采用微 软 的GDI Plus提供的功能,很是方便,先获取jpg图像的编码,然后根据图像的位图数据创建一个Bitmap类的对象,再保存图像为jpg格式就行了。但是我对 GDI+还是很信任,总感觉不踏实(没有理由的),我们的系统一旦安装就要长期运行,我就是担心长期运行一段时间后GDI+会出问题,结果也证实了我的担 心,我们实际使用的套系统中有一套,连续运行3-5天后,GDI+就会崩溃,于是我决心采用IJG JPEG Library。您可以到

        站下载libjpeg的源码, IJG JPEG Library就是jpeg压缩库,是以源码的形式提供给软件开发人员的,当然在软件包里也有编译好的库文件,我们这里就只用到其中的 libjpeg.lib,jconfig.h,jmorecfg.h,jpeglib.h这几个文件,下面我就介绍一下怎样在自己的程序里嵌入图像压缩功 能。

       ã€€ã€€ä¸€ã€å»ºç«‹ç¼–译环境

       ã€€ã€€æ‰€è°“建立编译环境,其实非常简单,就是把上面提到的4个文件拷 贝到你的项目文件夹下,把libjpeg.lib添加到你的项目中,然后在你完成压缩功能的那个文件里加入#include "jpeglib.h",需要注意的是,libjpeg.lib是用c语言开发的,如果要用在你的C++程序里,需要用到extern "C",如下:

       // TestLibjpeg.cpp : Defines the entry point for the console application.

       //

       #include "stdafx.h"

       #include "memory.h"

       extern "C" {

       #include "jpeglib.h"

       }

       ã€€ã€€äºŒã€åŽ‹ç¼©æ­¥éª¤

       ã€€ã€€1、申请并初始化jpeg压缩对象,同时要指定错误处理器

       struct jpeg_compress_struct jcs;

       // 声明错误处理器,并赋值给jcs.err域

        struct jpeg_error_mgr jem;

        jcs.err = jpeg_std_error(&jem);

        jpeg_create_compress(&jcs);

       ã€€ã€€2、指定压缩后的图像所存放的目标文件,注意,目标文件应以二进制模式打开

       f=fopen(".jpg","wb");

        if (f==NULL)

        {

        delete [] data;

        delete [] pDataConv;

        return 0;

        }

        jpeg_stdio_dest(&jcs, f);

       ã€€ã€€3、设置压缩参数,主要参数有图像宽、高、色彩通道数(1:索引图像,3:其他),色彩空间(JCS_GRAYSCALE表示灰度图,JCS_RGB表示彩色图像),压缩质量等,如下:

        jcs.image_width = nWidth; // 为图的宽和高,单位为像素

        jcs.image_height = nHeight;

        jcs.input_components = 1; // 在此为1,表示灰度图, 如果是彩色位图,则为3

        jcs.in_color_space = JCS_GRAYSCALE; //JCS_GRAYSCALE表示灰度图,JCS_RGB表示彩色图像

        jpeg_set_defaults(&jcs);

       jpeg_set_quality (&jcs, , true);

       éœ€è¦æ³¨æ„çš„是,jpeg_set_defaults函数一定要等设 置好图像宽、高、色彩通道数计色彩空间四个参数后才能调用,因为这个函数要用到这四个值,调用jpeg_set_defaults函数后,jpeglib 库采用默认的设置对图像进行压缩,如果需要改变设置,如压缩质量,调用这个函数后,可以调用其它设置函数,如jpeg_set_quality函数。其实 图像压缩时有好多参数可以设置,但大部分我们都用不着设置,只需调用jpeg_set_defaults函数值为默认值即可。

       ã€€ã€€4、上面的工作准备完成后,就可以压缩了,压缩过程非常简单, 首先调用jpeg_start_compress,然后可以对每一行进行压缩,也可以对若干行进行压缩,甚至可以对整个的图像进行一次压缩,压缩完成后, 记得要调用jpeg_finish_compress函数,如下:

        jpeg_start_compress(&jcs, TRUE);

        JSAMPROW row_pointer[1]; // 一行位图

        int row_stride; // 每一行的字节数

       row_stride = jcs.image_width; // 如果不是索引图,此处需要乘以3

        // 对每一行进行压缩

        while (jcs.next_scanline < jcs.image_height) {

        row_pointer[0] = & pDataConv[jcs.next_scanline * row_stride];

        jpeg_write_scanlines(&jcs, row_pointer, 1);

        }

        jpeg_finish_compress(&jcs);

       ã€€ã€€5、最后就是释放压缩工作过程中所申请的资源了,主要就是jpeg压缩对象,由于在本例中我是直接用的局部变量,所以只需调用jpeg_destroy_compress这个函数即可,如下:

       jpeg_destroy_compress(&jcs);

       ã€€ã€€ä¸‰ã€è§£åŽ‹ç¼©æ­¥éª¤

       ã€€ã€€è§£åŽ‹ç¼©æ­¥éª¤ä¸ŽåŽ‹ç¼©æ­¥éª¤éžå¸¸ç›¸ä¼¼ï¼Œåªæ˜¯è§£åŽ‹ç¼©å¯¹è±¡ä¸ºjpeg_decompress_struct类型,步骤如下:

       ã€€ã€€1、声明并初始化解压缩对象,同时制定错误信息管理器

       struct jpeg_decompress_struct cinfo;

       struct jpeg_error_mgr jerr;

       cinfo.err = jpeg_std_error(&jerr);

       jpeg_create_decompress(&cinfo);

       ã€€ã€€2、打开jpg图像文件,并指定为解压缩对象的源文件

       FILE *f = fopen(strSourceFileName,"rb");

       if (f==NULL)

       {

        printf("Open file error!\n");

        return;

       }

       //

       jpeg_stdio_src(&cinfo, f);

       ã€€ã€€3、读取图像信息

       jpeg_read_header(&cinfo, TRUE);

       ã€€ã€€4、根据图像信息申请一个图像缓冲区

       data = new BYTE cinfo.image_width*cinfo.image_height*cinfo.num_components];

       ã€€ã€€5、开始解压缩

       jpeg_start_decompress(&cinfo);

       JSAMPROW row_pointer[1];

       while (cinfo.output_scanline < cinfo.output_height)

       {

        row_pointer[0] = &data[(cinfo.output_height - cinfo.output_scanline-1)*cinfo.image_width*cinfo.num_components];

        jpeg_read_scanlines(&cinfo,row_pointer ,

        1);

       }

       jpeg_finish_decompress(&cinfo);

       ã€€ã€€6、释放资源

       jpeg_destroy_decompress(&cinfo);

       fclose(f);

       ã€€ã€€å¥½äº†ï¼Œåˆ©ç”¨IJG JPEG Library进行图像压缩就介绍到这里,希望对大家有所帮助,实例代码已经实现了图像的压缩和解压缩的全部功能,命令格式 为:“TestLibjpeg.exe j|j|b 源文件名 目标文件名”,其中,j选项将源文件压缩为jpg格式,不改变色彩模式,j选项将源文件压缩为为jpg格式,b选项将源文件解压缩为bmp格式, 该实例并没有提供文件有效性的验证,如果要引入自己的代码,请自己实现文件有效性的验证。

kali里边怎么安装libjpeg-turbo8这个库?急急急

       下载libjpeg-turbo源码。

       安装编译依赖包。

       $ sudo apt-get install nasm

       编译安装。

       第一步,移动到源文件目录,并执行autoreconf -fiv 命令。

       第二步,运行configure脚本并加上配置参数。我们就直接在源目录执行,不用创建build目录了。

       不过在运行之前,我们查看一下/usr/local/lib下有没有libjpeg.so*文件,有的话我们执行操作,删除这些文件。sudo rm -rf /usr/local/lib/libjpeg.so*否则,直接执行此步即可。

       $ ./configure --prefix=/usr/local --mandir=/usr/local/share/man --with-jpeg8 --disable-static --docdir=/usr/local/share/doc/libjpeg-turbo-1.5.2

       解释一下各项参数简单意思。

       –prefix=/usr/local 指定库安装路径

       –mandir=/usr/local/share/man 指定man文件(相关命令参考信息)安装路径

       –with-jpeg8 这个开关启用与libjpeg 版本8的兼容性,即可使用libjpeg8的API.

       –disable-static 阻止安装静态版本的库

       –docdir=/usr/local/share/doc/libjpeg-turbo-1.5.2 指定文档安装路径

       第三步,编译及安装。

       $ make$ sudo make install

       另外建议看看《Linux就该这么学》这本书熟悉下命令