我尝试将原始像素数据转换为QPixmap,但将qimage转换为qpixmap时出错。
首先,我通过qlocalsocket从服务器A发送原始数据,然后客户端B获取它。
这是服务器A.
if (clientSocket)
{
if (clientSocket->isOpen())
{
QByteArray block;
QDataStream out(&block, QIODevice::WriteOnly);
out.setVersion(QDataStream::Qt_5_7);
const char* rc_data = reinterpret_cast<const char*>(r_data);
out <<sizeof(strlen(rc_data))<< r_width << r_height << r_step;
out.writeBytes(rc_data, strlen(rc_data));
clientSocket->write(block);
clientSocket->flush();
}
}
这是客户B。
QByteArray block = connection->readAll();
QDataStream in(&block, QIODevice::ReadOnly);
in.setVersion(QDataStream::Qt_5_7);
char* data;
size_t size;
int width;
int height;
int step;
while (!in.atEnd())
{
in >> size >> width >> height >> step;
in.readBytes(data,size);
}
mutex.lock();
receivePixmap = QPixmap::fromImage(QImage((unsigned char*)data, width, height, step, QImage::Format::Format_RGB888));
mutex.unlock();
ui.label->setPixmap(receivePixmap.scaled(ui.label->size(), Qt::KeepAspectRatio));
}
将(unsigned char *)数据转换为QImage时没有错误,但QPixmap :: fromImage时出错。
当我调试代码时,发送和接收的数据是相同的。
这是我的错误。 错误:0xC0000005:访问冲突读取位置0xCDCDCDD1。
发生在这里。
#ifdef Q_COMPILER_RVALUE_REFS
static QPixmap fromImage(QImage &&image, Qt::ImageConversionFlags flags = Qt::AutoColor)
{
return fromImageInPlace(image, flags);
}
#endif
请分享您的想法谢谢。
答案 0 :(得分:1)
序列化时,您将尺寸组件写为sizeof strlen(rc_data)
,即sizeof (size_t)
,这可能比data
的内容小得多(它通常为4或8)字节)。重新构建图像数据时,只能读取该大小,因此QImage
现在指的是内存空间不足以表示width
x {{1} }像素。
您需要编写height
的实际长度才能成功读取它。 data
几乎肯定是错误的衡量标准,因为它测量的是以空值终止的字符串,而像素数据却不是。如果没有完整的示例,则无法确定如何确定strlen(rcdata)
的长度。
答案 1 :(得分:0)
我解决了这个问题
writeBytes(rc_data,r_step*r_height)
readBytes(data,r_step*r_height)
我检查了strlen(rc_data),但这个大小不正确。
图像的实际尺寸为step * height。
谢谢你们~~~ !!!答案 2 :(得分:-1)
使用QPixmap的loadFromData方法:
bool QPixmap::loadFromData(const uchar * data, uint len, const char * format = 0, Qt::ImageConversionFlags flags = Qt::AutoColor)
或者
bool QPixmap::loadFromData(const QByteArray & data, const char * format = 0, Qt::ImageConversionFlags flags = Qt::AutoColor)