【Halcon】图像BYTE数据生成 Mat 格式和 Hobject 格式

本文介绍如何将BYTE类型的数据转换为OpenCV中的Mat格式和HALCON中的Hobject格式,包括灰度图和彩色图的处理过程,并展示了使用这些格式进行图像显示的方法。

BYTE转换成Mat格式

int nImgMatType;
int nTmgMatType;
if ( nImgType == 0 )
{
nImgMatType = CV_8UC1;
}
else if ( nImgType == 1 )
{
nImgMatType = CV_8UC3;
}
else
{
return 1;
}


if ( nTmgType == 0 )
{
nTmgMatType = CV_8UC1;
}
else if ( nTmgType == 1 )
{
nTmgMatType = CV_8UC3;
}
else
{
return 1;
}


CvSize size;
size.width  = (int)((fImgWidth*1000+1)/1000);
size.height = (int)((fImgHeight*1000+1)/1000);


CvSize sizeTemp;
sizeTemp.width  = (int)((fTmgWidth*1000+1)/1000);
sizeTemp.height = (int)((fTmgHeight*1000+1)/1000);


Mat imgMat(size.height, size.width, nImgMatType, image_data);
Mat tmgMat(sizeTemp.height, sizeTemp.width, nTmgMatType, temp_data); 


namedWindow("Source");
imshow("Source", imgMat);
namedWindow("Template");  
imshow("Template", tmgMat);
cvWaitKey();
cvDestroyAllWindows();




BYTE转换成Hobject格式

//--------------------------------//

if ( nImgType == 0 )
{
nImgMatType = 1;

unsigned char *dataGray = new unsigned char [nImgWidth * nImgHeight];


for(int i = 0; i<nImgHeight; i++)

for ( int j=0;j<nImgWidth;j++)
{
dataGray[nImgWidth*i + j] = image_data[(nImgWidth*nImgMatType)*i + j*nImgMatType];
}
}
gen_image1(&Image,"byte",nImgWidth,nImgHeight,(Hlong)(dataGray));


}
else if ( nImgType == 1 )
{
nImgMatType = 3;


unsigned char *dataRed= new unsigned char [nImgWidth * nImgHeight];
unsigned char *dataGreen= new unsigned char [nImgWidth * nImgHeight];
unsigned char *dataBlue= new unsigned char [nImgWidth * nImgHeight];


for(int i = 0; i<nImgHeight; i++)
{
for(int j = 0; j<nImgWidth; j++)
{
dataBlue[nImgWidth*i + j] = image_data[(nImgWidth*nImgMatType)*i + j*nImgMatType + 0];
dataGreen[nImgWidth*i + j] = image_data[(nImgWidth*nImgMatType)*i + j*nImgMatType + 1];
dataRed[nImgWidth*i + j] = image_data[(nImgWidth*nImgMatType)*i + j*nImgMatType + 2];
}
}
gen_image3(&Image,"byte",nImgWidth,nImgHeight,(Hlong)(dataRed),(Hlong)(dataGreen),(Hlong)(dataBlue));


HTuple  Width, Height, WindowHandle;
  if (HDevWindowStack::IsOpen())
  close_window(HDevWindowStack::Pop());
  get_image_size(Image, &Width, &Height);
  set_window_attr("background_color","black");
  open_window(0,0,Width,Height,0,"","",&WindowHandle);
  HDevWindowStack::Push(WindowHandle);
  if (HDevWindowStack::IsOpen())
  disp_obj(Image, HDevWindowStack::GetActive());
write_image(Image, "bmp", 0, "e:/1.bmp");
}
else
{
return 1;
}


