OpenCV filter2D 内部非矩形 ROI

OpenCV filter2D inside non rectangular ROI

本文关键字:ROI filter2D 内部 OpenCV      更新时间:2023-10-16

我有一个图像,其中只有一小部分非矩形部分是有用的。我有一个二进制掩码,指示有用的投资回报率。

如何将 OpenCV 中的cv::filter2D仅应用于由二进制掩码定义的 ROI?


编辑

ROI 之外的像素值为 0。另一个的浮点值约为 300-500,因此 ROI 边界中的 filter2D 问题具有很高的值转换。

将ROI之外的像素值设置为ROI内最接近的像素也是可以接受的,类似于cv::BORDER_REPLICATE

可能是这样的。我认为边境口罩附近没有问题

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

int main(int argc, char* argv[])
{
Mat m = imread("f:/lib/opencv/samples/data/lena.jpg", CV_LOAD_IMAGE_GRAYSCALE);
Mat mask=Mat::zeros(m.size(), CV_8UC1),maskBlur,mc;
// mask is a disk
circle(mask, Point(200, 200), 100, Scalar(255),-1);
Mat negMask;
// neg mask
bitwise_not(mask, negMask);
circle(mask, Point(200, 200), 100, Scalar(255), -1);
Mat md,mdBlur,mdint;
m.copyTo(md);
// All pixels outside mask set to 0
md.setTo(0, negMask);
imshow("mask image", md);
// Convert image to int
md.convertTo(mdint, CV_32S);
Size fxy(13, 13);
blur(mdint, mdBlur, fxy);
mdBlur.convertTo(mc, CV_8U);
imshow("Blur without mask", mc);
imwrite("blurwithoutmask.jpg",mc);
mask.convertTo(maskBlur, CV_32S);
// blur mask
blur(maskBlur, maskBlur, fxy);
Mat mskB;
mskB.setTo(1, negMask);
divide(mdBlur,maskBlur/255,mdBlur);
mdBlur.convertTo(mc, CV_8U);
imshow("Blur with mask", mc);
imwrite("blurwithmask.jpg",mc);
waitKey();
}