OpenCV_13羽化
opencv
OpenCV: 开源计算机视觉库
项目地址:https://gitcode.com/gh_mirrors/opencv31/opencv
免费下载资源
·
一,原图:
二,代码:
//13羽化
float mSize = 0.5;
void Feathering()
{
Mat src = imread("D:\\test\\lena.jpg");
imshow("src", src);
int width = src.cols;
int heigh = src.rows;
int centerX = width >> 1;
int centerY = heigh >> 1;
int maxV = centerX*centerX + centerY*centerY;
int minV = (int)(maxV*(1 - mSize));
int diff = maxV - minV;
float ratio = width >heigh ? (float)heigh / (float)width : (float)width / (float)heigh;
Mat img;
src.copyTo(img);
Scalar avg = mean(src);
Mat dst(img.size(), CV_8UC3);
Mat mask1u[3];
float tmp, r;
for (int y = 0; y<heigh; y++)
{
uchar* imgP = img.ptr<uchar>(y);
uchar* dstP = dst.ptr<uchar>(y);
for (int x = 0; x<width; x++)
{
int b = imgP[3 * x];
int g = imgP[3 * x + 1];
int r = imgP[3 * x + 2];
float dx = centerX - x;
float dy = centerY - y;
if (width > heigh)
dx = (dx*ratio);
else
dy = (dy*ratio);
int dstSq = dx*dx + dy*dy;
float v = ((float)dstSq / diff) * 255;
r = (int)(r + v);
g = (int)(g + v);
b = (int)(b + v);
r = (r>255 ? 255 : (r<0 ? 0 : r));
g = (g>255 ? 255 : (g<0 ? 0 : g));
b = (b>255 ? 255 : (b<0 ? 0 : b));
dstP[3 * x] = (uchar)b;
dstP[3 * x + 1] = (uchar)g;
dstP[3 * x + 2] = (uchar)r;
}
}
imshow("羽化", dst);
waitKey();
imwrite("D://羽化.jpg", dst);
}
//-----开始------
void COpenCVLearningDlg::OnBnClickedStartButton()
{
Feathering();
}
三,结果:
欢迎扫码关注我的微信公众号
原文地址:https://blog.csdn.net/sangni007/column/info/stylizefliter
GitHub 加速计划 / opencv31 / opencv
156
15
下载
OpenCV: 开源计算机视觉库
最近提交(Master分支:4 个月前 )
4d26e16a
Speed up and reduce memory consumption for findContours 2 天前
1db98278
Add jxl (JPEG XL) codec support #26379
### Pull Request Readiness Checklist
Related CI and Docker changes:
- https://github.com/opencv/ci-gha-workflow/pull/190
- https://github.com/opencv-infrastructure/opencv-gha-dockerfile/pull/44
See details at https://github.com/opencv/opencv/wiki/How_to_contribute#making-a-good-pull-request
- [x] I agree to contribute to the project under Apache 2 License.
- [x] To the best of my knowledge, the proposed patch is not based on a code under GPL or another license that is incompatible with OpenCV
- [x] The PR is proposed to the proper branch
- [x] There is a reference to the original bug report and related work https://github.com/opencv/opencv/issues/20178
- [ ] There is accuracy test, performance test and test data in opencv_extra repository, if applicable
Patch to opencv_extra has the same branch name.
- [x] The feature is well documented and sample code can be built with the project CMake
2 天前
更多推荐
已为社区贡献10条内容
所有评论(0)