将 QImage* 转换为 void* ,反之亦然
Convert QImage* to void* and vice versa
我正在开发 C++ QT 项目,该项目包含一些模块,它们通过一个控制器模块使用带有签名的函数相互通信:
notify(QString stream_id, const void* stream, unsigned __int64 size)
所以我问的是如何将主要是 QImage* 的 QT 数据类型转换为 void*,反之亦然,以使用 void 指针及其大小发送数据,
我正在尝试使用此代码,但它不起作用:
void* imageVoidPtr = static_cast<void*>(&image);
StreamListener::getInstance()->notify(QString("Stream_Name"),imageVoidPtr,sizeof(imageVoidPtr));
------------- 编辑
我正在尝试使用以下方法检索数据:
void VideoView::receive(QString stream_id, const void* stream, unsigned __int64 size){
QByteArray data = QByteArray::fromRawData(reinterpret_cast<const char*>(stream), size);
QBuffer buffer(&data);
QImageReader reader(&buffer);
QImage img = reader.read();}
--------编辑2
Void* 缓冲区的大小为 4 或 12(在 sizeOf(QImage) 的情况下)并且没有给出正确的图像字节大小的代码有什么问题,
并且接收器中接收到的图像是空的(没有出现错误)。
谢谢
乍一看,这显然是导致您的代码无法运行的问题:
StreamListener::getInstance()->notify(QString("Stream_Name"),imageVoidPtr,sizeof(imageVoidPtr));
最后一个参数应该是 sizeof(QImage) 而不是像下面这样:
StreamListener::getInstance()->notify(QString("Stream_Name"),imageVoidPtr,sizeof(QImage));
希望它能以这种方式工作,但如果没有,最好指出代码有什么问题,如果它不工作,输出或错误是什么?
使用QImage
save method:
QImage image;
QByteArray ba;
QBuffer buffer(&ba);
buffer.open(QIODevice::WriteOnly);
image.save(&buffer, "PNG"); // writes image into ba in PNG format
您现在可以像这样使用 QByteArray
底层缓冲区:
void* imageVoidPtr = static_cast<void*>(ba.data());
StreamListener::getInstance()->notify(QString("Stream_Name"), imageVoidPtr, ba.size());
如果您需要设置 format-specific 选项(例如质量、压缩格式),请使用 QImageWriter,而不是:
QByteArray ba;
QBuffer buffer(&ba);
QImageWriter writer(&buffer, "JPG");
writer.setQuality(100); //max quality for jpeg
writer.write(image);
在接收端,一切都应该已经很好了(使用 QBuffer
和 QImageReader
)。
令人惊奇的是你期望它能起作用。
指针只是一个整数,代表一个可以存放任意数据的内存地址。因此指针总是相同的大小,无论它指向什么,因为它总是一个内存地址,并且它总是由固定数量的位表示,32 位构建中为 32,64 位构建中为 64。
QImage
将数据存储在堆上。实际的 class 只是数据的控制器。因此 sizeof()
无论图片有多大,结果都是一样的。
QImage
已经支持序列化和反序列化使用 QDataStream
:
QImage img(100, 100, QImage::Format_Mono); // original image
QByteArray data; // data container
QBuffer buffer(&data); // io device
buffer.open(QIODevice::ReadWrite);
QDataStream stream(&buffer); // data stream
stream << img; // save img to data
// you can now use the data.data() pointer, convert to void, and send data.size() number of bytes and put it into another byte array on the other side
// then replicate the io dev and data stream steps too, omitted for brevity
QImage img2; // new image
buffer.seek(0); // go to beginning of data
stream >> img2; // read data into new image
qDebug() << (img == img2) << data.size(); // true, it is the same content, size is 723 bytes, that includes the image format and raw data
我找到了解决这个问题的简单方法,
在将数据作为 void* 发送时,我只是将 QImage 的地址提供给通知函数,不需要大小:
QImage image = CreateImage(imageStreamByteArray);
StreamListener::getInstance()->notify(StreamsNames::VIDEO_DAT_IMAGE,&image,0);
并且在接收时我使用了这种类型的铸造,但没有使用尺寸:
void VideoView::receive(QString stream_id, const void* stream, unsigned __int64 size){
QImage *img = const_cast<QImage*>(reinterpret_cast<const QImage *>(stream));
updateDisplay(img);
}
谢谢
我正在开发 C++ QT 项目,该项目包含一些模块,它们通过一个控制器模块使用带有签名的函数相互通信:
notify(QString stream_id, const void* stream, unsigned __int64 size)
所以我问的是如何将主要是 QImage* 的 QT 数据类型转换为 void*,反之亦然,以使用 void 指针及其大小发送数据,
我正在尝试使用此代码,但它不起作用:
void* imageVoidPtr = static_cast<void*>(&image);
StreamListener::getInstance()->notify(QString("Stream_Name"),imageVoidPtr,sizeof(imageVoidPtr));
------------- 编辑
我正在尝试使用以下方法检索数据:
void VideoView::receive(QString stream_id, const void* stream, unsigned __int64 size){
QByteArray data = QByteArray::fromRawData(reinterpret_cast<const char*>(stream), size);
QBuffer buffer(&data);
QImageReader reader(&buffer);
QImage img = reader.read();}
--------编辑2
Void* 缓冲区的大小为 4 或 12(在 sizeOf(QImage) 的情况下)并且没有给出正确的图像字节大小的代码有什么问题, 并且接收器中接收到的图像是空的(没有出现错误)。
谢谢
乍一看,这显然是导致您的代码无法运行的问题:
StreamListener::getInstance()->notify(QString("Stream_Name"),imageVoidPtr,sizeof(imageVoidPtr));
最后一个参数应该是 sizeof(QImage) 而不是像下面这样:
StreamListener::getInstance()->notify(QString("Stream_Name"),imageVoidPtr,sizeof(QImage));
希望它能以这种方式工作,但如果没有,最好指出代码有什么问题,如果它不工作,输出或错误是什么?
使用QImage
save method:
QImage image;
QByteArray ba;
QBuffer buffer(&ba);
buffer.open(QIODevice::WriteOnly);
image.save(&buffer, "PNG"); // writes image into ba in PNG format
您现在可以像这样使用 QByteArray
底层缓冲区:
void* imageVoidPtr = static_cast<void*>(ba.data());
StreamListener::getInstance()->notify(QString("Stream_Name"), imageVoidPtr, ba.size());
如果您需要设置 format-specific 选项(例如质量、压缩格式),请使用 QImageWriter,而不是:
QByteArray ba;
QBuffer buffer(&ba);
QImageWriter writer(&buffer, "JPG");
writer.setQuality(100); //max quality for jpeg
writer.write(image);
在接收端,一切都应该已经很好了(使用 QBuffer
和 QImageReader
)。
令人惊奇的是你期望它能起作用。
指针只是一个整数,代表一个可以存放任意数据的内存地址。因此指针总是相同的大小,无论它指向什么,因为它总是一个内存地址,并且它总是由固定数量的位表示,32 位构建中为 32,64 位构建中为 64。
QImage
将数据存储在堆上。实际的 class 只是数据的控制器。因此 sizeof()
无论图片有多大,结果都是一样的。
QImage
已经支持序列化和反序列化使用 QDataStream
:
QImage img(100, 100, QImage::Format_Mono); // original image
QByteArray data; // data container
QBuffer buffer(&data); // io device
buffer.open(QIODevice::ReadWrite);
QDataStream stream(&buffer); // data stream
stream << img; // save img to data
// you can now use the data.data() pointer, convert to void, and send data.size() number of bytes and put it into another byte array on the other side
// then replicate the io dev and data stream steps too, omitted for brevity
QImage img2; // new image
buffer.seek(0); // go to beginning of data
stream >> img2; // read data into new image
qDebug() << (img == img2) << data.size(); // true, it is the same content, size is 723 bytes, that includes the image format and raw data
我找到了解决这个问题的简单方法,
在将数据作为 void* 发送时,我只是将 QImage 的地址提供给通知函数,不需要大小:
QImage image = CreateImage(imageStreamByteArray);
StreamListener::getInstance()->notify(StreamsNames::VIDEO_DAT_IMAGE,&image,0);
并且在接收时我使用了这种类型的铸造,但没有使用尺寸:
void VideoView::receive(QString stream_id, const void* stream, unsigned __int64 size){
QImage *img = const_cast<QImage*>(reinterpret_cast<const QImage *>(stream));
updateDisplay(img);
}
谢谢