//--------------------------------//
if ( nTmgType == 0 )
{
nTmgMatType = 1;


unsigned char *dataGray = new unsigned char [nTmgWidth * nTmgHeight];
for(int i = 0; i<nTmgHeight; i++)

for ( int j=0;j<nTmgWidth;j++)
{
dataGray[nTmgWidth*i + j] = temp_data[(nTmgWidth*nImgMatType)*i + j*nImgMatType];
}
}
gen_image1(&TmpImage,"byte",nTmgWidth,nTmgHeight,(Hlong)(dataGray));
}
else if ( nTmgType == 1 )
{
nTmgMatType = 3;
unsigned char *dataRed= new unsigned char [nTmgWidth * nTmgHeight];
unsigned char *dataGreen= new unsigned char [nTmgWidth * nTmgHeight];
unsigned char *dataBlue= new unsigned char [nTmgWidth * nTmgHeight];


for(int i = 0; i<nTmgHeight; i++)
{
for(int j = 0; j<nTmgWidth; j++)
{
dataBlue[nTmgWidth*i + j] = temp_data[(nTmgWidth*nTmgMatType)*i + j*nTmgMatType + 0];
dataGreen[nTmgWidth*i + j] = temp_data[(nTmgWidth*nTmgMatType)*i + j*nTmgMatType + 1];
dataRed[nTmgWidth*i + j] = temp_data[(nTmgWidth*nTmgMatType)*i + j*nTmgMatType + 2];
}
}
gen_image3(&TmpImage,"byte",nTmgWidth,nTmgHeight,(Hlong)(dataRed),(Hlong)(dataGreen),(Hlong)(dataBlue));


HTuple  Width, Height, WindowHandle;
// if (HDevWindowStack::IsOpen())
// close_window(HDevWindowStack::Pop());
get_image_size(TmpImage, &Width, &Height);
set_window_attr("background_color","black");
open_window(0,0,Width,Height,0,"","",&WindowHandle);
HDevWindowStack::Push(WindowHandle);
if (HDevWindowStack::IsOpen())
disp_obj(TmpImage, HDevWindowStack::GetActive());
write_image(TmpImage, "bmp", 0, "e:/2.bmp");
}
else
{
return 1;
}
### 将 OpenCV 的 Mat 对象换为 HalconHObject 为了实现从 OpenCV `Mat` 到 Halcon `HObject` 的换,可以采用一种间接的方式:先将 `Mat` 换为标准图像格式(如 BMP 或 PNG),再利用 Halcon 提供的功能读取该文件并创建相应的 `HObject` 实例。 另一种更高效的方法是在内存层面直接操作数据。下面提供了一种基于指针访问数据复制的技术方案来完成这一过程: #### 方法一:通过临时文件过渡 这种方法较为简单直观,适用于初学者或调试阶段[^1]。 ```cpp #include <iostream> #include "halcon.h" #include <opencv2/opencv.hpp> void Mat_to_HObject_File(cv::Mat& src, Hobject& dst) { std::string tempFile = "temp.bmp"; cv::imwrite(tempFile, src); read_image(&dst, (HTuple)(std::string("temp").c_str())); } ``` 此方法依赖于磁盘IO,在性能上不如第二种方法理想;但在某些情况下可能更加稳定可靠。 #### 方法二:直接内存映射换 对于追求效率的应用场景来说,推荐使用这种方式来进行快速的数据交换[^2]。 ```cpp #include <iostream> #include "halcon.h" #include <opencv2/opencv.hpp> void Mat_to_HObject_Directly(const cv::Mat& mat, Hobject& hobj) { // 获取图像基本信息 int width = mat.cols; int height = mat.rows; // 创建一个新的 HALCON 图像对象 gen_empty_obj(&hobj); // 假设输入的是灰度图,如果是彩色图则需调整通道数 HTuple type = "byte"; // 可能需要根据实际情况修改 // 使用 create_image 函数分配空间给新创建的对象 create_image(&hobj, type, width, height); // 获取目标图像的指针以便写入像素值 double* p_data = nullptr; get_image_pointer1(hobj, reinterpret_cast<Hlong*>(&p_data), NULL, NULL, NULL); // 复制源矩阵中的数据至HALCON图像中 memcpy(p_data, mat.ptr<uchar>(0), sizeof(uchar)*mat.total()); } // 测试函数调用 int main() { cv::Mat img = cv::imread("example.jpg", cv::IMREAD_GRAYSCALE); if(img.empty()) return -1; Hobject ho_Image; Mat_to_HObject_Directly(img, ho_Image); disp_img(ho_Image); // 显示图片用于验证效果 return 0; } ``` 上述代码展示了如何不经过任何中间介质而直接在两个不同框架之间传递图像信息。需要注意的是,这里假设了输入图为单通道灰度图形式,如果处理多通道颜色图像,则还需要额外考虑色彩模型之间的差异以及适当调整代码逻辑。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值