首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >libpng+VS2012(VS2015)的使用

libpng+VS2012(VS2015)的使用

作者头像
一棹烟波
发布2018-01-12 16:45:23
发布2018-01-12 16:45:23
2.1K00
代码可运行
举报
文章被收录于专栏:一棹烟波一棹烟波
运行总次数:0
代码可运行

 OpenCV保存PNG图像底层调用的就是libpng库,简要说一下libPNG库的单独使用。

1.首先需要下载两个库,一个是libpng,一个是zlib

libpng库下载地址:http://www.libpng.org/pub/png/libpng.html

zlib库下载地址:http://www.zlib.net/

2.将两个库下载后解压到同一个文件目录下,如图:

3. 打开libpng库文件目录:\lpng1632\projects\vstudio中,用记事本打开zlib.props配置文件,对应修改zlib库的版本并保存,如下图,我用的是zlib-1.2.11

4.打开同目录下的vstudio解决方案,然后直接在debug或者release模式编译,win32或者x64均可。我用VS2012编译没有任何异常,全部成功,VS2015出现一些错误提示,但是不影响lib库的生成.

5.编译后得到的lib库和dll文件分别在同目录的Debug和Release文件中,x64下编译会在x64文件中。我们需要的是其中的libpng16.lib,libpng16.dll和zlib.lib三个文件。

6.新建VS项目,VC++目录中的包含目录分别设置为libpng库和zlib库所在路径,库目录设置为刚刚生成的lib库所在目录,链接器->输入中将两个lib库名称添加进去,并将libpng16.dll放进工程的可执行文件目录中。(其实跟配置Opencv一样一样的)

以上配置完毕,可以调用libpng库中的接口API进行图像的读写操作了,可以参考libpng库目录中的example.c文件,里面有API的说明。具体的读写代码网上也都能找到。

我列出自己简单编写的写入png图像的代码,读入lena.jpg,保存为lena.png。代码如下,仅供参考。

代码语言:javascript
代码运行次数:0
运行
复制
  1 #include <opencv2\opencv.hpp>
  2 #include <stddef.h>
  3 #include <stdlib.h>
  4 #include <string.h>
  5 #include <stdio.h>
  6 #include <png.h>
  7 #include <zlib.h>
  8 
  9 using namespace cv;
 10 
 11 int write_png_file(char *file_name , Mat srcImg, int imgW, int imgH, int channels)
 12 {
 13      uchar* pImgData=(uchar*)srcImg.data;
 14      int j, i, temp, pos;
 15      png_byte color_type;
 16 
 17      png_structp png_ptr;
 18      png_infop info_ptr; 
 19      png_bytep * row_pointers;
 20      /* create file */
 21      FILE *fp = fopen(file_name, "wb");
 22      if (!fp)
 23      {
 24           printf("[write_png_file] File %s could not be opened for writing", file_name);
 25           return -1;
 26      }
 27 
 28      /* initialize stuff */
 29      png_ptr = png_create_write_struct(PNG_LIBPNG_VER_STRING, NULL, NULL, NULL);
 30 
 31      if (!png_ptr)
 32      {
 33          printf("[write_png_file] png_create_write_struct failed");
 34          return -1;
 35      }
 36      info_ptr = png_create_info_struct(png_ptr);
 37      if (!info_ptr)
 38      {
 39         printf("[write_png_file] png_create_info_struct failed");
 40         return -1;
 41      }
 42      if (setjmp(png_jmpbuf(png_ptr)))
 43      {
 44         printf("[write_png_file] Error during init_io");
 45         return -1;
 46      }
 47      png_init_io(png_ptr, fp);
 48 
 49      /* write header */
 50      if (setjmp(png_jmpbuf(png_ptr)))
 51      {
 52          printf("[write_png_file] Error during writing header");
 53          return -1;
 54      }
 55      /* 判断要写入至文件的图片数据是否有透明度,来选择色彩类型 */
 56      if(channels == 4) 
 57      {
 58          color_type = PNG_COLOR_TYPE_RGB_ALPHA;
 59      }
 60      else if(channels==1)
 61      {
 62          color_type = PNG_COLOR_TYPE_GRAY;
 63      }
 64      else
 65      {
 66          color_type = PNG_COLOR_TYPE_RGB;
 67      }
 68      
 69      png_set_IHDR(png_ptr, info_ptr, imgW, imgH,
 70       8, color_type, PNG_INTERLACE_NONE,
 71       PNG_COMPRESSION_TYPE_BASE, PNG_FILTER_TYPE_BASE);
 72 
 73      png_write_info(png_ptr, info_ptr);
 74 
 75      /* write bytes */
 76      if (setjmp(png_jmpbuf(png_ptr)))
 77      {
 78         printf("[write_png_file] Error during writing bytes");
 79         return -1;
 80      }
 81      if(channels == 4) 
 82      {
 83         temp = (4 * imgW);
 84      }
 85      else if(channels == 1)
 86      {
 87          temp = ( imgW);
 88      }
 89      else
 90      {
 91          temp = ( 3*imgW);
 92      }
 93  
 94      row_pointers = (png_bytep*)malloc(imgH*sizeof(png_bytep));
 95      for(i = 0; i < imgH; i++)
 96      {
 97           row_pointers[i] = (png_bytep)malloc(sizeof(uchar)*temp);
 98           for(j = 0; j < imgW; j += 1)
 99           {
100                if(channels==4) 
101                {
102                    row_pointers[i][j*3+0]  = pImgData[i*imgW*3+ j*3+0]; // blue
103                    row_pointers[i][j*3+1] = pImgData[i*imgW*3+ j*3+1]; // green
104                    row_pointers[i][j*3+2] = pImgData[i*imgW*3+ j*3+2];  // red
105                    row_pointers[i][j*3+3] = pImgData[i*imgW*3+ j*3+3];  // alpha
106                }
107                else if(channels==1)
108                {
109                    row_pointers[i][j]  = pImgData[i*imgW+ j]; // gray
110                }
111                else
112                {
113                    row_pointers[i][j*3+0]  = pImgData[i*imgW*3+ j*3+0]; // blue
114                    row_pointers[i][j*3+1] = pImgData[i*imgW*3+ j*3+1]; // green
115                    row_pointers[i][j*3+2] = pImgData[i*imgW*3+ j*3+2];  // red
116                }
117           }
118      }
119      png_write_image(png_ptr, row_pointers);
120 
121      /* end write */
122      if (setjmp(png_jmpbuf(png_ptr)))
123      {
124       printf("[write_png_file] Error during end of write");
125       return -1;
126      }
127      png_write_end(png_ptr, NULL);
128 
129         /* cleanup heap allocation */
130      for (j=0; j<imgH; j++)
131      {
132         free(row_pointers[j]);
133      }
134      free(row_pointers);
135 
136     fclose(fp);
137     return 0;
138 }
139 
140 void main()
141 {
142     Mat img=imread("lena.jpg", 0);
143     namedWindow("lena");
144     imshow("lena",img);
145     waitKey(0);
146     char imgName[10]="lena.png";
147     int imgWidth=img.cols;
148     int imgHeight=img.rows;
149     int channels=img.channels();
150     write_png_file(imgName , img, imgWidth, imgHeight, channels);
151 
152     getchar();
153 }
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017-09-12 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档