Pixmap from QImage is broken
- 
Hi folks, in a sample project I try to implement littlecms as described here.(https://littlecms.com/blog/2020/12/09/using-lcms2-on-qt/) All went s fine - until I create the QPixmap to be displayed int the graphic scene. 
 For debugging I also save the image to harddisk (next to the executable).a) When I load this image into the pixmap it works fine 
 b) If I copy the image from memory the result is brokenHere is my download page for sample projects. 
 http://code.ademmler.comThe effected lines are 94-100. Regards & Thx Alex 
- 
Here is the reason and solution. Thanks to Marti Maria - the author of littlecms - 
 to sort this out ...This program does not work because you missed the part on 
 https://littlecms.com/blog/2020/12/09/using-lcms2-on-qt/ that says:Alpha channels are supported as long as the image is not using premultiplied alpha. To get alpha channel make sure to include cmsFLAGS_COPY_ALPHA in the flags field. This is explained in LittleCMS documentation. So, try: toDisplay = colorManage(sourceImage, profiles, INTENT_PERCEPTUAL, cmsFLAGS_COPY_ALPHA);* This fixed the issue for me. 
- 
Put your qDebug() before the return in MainWindow::colorManage() will show you the warnings. Putting them after the return statement is somewhat useless. 
- 
Hi, Just in case, there are several return statement in the LittleCMS sample code, you should check all of them. 
- 
Put your qDebug() before the return in MainWindow::colorManage() will show you the warnings. Putting them after the return statement is somewhat useless. @Christian-Ehrlicher thx for your hint - I have overseen this :-) I have done this and here is the output: 
 21:12:06: Starting /Users/ademmler/QtTryouts/GraphicsViewer/build/debug/GraphicsViewer.app/Contents/MacOS/GraphicsViewer ...Hence no error at all. As i wrote to SGaist the final image (saved to hardest for debugging) is fine. It really seems to be an issue with 
 QPixmap pixmap = QPixmap::fromImage(toDisplay);
- 
Hi, Just in case, there are several return statement in the LittleCMS sample code, you should check all of them. @SGaist the result from littlecms is perfectly fine. As you can see from the image saved next to the executable. 
 Especially when I load this into my graphics scene the result is ok:
 QPixmap pixmap;
 pixmap.load("toDisplay.jpg");but if I do this: 
 QPixmap pixmap = QPixmap::fromImage(toDisplay);the image is "distorted/broken) somehow ... 
- 
When I run your program, cmsCreateMultiprofileTransform() returns a nullptr and (since I corrected the qDebug - output) get the warning 'Couldn't create color transform !' and then a QMessageBox that the image conversion failed. 
- 
When I run your program, cmsCreateMultiprofileTransform() returns a nullptr and (since I corrected the qDebug - output) get the warning 'Couldn't create color transform !' and then a QMessageBox that the image conversion failed. @Christian-Ehrlicher thx for your response. I have corrected my code - as you mentioned - but I do not get this warning. 
 I get an broken image displayed. Here is a screenshot:
 http://code.ademmler.com/gvimg01.pngAnd here is what qt saved to hard disk: 
 http://code.ademmler.com/toDisplay.jpgNote: 
 I have also contacted the author of little CMS - he wrote this sample code.
 I got stuck between opinions and thoughts
- 
What is the format of the QImage (toDisplay->format())? Can you show exactly what you mean by 'the image is distorted/broken'. @mchinand https://littlecms.com/blog/2020/12/09/using-lcms2-on-qt/ little cmd uses a different format than qt - that is what the author wrote about it. 
 I just try to create a working minimal sample ...Here is what the resulting image looks like: 
 http://code.ademmler.com/gvimg01.pngAnd here is what qt saved to hard disk: 
 http://code.ademmler.com/toDisplay.jpg
- 
And here is the pixmap saved to hard disk: 
 http://code.ademmler.com/qtPixmap.jpgWhich is also ok - hence I do not understand what's going wrong with displaying this ... 
- 
And here is the pixmap saved to hard disk: 
 http://code.ademmler.com/qtPixmap.jpgWhich is also ok - hence I do not understand what's going wrong with displaying this ... @ademmler have you checked the format of toDisplay? Image::save does take guesses if the format is missing or wrong.
 Also you should check the return type of save, in case saving fails and you actually see the file of a previous attempt
- 
When I run your program, cmsCreateMultiprofileTransform() returns a nullptr and (since I corrected the qDebug - output) get the warning 'Couldn't create color transform !' and then a QMessageBox that the image conversion failed. @Christian-Ehrlicher said in Pixmap from QImage is broken: When I run your program, cmsCreateMultiprofileTransform() returns a nullptr and (since I corrected the qDebug - output) get the warning 'Couldn't create color transform !' and then a QMessageBox that the image conversion failed. Are you working on MacOS or Windows? 
 Have you littlecms installed ? Or checked if you can use the libs I provided?
- 
@ademmler have you checked the format of toDisplay? Image::save does take guesses if the format is missing or wrong.
 Also you should check the return type of save, in case saving fails and you actually see the file of a previous attempt
- 
@ademmler have you checked the format of toDisplay? Image::save does take guesses if the format is missing or wrong.
 Also you should check the return type of save, in case saving fails and you actually see the file of a previous attempt@J-Hilk Here is what I see in the debugger. Looks like all "images" have content. 
 http://code.ademmler.com/debugger.pngPls - where can I see the "return value type" in this window? 
- 
Here is the reason and solution. Thanks to Marti Maria - the author of littlecms - 
 to sort this out ...This program does not work because you missed the part on 
 https://littlecms.com/blog/2020/12/09/using-lcms2-on-qt/ that says:Alpha channels are supported as long as the image is not using premultiplied alpha. To get alpha channel make sure to include cmsFLAGS_COPY_ALPHA in the flags field. This is explained in LittleCMS documentation. So, try: toDisplay = colorManage(sourceImage, profiles, INTENT_PERCEPTUAL, cmsFLAGS_COPY_ALPHA);* This fixed the issue for me. 
 


