如何通过OpenCV实现图像数据从64位浮点数到8位无符号整数的转换?

2026-05-25 02:351阅读0评论SEO资源
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计608个文字,预计阅读时间需要3分钟。

如何通过OpenCV实现图像数据从64位浮点数到8位无符号整数的转换?

在OpenCV中,对大量数据的运算通常需要将数据转换为64位类型,如浮点数double。例如,在进行图像处理时,cvShowImage()函数需要U8类型才能正确显示图像,否则显示结果可能是一片空白。因此,经常需要进行数据类型转换。

在OpenCV中很多对数据的运算都需要转换为64F类型,比如伽玛变换,这个很明显要求幂的底数是double类型~

而cvShowImage()又要求是U8才能显示,否则显示出来是一片空白!

所以经常要进行转换,怎么做呢?看了下面的几行代码你就知道了!

IplImage *pSrcImage = cvLoadImage("pout.jpg", CV_LOAD_IMAGE_UNCHANGED); IplImage *pGrayImage_8U = cvCreateImage(cvGetSize(pSrcImage), IPL_DEPTH_8U, 1); IplImage *pGrayImage_8U_2 = cvCreateImage(cvGetSize(pSrcImage), IPL_DEPTH_8U, 1); IplImage *pGrayImage_64F=cvCreateImage(cvGetSize(pSrcImage), IPL_DEPTH_64F, 1); cvCvtColor(pSrcImage, pGrayImage_8U, CV_BGR2GRAY); //RGB转灰度图像 cvConvertScale(pGrayImage_8U, pGrayImage_64F); //8U转64F cvConvertScale(pGrayImage_64F, pGrayImage_8U_2) //64F转8U

补充知识:OpenCV中利用cvConvertScale()对图像数据作线性变换~

在OpenCV的IplImage结构体char * imageData成员的说明中,官方文档明确提示大家不能对这个指针所对应的数据直接操作,否则会带来意想不到的错误。

原话是这样的:

Do not assign imageData directly. Use SetData().

如何通过OpenCV实现图像数据从64位浮点数到8位无符号整数的转换?

我曾经就犯傻直接进行操作,结果造成数据类型不匹配,最后还非得去修改头文件中的char * imageData为unsigned char * imageData才解决问题,然而这种操作是极其不妥的~正确的做法是用OpenCV提供的各种函数来对图像数据就行操作!比如cvConvertScale()、Use SetData()之类的!

这里我用cvConvertScale()来实现灰度图像的线性变换,程序非常简洁,而且没有任何问题!

源代码如下:

#include <opencv2/opencv.hpp> #include <opencv2/legacy/compat.hpp> using namespace std; #pragma comment(linker, "/subsystem:\"windows\" /entry:\"mainCRTStartup\"") int main() { int i=0; unsigned char *imageData_1; unsigned char *imageData_2; const char *pstrWindowsATitle = "原图像(opencv66.net)"; const char *pstrWindowsBTitle = "线性变换后的图像(opencv66.net))"; //从文件中加载原图 IplImage *pSrcImage = cvLoadImage("coins.png", CV_LOAD_IMAGE_UNCHANGED); //创建输出的图像 IplImage *pOutImage = cvCreateImage(cvGetSize(pSrcImage), IPL_DEPTH_8U,1); cvConvertScale(pSrcImage,pOutImage,2,-55); //利用cvConvertScale增加对比度的线性变换,线性变换中的比例因子k=2 偏移值b=-55 cvNamedWindow(pstrWindowsATitle, CV_WINDOW_AUTOSIZE); cvShowImage(pstrWindowsATitle,pSrcImage); cvNamedWindow(pstrWindowsBTitle, CV_WINDOW_AUTOSIZE); cvShowImage(pstrWindowsBTitle, pOutImage); cvWaitKey(0); cvDestroyWindow(pstrWindowsATitle); cvDestroyWindow(pstrWindowsBTitle); cvReleaseImage(&pSrcImage); cvReleaseImage(&pOutImage); return 0; }

运行结果如下图所示(和我在MATLAB中的运行结果一致哦)

MATLAB运行后的结果

