Skip to main content

OpenCV : Image synthesis (ROI, Mask, Binary)

Today we will make Image synthesis by using ROI, Masking, binarization.





The full code is like that.

#include <iostream>
#include "opencv2/opencv.hpp"
using namespace std;
using namespace cv;

int main() {
    Mat me = imread("./res/pic/mh.jpg");
    Mat animal = imread("./res/pic/animal_head.png");
    Mat animalGray;
    Mat mask_ani;
    Mat mask_ani_inv;
    imshow("me origin", me);
    imshow("animal", animal);
    cvtColor(animal, animalGray, CV_BGR2GRAY); // color to black and white    
    threshold(animalGray, mask_ani, 10, 255, 0); // make binary    
    bitwise_not(mask_ani, mask_ani_inv);
    imshow("mask ani inv", mask_ani_inv);
    imshow("mask ani", mask_ani);

    Mat imgRoi;
    imgRoi = me(Rect(50, 50, animal.cols, animal.rows));
    imshow("imgRoi", imgRoi);
    Mat me_back;
    Mat ani_for;

    bitwise_and(animal, animal, ani_for, mask_ani); // mask with mask_ani    
    bitwise_and(imgRoi, imgRoi, me_back, mask_ani_inv); // mask with mask_ani_inv    
    imshow("ani_for", ani_for);
    imshow("me_back", me_back);

    Mat dst;
    add(me_back, ani_for, dst); //add background of roi , foreground of animal    
    dst.copyTo(imgRoi); // result copy to imgRoi    imshow("dst", dst);
    imshow("result", me);
    waitKey(0);
    return 0;
}



  • Make binary images for masking background and foreground images

cvtColor(animal, animalGray, CV_BGR2GRAY); // color to black and white
threshold(animalGray, mask_ani, 10, 255, 0); // make binary
bitwise_not(mask_ani, mask_ani_inv);



  • Make image ROI and fit to the synthesis position.
Mat imgRoi;
// start at x:50, y:50, size width: animal.cols, height: animal.rows
imgRoi = me(Rect(50, 50, animal.cols, animal.rows)); 
imshow("imgRoi", imgRoi);




  • Remove animal image background and the part of the image ROI that will contain the animal picture by using bitwise operation.
Mat me_back;
Mat ani_for;
bitwise_and(animal, animal, ani_for, mask_ani); // remove background
bitwise_and(imgRoi, imgRoi, me_back, mask_ani_inv); // remove foreground
imshow("ani_for", ani_for);
imshow("me_back", me_back);




  • Finally add background of ROI, foreground of animal image.
Mat dst;
add(me_back, ani_for, dst); //add background of roi , foreground of animal
dst.copyTo(imgRoi); // result copy to imgRoi
imshow("dst", dst);
imshow("result", me);
waitKey(0);



Comments

Popular posts from this blog

OpenGL SL - Translate, roate, and scale

Translate, rotate and scale are most basic element of image effect. If you didn't understand how make effect at each pixel, please read again before post "Show Video and Image" . 1. Translate Translation means each pixel move parallel on the x, y-axis. In other words, if you want to translate 0.25 on the x-axis, a pixel should point to a distance of -0.25 from the original. Translate ex) void mainImage( out vec4 fragColor, in vec2 fragCoord ){     vec2 uv = fragCoord/iResolution.xy;     if (uv.x < 0.5 ){         // translate to x ( -0.25 )         uv.x += 0.25 ;     } else {         // translate to x ( +0.25 )         uv.x -= 0.25 ;     }     fragColor = texture (iChannel0, uv); } result) 2. Scale Scale also has a  similar concept to parallel translation. If you want to zoom in twice, each pixel s...

OpenGL SL - Mosaic effect

Mosaic effect is similar to lowering the resolution of an image. Let's see example image. And full source code likes below. void mainImage( out vec4 fragColor, in vec2 fragCoord ){     // Normalized pixel coordinates (from 0 to 1)     vec2 uv = fragCoord/iResolution.xy;     if (uv.x > 0.7 && uv.y < 0.4 ){          //left bottoom small image         uv.x -= 0.6 ;         uv *= 2.0 ;         fragColor = texture (iChannel0, uv);         fragColor += vec4 ( 0.2 );         return ;     }     //mosaic effect     uv = uv * 30.0 ;     vec2 uv = floor (uv);     uv = uv/ 30.0 ;     fragColor = texture (iChannel0, uv); } The key function of mosaic effect is "floor" If you want to make it sharper, multiply uv by ...

OpenCV : How to setting OpenCV in CLion

CLion is A Cross-Platform IDE for C and C++ by JetBrains Setting OpenCV in CLion is so easy. FIrst, make new c++ project. Second, edit CmakeList.txt cmake_minimum_required( VERSION 3.10 ) project( [YourProject] ) set( CMAKE_CXX_STANDARD 11 ) find_package( OpenCV REQUIRED ) add_executable( [YourProject] main.cpp ) target_link_libraries( [YourProject] ${OpenCV_LIBS} ) At Last include OpenCV to main.cpp #include <iostream> #include "opencv2/opencv.hpp" using namespace std ; using namespace cv ; ...