在使用C ++时,我并没有很好的体验,当我使用不操纵图像的方法时,我从Andrey Smorodov获得了一些代码。我相信它是通过值传递的,一旦方法完成运行,变量就消失了。有人可以告诉我,如果通过引用vs值是错误的吗?当我注释掉该方法时,它不会更改结果图像。
方法:
void CalcBlockMeanVariance(cv::Mat Img,cv::Mat Res,float blockSide=21) // blockSide - the parameter (set greater for larger font on image)
{
cv::Mat I;
Img.convertTo(I,CV_32FC1);
Res=cv::Mat::zeros(Img.rows/blockSide,Img.cols/blockSide,CV_32FC1);
cv::Mat inpaintmask;
cv::Mat patch;
cv::Mat smallImg;
cv::Scalar m,s;
for(int i = 0;i < Img.rows-blockSide;i+=blockSide)
{
for (int j=0;j<Img.cols-blockSide;j+=blockSide)
{
patch=I(cv::Rect(j,i,blockSide,blockSide));
cv::meanStdDev(patch,m,s);
if(s[0]>0.01) // Thresholding parameter (set smaller for lower contrast image)
{
Res.at<float>(i/blockSide,j/blockSide)=m[0];
}else
{
Res.at<float>(i/blockSide,j/blockSide)=0;
}
}
}
cv::resize(I,smallImg,Res.size());
cv::threshold(Res,inpaintmask,0.02,1.0,cv::THRESH_BINARY);
cv::Mat inpainted;
smallImg.convertTo(smallImg,CV_8UC1,255);
inpaintmask.convertTo(inpaintmask,CV_8UC1);
inpaint(smallImg, inpaintmask, inpainted, 5, cv::INPAINT_TELEA);
cv::resize(inpainted,Res,Img.size());
Res.convertTo(Res,CV_32FC1,1.0/255.0);
}
调用方法:
cv::Mat cvImage = [self cvMatFromUIImage:image];
cv::Mat res;
cv::cvtColor(cvImage, cvImage, CV_RGB2GRAY);
cvImage.convertTo(cvImage,CV_32FC1,1.0/255.0);
//CalcBlockMeanVariance(cvImage,res);
res=1.0-res;
res=cvImage+res;
cv::threshold(res,res, 0.85, 1, cv::THRESH_BINARY);
cv::resize(res, res, cv::Size(res.cols/2,res.rows/2));
cvImage.convertTo(cvImage,CV_8UC3,255.0);
_endImage = [self UIImageFromCVMat:cvImage];
转换回UIImage
时,我可能会丢失任何数据吗?
这是我的结果图片:
安德利使用这种方法的结果:
有没有人可以解释为什么与安德烈相比,我可能会得到如此不同的结果? 感谢
答案 0 :(得分:0)
将功能定义更改为以下内容:
void CalcBlockMeanVariance(const cv::Mat &Img, cv::Mat &Res, float blockSide=21)