1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
| QImage IplToQImage(const IplImage *newImage)
{
QImage qtemp;
if(newImage && newImage->width>0)//image valide
{
int x;
int y;
char* data = newImage->imageData;
qtemp = QImage(newImage->width, newImage->height,QImage::Format_RGB32);//on cree l'architecture de la QImage
for( y = 0; y < newImage->height; y++, data +=newImage->widthStep )
for( x = 0; x < newImage->width; x++)
{
uint *p = (uint*)qtemp.scanLine(newImage->height-y-1) +x;//le scanline est a adapter, selon l'originie de l'IplImage
*p = qRgb(data[x * newImage->nChannels+2],//on "copie" la valeur du pixel, alpha est par défaut opaque
data[x * newImage->nChannels+1],
data[x * newImage->nChannels]);
}
}
return qtemp;
} |
Partager