ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

Basler sdk 图像数据转换Opencv、Halcon方式

2021-08-25 10:00:12  阅读:580  来源: 互联网

标签:ptrGrabResult targetImage Basler HTuple unsigned Halcon char Opencv GetBuffer


1.转Opencv Mat参考代码如下:

//Open cv 2.4.10
//for Mono
Mat Img;
uchar* test = (uchar *)(ptrGrabResult->GetBuffer());
Mat mat(ptrGrabResult->GetHeight(), ptrGrabResult->GetWidth(), CV_8UC1, test);

//for Color
Mat BayerImg;
uchar* test = (uchar *)(ptrGrabResult->GetBuffer());
Mat mat(ptrGrabResult->GetHeight(), ptrGrabResult->GetWidth(), CV_8UC1, test);
cvtColor(mat, BayerImg, CV_BayerGB2RGB); //CV_BayerGB2RGB 根据相机Bayer设置 

2、转halcon HImage类型代码参考如下:

// 3、转halcon图像并保存
				    
Hobject hImage;
unsigned char *Pointer;
int width,height;

height = ptrGrabResult->GetHeight();
width = ptrGrabResult->GetWidth();
Pylon::PixelType pPixeltype;
pPixeltype = ptrGrabResult->GetPixelType();
Pointer = (uint8_t *) ptrGrabResult->GetBuffer();

if(pPixeltype== PixelType_Mono8) //For Mono
{
 gen_image1_extern(&hImage,"byte",(HTuple)width,(HTuple)height,(long)Pointer,NULL); //Mono
 write_image(hImage,"bmp",0,"HalconTestMono.bmp");
}
else if(pPixeltype== PixelType_BayerGB8 || pPixeltype== PixelType_BayerBG8)//For Color
{
		CImageFormatConverter converter;
		CPylonImage targetImage;
		converter.OutputPixelFormat = PixelType_RGB8packed ;
		converter.Convert(targetImage,ptrGrabResult);
		unsigned char *Pointer = (unsigned char*)targetImage.GetBuffer(); //for Color
		1)	
		PointerR = (unsigned char*)targetImage.GetPlane(0).GetBuffer();
		PointerG = (unsigned char*)targetImage.GetPlane(1).GetBuffer();
		PointerB = (unsigned char*)targetImage.GetPlane(2).GetBuffer();
		HalconCpp::GenImage3Extern(&HImage,"byte",(HTuple)width,(HTuple)height,(long)PointerR,(long)PointerG,(long)PointerB,NULL); //Color
				
		2)
		gen_image_interleaved (&hImage,(long)Pointer, "rgb", (HTuple)width,(HTuple)height, 0, "byte", 0, 0, 0, 0, 8, 0);
		write_image(hImage,"bmp",0,"TestColor.bmp");
}

标签:ptrGrabResult,targetImage,Basler,HTuple,unsigned,Halcon,char,Opencv,GetBuffer
来源: https://blog.csdn.net/bingheliushui520/article/details/119904204

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有