要求:
将cat.jpg中猫放置到table.jpg中的桌子上
一开始我的想法是将cat.jpg中绿色部分变成透明,然后贴在table.jpg上,发现得要将图片改成png格式能增加一个表示透明度的通道,尝试过后发现达不到我的效果,不知道什么原因。后来我采用遍历cat.jpg,一个个像素替换的方法,发现比我预想简单许多。操作的时候,总会边缘有一圈绿色的抠不干净,改了几次限制条件还是不尽如人意,最后在网络上搜索了一下,说HSV的颜色空间对于绿色背景的筛选更加便当,于是将图片转化成HSV,效果还可以,比之前好很多。(代码部分opencv的头文件没有添加,用者记得加一下··)
int main(int argc, char** argv) {
Mat img1 = imread("C:/Users/WU/Desktop/数字图像处理/DIP实验2/cat.jpg");
Mat img2 = imread("C:/Users/WU/Desktop/数字图像处理/DIP实验2/table.jpg");
Mat img3;
cvtColor(img1, img3, COLOR_BGR2HSV); //将图像由RGB颜色模型转化为HSV颜色模型
Mat roi = img2(Rect(384, 210, img1.cols, img1.rows)); //在table.jpg中创建复制区域
for (int i = 0; i < img1.rows; i++) //遍历cat.jpg中的像素
{
for (int j = 0; j < img1.cols; j++)
{
if(img3.at<Vec3b>(i, j)[2] != 255 && img3.at<Vec3b>(i, j)[0] < 50) //抠图限制条件
{
roi.at<Vec3b>(i, j)[0] = img1.at<Vec3b>(i, j)[0];
roi.at<Vec3b>(i, j)[1] = img1.at<Vec3b>(i, j)[1];
roi.at<Vec3b>(i, j)[2] = img1.at<Vec3b>(i, j)[2];
}
}
}
imshow("test",img2);
imwrite("cat on the table.jpg", img2);
waitKey(0);
destroyAllWindows();
return 0;
}