C++实现中值滤波的示例代码
void medianFilter(cv::Mat& src, cv::Mat& dst, cv::Size width)
{
//判断窗口是否为奇数
if (width.width % 2 == 0 || width.height % 2 == 0)
{
std::cout << "输入窗口大小应该为奇数,请重新输入" << endl;
exit(-1);
}
else
{
//计算边界扩充长度
int h = (width.height - 1) / 2;
int w = (width.width - 1) / 2;
//对原图边界扩充
cv::Mat src_border;
cv::copyMakeBorder(src, src_border, h, h, w, w, cv::BORDER_REFLECT_101);
for (int i = h; i < src.rows + h; i++)
{
for (int j = w; j < src.cols + w; j++)
{
//定义容器存放窗口对应的像素
std::vector
for (int ii = i - h; ii <= i + h; ii++)
{
for (int jj = j - w; jj <= j + w; jj++)
{
v.push_back(src_border.at
}
}
//对容器内存放的像素排序
int len = width.area();
bubble(v, len);
//将中值赋给目标图像对应位置
dst.at
}
}
}
}
- .NET Core系列之MemoryCache 初识
- 007手机一键Root(安机网一键Root) v3.0 官方最新版 一键ROOT您的Android手机
- 12306密码被盗了怎么办?12306密码外泄解决方法
- 12个字的qq网名
- 150M迷你型无线路由器怎么设置?
- 192.168.1.1打不开怎么办?路由器192.168.1.1打不开的原因以及解决办法
- 2011年电子报合订本 电子报 编辑部 中文 PDF版 [84M]
- 2015年1月15日小米新旗舰发布会现场图文直播
- 2016.3.1vivo Xplay5新品发布会现场视频直播 优酷直播
- 2016华为P9发布会视频直播地址 4月15日华为P9国行发布会直播