Search code examples
qtimage-masking

QT : Masking an image - Suggestions?


I dont know if I am using the correct term here. However this is what I am trying to achieve and I would like some suggestions on how I could achieve that. I want to have a circle with border visible. Now here is the hard part and something I dont even know how to start with. I want to manipulate the circle in such a way that the borders of the circle are visible and its center is not (i.e Pretty much that it has a hole in it and would show what ever is placed under it)I would then like to have another image placed under the circle such that only the part of the image that is under the transparent part of the circle is shown the parts outside the transparent boundary of the circle become invisible. Any suggestions on how I could achieve this. It seems that googling isnt helping me.


Solution

  • I would suggest the alternative way for unmasking a circular area of an image. You can specify the clip region - the area where you need to perform painting. For example:

    [..]
    QPainter painter(this);
    // Sample circular area.
    QRegion r(QRect(100, 100, 200, 200), QRegion::Ellipse);
    painter.setClipRegion(r);
    [..]
    painter.drawImage(0, 0, image);
    [..]
    

    This will draw only those parts of your image that are inside of the circle with radius 200. All the rest pixels will be hidden. You can handle mouse move event to move this "circle" over the image like a loupe.

    UPDATE

    Below is the sample code that generates an image with circular mask and insert it into the label:

    QPixmap target(500, 500); // the size may vary
    QPixmap source("image.png");
    
    QPainter painter(&target);
    QRegion r(QRect(100, 100, 200, 200), QRegion::Ellipse);
    painter.setClipRegion(r);
    painter.drawPixmap(0, 0, source);
    
    QLabel l;
    l.setPixmap(target);
    l.show();