以上这篇利用OpenCV中对图像数据进行64F和8U转换的方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持易盾网络。

本文共计608个文字,预计阅读时间需要3分钟。

如何通过OpenCV实现图像数据从64位浮点数到8位无符号整数的转换?

在OpenCV中,对大量数据的运算通常需要将数据转换为64位类型,如浮点数double。例如,在进行图像处理时,cvShowImage()函数需要U8类型才能正确显示图像,否则显示结果可能是一片空白。因此,经常需要进行数据类型转换。

在OpenCV中很多对数据的运算都需要转换为64F类型,比如伽玛变换,这个很明显要求幂的底数是double类型~

而cvShowImage()又要求是U8才能显示,否则显示出来是一片空白!

所以经常要进行转换,怎么做呢?看了下面的几行代码你就知道了!

IplImage *pSrcImage = cvLoadImage("pout.jpg", CV_LOAD_IMAGE_UNCHANGED); IplImage *pGrayImage_8U = cvCreateImage(cvGetSize(pSrcImage), IPL_DEPTH_8U, 1); IplImage *pGrayImage_8U_2 = cvCreateImage(cvGetSize(pSrcImage), IPL_DEPTH_8U, 1); IplImage *pGrayImage_64F=cvCreateImage(cvGetSize(pSrcImage), IPL_DEPTH_64F, 1); cvCvtColor(pSrcImage, pGrayImage_8U, CV_BGR2GRAY); //RGB转灰度图像 cvConvertScale(pGrayImage_8U, pGrayImage_64F); //8U转64F cvConvertScale(pGrayImage_64F, pGrayImage_8U_2) //64F转8U

补充知识:OpenCV中利用cvConvertScale()对图像数据作线性变换~

在OpenCV的IplImage结构体char * imageData成员的说明中,官方文档明确提示大家不能对这个指针所对应的数据直接操作,否则会带来意想不到的错误。

原话是这样的:

Do not assign imageData directly. Use SetData().

如何通过OpenCV实现图像数据从64位浮点数到8位无符号整数的转换?

我曾经就犯傻直接进行操作,结果造成数据类型不匹配,最后还非得去修改头文件中的char * imageData为unsigned char * imageData才解决问题,然而这种操作是极其不妥的~正确的做法是用OpenCV提供的各种函数来对图像数据就行操作!比如cvConvertScale()、Use SetData()之类的!

这里我用cvConvertScale()来实现灰度图像的线性变换,程序非常简洁,而且没有任何问题!

源代码如下:

#include <opencv2/opencv.hpp> #include <opencv2/legacy/compat.hpp> using namespace std; #pragma comment(linker, "/subsystem:\"windows\" /entry:\"mainCRTStartup\"") int main() { int i=0; unsigned char *imageData_1; unsigned char *imageData_2; const char *pstrWindowsATitle = "原图像(opencv66.net)"; const char *pstrWindowsBTitle = "线性变换后的图像(opencv66.net))"; //从文件中加载原图 IplImage *pSrcImage = cvLoadImage("coins.png", CV_LOAD_IMAGE_UNCHANGED); //创建输出的图像 IplImage *pOutImage = cvCreateImage(cvGetSize(pSrcImage), IPL_DEPTH_8U,1); cvConvertScale(pSrcImage,pOutImage,2,-55); //利用cvConvertScale增加对比度的线性变换,线性变换中的比例因子k=2 偏移值b=-55 cvNamedWindow(pstrWindowsATitle, CV_WINDOW_AUTOSIZE); cvShowImage(pstrWindowsATitle,pSrcImage); cvNamedWindow(pstrWindowsBTitle, CV_WINDOW_AUTOSIZE); cvShowImage(pstrWindowsBTitle, pOutImage); cvWaitKey(0); cvDestroyWindow(pstrWindowsATitle); cvDestroyWindow(pstrWindowsBTitle); cvReleaseImage(&pSrcImage); cvReleaseImage(&pOutImage); return 0; }

运行结果如下图所示(和我在MATLAB中的运行结果一致哦)

MATLAB运行后的结果

以上这篇利用OpenCV中对图像数据进行64F和8U转换的方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持易盾网络。