当前位置: 首页 > news >正文

图像扭曲之锯齿

源码:

void wave_sawtooth(cv::Mat& src,cv::Mat& dst,double amplitude,double wavelength)
{dst.create(src.rows, src.cols, CV_8UC3);dst.setTo(0);double xAmplitude = amplitude;double yAmplitude = amplitude;int xWavelength = wavelength;int yWavelength = wavelength;for (int h = 0; h < dst.rows; h ++) {double fh = 1.0 * (h % yWavelength) / yWavelength;fh = h + yAmplitude * fh;int nh = floor(fh);if (nh < 0 || nh > dst.rows - 1)nh = h;for (int w = 0; w < dst.cols; w ++) {double fw  = 1.0 * (w % xWavelength) / xWavelength;fw = w + xAmplitude * fw;int nw = floor(fw);if (nw < 0 || nw > dst.cols - 1)nw = w;dst.at<Vec3b>(h, w)[0] = src.at<Vec3b>(nh, nw)[0];dst.at<Vec3b>(h, w)[1] = src.at<Vec3b>(nh, nw)[1];dst.at<Vec3b>(h, w)[2] = src.at<Vec3b>(nh, nw)[2];}}
}

源图像:

 当amplitude=50,wavelength = 50时的效果:

 

http://www.lryc.cn/news/143971.html

相关文章:

  • 【分布式技术专题】「OSS中间件系列」Minio的文件服务的存储模型及整合Java客户端访问的实战指南
  • 构建个人博客_Obsidian_github.io_hexo
  • 烟花厂人员作业释放静电行为检测算法
  • ARTS挑战第二周-T:PHP数组相关操作
  • 【如何对公司网络进行限速?一个案例详解】
  • 服务器安全-修改默认ssh端口
  • 保护隐私的第一步:从更新浏览器开始
  • Python爬虫框架之快速抓取互联网数据详解
  • 【算法专题突破】双指针 - 盛最多水的容器(4)
  • 循环神经网络(RNN) | 项目还不成熟 |还在初级阶段
  • 【Spring Boot】数据库持久层框架MyBatis — MyBatis简介
  • K8S Nginx Ingress实现金丝雀发布
  • 【C++入门】new和delete(C/C++内存管理)
  • C++设计模式之桥接模式
  • 前端速查速记系列----评论列表
  • hiredis的安装与使用
  • 【InsCode】InsCode打造的JavaSE与Linux命令互融的伪Linux文件系统小项目
  • “深入解析JVM:探索Java虚拟机的内部机制“
  • 内网远程控制总结
  • Excel显示此值与此单元格定义的数据验证限制不匹配怎么办?
  • mysql(八)事务隔离级别及加锁流程详解
  • 华为云Stack的学习(二)
  • 好用的网页制作工具就是这6个,快点来看!
  • 一文讲通物联网嵌入式
  • Unity3D Pico VR 手势识别 二
  • ubuntu中使用iptables限制端口
  • Orchestrator介绍二 自身高可用性方案
  • 成集云 | 旺店通多包裹数据同步钉钉 | 解决方案
  • 什么是字体图标(Icon Font)?如何在网页中使用字体图标?
  • Blender文件云端GPU渲染