halcon与opencv图片的数据结构转换
来源:互联网 发布:国外网上购物知乎 编辑:程序博客网 时间:2024/05/17 17:46
IplImage* ImageProcess::HImageToIplImage(Hobject &Hobj){ IplImage* pImage; HTuple htChannels; char cType[MAX_STRING]; Hlong width,height; width=height=0; //转换图像格式 convert_image_type(Hobj,&Hobj,"byte"); count_channels(Hobj,&htChannels); if(htChannels[0].I()==1) { unsigned char* ptr; get_image_pointer1(Hobj,(Hlong*)&ptr,cType,&width,&height); pImage=cvCreateImage(cvSize(width,height),IPL_DEPTH_8U,1); for(int i=0;i<height;i++) { memcpy(pImage->imageData+pImage->widthStep*i,ptr+width*i,width); } } if(htChannels[0].I()==3) { unsigned char *ptrRed , *ptrGreen , *ptrBlue; ptrRed=ptrGreen=ptrBlue=NULL; get_image_pointer3(Hobj,(Hlong*)&ptrRed,(Hlong*)&ptrGreen,(Hlong*)&ptrBlue,cType,&width,&height); IplImage *pImageRed , *pImageGreen , *pImageBlue ; pImage=cvCreateImage(cvSize(width,height),IPL_DEPTH_8U,3); pImageRed=cvCreateImage(cvSize(width,height),IPL_DEPTH_8U,1); pImageGreen=cvCreateImage(cvSize(width,height),IPL_DEPTH_8U,1); pImageBlue=cvCreateImage(cvSize(width,height),IPL_DEPTH_8U,1); for(int i=0;i<height;i++) { memcpy(pImageRed->imageData+pImageRed->widthStep*i , ptrRed+width*i , width); memcpy(pImageGreen->imageData+pImageGreen->widthStep*i , ptrGreen+width*i , width); memcpy(pImageBlue->imageData+pImageBlue->widthStep*i , ptrBlue+width*i , width); } cvMerge(pImageBlue,pImageGreen,pImageRed,NULL,pImage); cvReleaseImage(&pImageRed); cvReleaseImage(&pImageGreen); cvReleaseImage(&pImageBlue); } return pImage;} Hobject ImageProcess::IplImageToHImage(IplImage* pImage){ Hobject Hobj; if(pImage->nChannels==1) { int height=pImage->height; int width=pImage->width; uchar *dataGray=new uchar[width*height]; for(int i=0; i<height; i++) { memcpy(dataGray+width*i, pImage->imageData+pImage->widthStep*i,width); } gen_image1(&Hobj,"byte",pImage->width,pImage->height,(Hlong)(dataGray)); delete[ ] dataGray; } if(pImage->nChannels==3) { IplImage *pImageRed, *pImageGreen, *pImageBlue; pImageRed=cvCreateImage(cvGetSize(pImage),IPL_DEPTH_8U,1); pImageGreen=cvCreateImage(cvGetSize(pImage),IPL_DEPTH_8U,1); pImageBlue=cvCreateImage(cvGetSize(pImage),IPL_DEPTH_8U,1); cvSplit(pImage, pImageBlue, pImageGreen, pImageRed,NULL); uchar* dataRed=new uchar[pImage->width*pImage->height]; uchar* dataGreen=new uchar[pImage->width*pImage->height]; uchar* dataBlue=new uchar[pImage->width*pImage->height]; int height=pImage->height; int width=pImage->width; for(int i=0; i<height; i++) { memcpy(dataRed+width*i, pImageRed->imageData+pImageRed->widthStep*i,width); memcpy(dataGreen+width*i, pImageGreen->imageData+pImageGreen->widthStep*i,width); memcpy(dataBlue+width*i, pImageBlue->imageData+pImageBlue->widthStep*i,width); } gen_image3(&Hobj,"byte",pImage->width,pImage->height,(Hlong)(dataRed),(Hlong)(dataGreen),(Hlong)(dataBlue)); cvReleaseImage(&pImageRed); cvReleaseImage(&pImageGreen); cvReleaseImage(&pImageBlue); delete[ ] dataRed; delete[ ] dataGreen; delete[ ] dataBlue; } return Hobj; }
主要包括这两个函数:
IplImage* HImageToIplImage(Halcon::Hobject &Hobj);
Hobject IplImageToHImage(IplImage* pImage); 0 0
- halcon与opencv图片的数据结构转换
- halcon HImage 与opencv 里的 IplImage互相转换
- Halcon与Opencv图像数据格式转换
- Halcon 与 OpenCV 图像数据类型转换
- Halcon与Opencv图像数据格式转换
- Halcon 与 OpenCV 图像数据类型转换
- OpenCV 图片与视频的相互转换
- 【Halcon】显示图片+opencv转halcon
- Halcon图像与Opencv图像相互转换(C++代码)
- Halcon Image与OpenCV IplImage图像数据相互转换
- Halcon图像与Opencv图像相互转换(C++代码)
- Halcon Image与OpenCV IplImage图像数据相互转换
- Halcon图像与Opencv图像相互转换(C++代码)
- Halcon 与 C++ 的类型转换
- halcon图片格式和opencv的IPLimage格式的转换
- OpenCV的Mat和Halcon的HObject类型互相转换
- 【Halcon】Halcon与OpenCV介绍、比较
- OpenCV|图片与视频的相互转换(C++&Python)
- SACD ISO提取DSF文件,添加封面
- VMware Workstation虚拟机打开 .vmx 文件没有反应--解决办法
- 创建Android快捷方式牛刀小试
- Kafka初涉
- JavaScript 数据类型转换(2017-1-3)
- halcon与opencv图片的数据结构转换
- 05-CSS 权重 盒模型 标准文档流 浮动
- 06-CSS 浮动的清除 margin Fireworks和精确盒子还原
- Gradle之依赖管理
- 数据库在windows下的坑
- PHP会话应用之COOKIE应用(一)
- MySQL子查询和联结表笔记
- 电脑播放SACD-ISO/DSD/DFF音乐
- 原生JS写Ajax的请求函数