C#描述-计算机视觉OpenCV(3):重映射

C#描述-计算机视觉OpenCV(3):重映射

    • 前言
    • 色彩波形
    • 图像重映射

前言

C#描述-计算机视觉OpenCV(1):基础操作
C#描述-计算机视觉OpenCV(2):图像处理
在前文中,描述了如何对像素和图像进行基本的运算与处理,结合图像的原理,我们已经可以做出很多操作了。这里我们先做一个热身,如何将一张胶卷的负片转换为正片。
胶卷作为一种古早的记录图像的工具,有正负两种格式,正片与我们肉眼所见色彩一致。那么负片,也就是我们印象中最常见到的胶片,看起来明暗是相反的,其色彩为被摄体的补色,其中,负片的负的含义,就是RGB码取了余数。
知道了原理,我们就可以很轻松的来写一个扫描负片的方法:

int r = img.Rows;
int c = img.Cols;
Cv2.ImShow("win0", img);
for (int i = 0; i < r; i++)for (int j = 0; j < c; j++){img.At<Vec3b>(i, j)[0] = (byte)(255-img.At<Vec3b>(i, j)[0]);img.At<Vec3b>(i, j)[1] = (byte)(255-img.At<Vec3b>(i, j)[1]);img.At<Vec3b>(i, j)[2] = (byte)(255-img.At<Vec3b>(i, j)[2]);}
Cv2.ImShow("win1", img);

在这里插入图片描述
结果如图,这就是我们现实中扫描前与扫描后的胶卷底片的差异。学习OpenCV不只是要去机械的学习算法与代码,要结合实际的运用,才能具象的理解算法的原理与作用。

色彩波形

对于一个图案内部的色彩变化,我们可以借助取出行列的RGB波形来研究:
先去定义一个Chart与加载一套list(一式三份,对应RGB),再输出

for (int j = 0; j < Max; j++){int r = 50;//对(50,j)进行扫描读取string str;str = Convert.ToString(j) + ":" + Convert.ToString(img.At<Vec3b>(50, j)[0]) + "/ " + Convert.ToString(img.At<Vec3b>(50, j)[1]) + "/ " + Convert.ToString(img.At<Vec3b>(50, j)[2]);textBox1.Text += str + "\r\n";XList1.Add(j);YList1.Add(img.At<Vec3b>(r, j)[1]);chart1.Series["Green"].Points.DataBindXY(XList1, YList1);XList2.Add(j);YList2.Add(img.At<Vec3b>(r, j)[2]);chart1.Series["Blue"].Points.DataBindXY(XList2, YList2);XList.Add(j);YList.Add(img.At<Vec3b>(r, j)[0]);chart1.Series["Red"].Points.DataBindXY(XList, YList);}

效果:
在这里插入图片描述
当我们分析渐变色区域的时候,我们可以借助这个方法来分析图像的色彩区间。

图像重映射

重映射是通过移动像素修改图像的外观。这个过程不会修改像素值,而是把每个像素的位置重新映射到新的位置。那么其实我们常用的图像翻转也是重映射的方法,同时我们还可以用这个方法来制作特效与扭曲图像。
重映射运用到的方法是Remap,
remap(image, // 源图像
result, // 目标图像
srcX, // x 映射
srcY, // y 映射
cv::INTER_LINEAR); // 填补方法
}
无论什么语言下的OpenCv都可以调用这个方法,参数也是一样的。
其中,img为待修改Mat原图,result为结果保存到的Mat图片,srcX和Y是映射Mat矩阵,填补方法是像素插值法,可以重载暂时不管。
那么我们来声明三组参数:

Mat res;
Mat srcX;
Mat srcY;
res=new Mat(image.Rows,image.Cols, image.Type());
srcX = new Mat(image.Rows, image.Cols, MatType.CV_32F);
srcY = new Mat(image.Rows, image.Cols, MatType.CV_32F);

其中,MatType.CV_32F是Mat的数据类型,对应着占32位的float。
然后我们需要写一个循环,来布置映射矩阵,以实现图像的翻转:

for (int i = 0; i < image.Rows; i++){for (int j = 0; j < image.Cols; j++){// (i,j)像素的新位置srcX.At<float>(j, i) = i;                        // 行不变(X不变)srcY.At<float>(j, i) = image.Rows-j;      // 列翻转(Y翻转不变)}}

映射矩阵的作用是告诉remap像素移动的方式或者说位置,可以说,映射的算法都由映射矩阵来实现。写完映射矩阵,我们就可以直接调用Cv2.Remap()了。
再例如,我们对图像做一个波浪形映射,运用三角函数来运算映射矩阵:
效果图:
在这里插入图片描述
完整代码:

 public void test(Mat image){Mat res;Mat srcX;Mat srcY;res=new Mat(image.Rows,image.Cols, image.Type());srcX = new Mat(image.Rows, image.Cols, MatType.CV_32F);srcY = new Mat(image.Rows, image.Cols, MatType.CV_32F);for (int i = 0; i < image.Rows; i++){for (int j = 0; j < image.Cols; j++){// (i,j)像素的新位置srcX.At<float>(i,j) = j;//j; // 保持在同一列// 原来在第 i 行的像素,现在根据一个正弦曲线移动srcY.At<float>(i, j) = i + 5 * (float)(Math.Sin(j / 10.0));}}Cv2.Remap(image, res, srcX, srcY);Cv2.ImShow("win1", res);Cv2.ImShow("win0", image);}

在这其中,sin控制了扭曲的波形,x*sin为波形的幅度
2倍正弦波:
在这里插入图片描述
6倍正弦波:
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/1410407.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

【跟马少平老师学AI】-【神经网络是怎么实现的】(四)卷积神经网络

一句话归纳&#xff1a; 1&#xff09;用1个小粒度的模式&#xff0c;逐个与图像的局部区域进行运算&#xff0c;运算结果反映模式与区域的匹配程度。 2&#xff09;卷积神经网络与全连接神经网络的区别&#xff1a; 卷积神经网络的输出只与局部输入有连接。参数较少&#xff0…

如何将手机投屏到mac电脑

1、将iphone手机和mac电脑连接到同一个网络 2、点击电脑上的QuickTime Player 3、点击之后&#xff0c;这个QuickTime Player的进程就开启了 4、鼠标点到这个上面&#xff0c;然后右击&#xff0c;选择新建影片录制 5、点击这个按钮后&#xff0c;来到这个界面&#xff0c;点击…

汉王科技亮相世界数字健康论坛:以AI定义第四代血压计

作为科技行业的年度盛会&#xff0c;2024年中关村论坛年会于近日在北京揭幕。 作为中关村知名的人工智能企业&#xff0c;汉王科技携大模型的最新垂直应用、柯氏音法电子血压计等创新成果&#xff0c;在4月29日中关村论坛平行论坛“2024世界数字健康论坛”上亮相。 在《AI赋能血…

jupyter notebook使用与本地位置设置

本地安装好Anaconda之后&#xff0c;自带的有Jupter notebook。 使用jupyter notebook 使用jupyter notebook时&#xff0c;可以直接打开或者搜索打开&#xff1a; 打开后&#xff0c;我们生成的或者编辑的一些文件&#xff0c;都可以看到&#xff0c;如下&#xff1a; j…

UDP_INTRODUCTION_03:介绍 - 挂起的监听调用

测试目的&#xff1a; 验证当数据报到达一个没有挂起监听&#xff08;LISTEN&#xff09;调用的UDP端口时&#xff0c;UDP是否应该发送ICMP端口不可达&#xff08;Port Unreachable&#xff09;消息。 描述&#xff1a; 本测试用例旨在确保当数据报发送到DUT上一个未被监听的…

如何基于nginx组建多个子目录网站

华子目录 实验要求实验步骤 实验要求 组建多个子目录网站www.openlab.com&#xff0c;该网站有2个子目录www.openlab.com/sxhkt和www.openlab.com/zywww.openlab.com/sxhkt使用http读取www.openlab.com/zy使用https读取 实验步骤 准备工作 [rootserver ~]# setenforce 0[ro…

PC通过串口发送指令控制LED+串口中断

如何让单片机接收数据&#xff1f; 首先要打开SCON中的串行接收控制位REN。当REN1时为允许接收状态&#xff0c;可以接收信息。 因此令SCON 0x50&#xff1b; 怎么知道收到数据&#xff1f; 利用RI接收中断请求标志位。当串行接收到第8位结束时由内部硬件自动置为RI1&#…

Python与OpenCV:图像处理与计算机视觉实战指南

前言 OpenCV&#xff08;Open Source Computer Vision Library&#xff09;是一个开源的计算机视觉和机器学习软件库&#xff0c;它包含了数百种计算机视觉算法&#xff0c;包括图像处理、视频分析、物体检测、面部识别等。结合Python语言的强大功能&#xff0c;OpenCV可以用于…

【哈希】Leetcode 面试题 01.02. 判定是否互为字符重排

题目讲解 面试题 01.02. 判定是否互为字符重排 算法讲解 直观的想法&#xff1a;我们找到一个字符串的全排列&#xff0c;然后对比当前的排列是否等于另一个字符串。如果两个字符串如果互为排列&#xff0c;所以我们知道两个字符串对应的字符出现的个数相同&#xff0c;那么…

【Linux—进程间通信】共享内存的原理、创建及使用

什么是共享内存 共享内存是一种计算机编程中的技术&#xff0c;它允许多个进程访问同一块内存区域&#xff0c;以此作为进程间通信&#xff08;IPC, Inter-Process Communication&#xff09;的一种方式。这种方式相对于管道、套接字等通信手段&#xff0c;具有更高的效率&…

<2024年5月软考高项极限冲刺>《2 考试知识块》

&#x1fab8;&#x1fab8;把你所学串起来&#xff0c;欢迎订阅。&#x1fab8;&#x1fab8; 每章附独家脑图&#xff0c;原图。 冲刺 冲刺 冲刺 1 看下面的图&#xff0c;让你知道你要学习的全部知识是什么 2 章节解析 我们考试的重点是项目管理知识&#xff0c;但是因…

Python零基础-上【详细】

目录 一、Python简介 1、Python发展史 2、Python理解 3、Python的优缺点 &#xff08;1&#xff09;优点 &#xff08;2&#xff09;缺点 二、Python开发环境搭建 1、环境搭建 2、尝试写一个基础程序 &#xff08;1&#xff09;调整配置 &#xff08;2&#xff09;新…

sunshine+n2n+moonlight串流远程控制全教程

远程主机说明&#xff08;两台电脑不在同一局域网下&#xff09;&#xff1a; 控制台电脑 被控制电脑 所有工具下载地址&#xff1a;https://www.lanzouw.com/b00eepod7e 密码:1234 一、首先NTN组网 使用NTN技术创建虚拟局域网&#xff0c;实现设备之间的P2P连接。 NTN组网…

【IO操作】标准IO和文件IO

一.标准IO和文件IO的区别 &#xff08;1&#xff09;一般标准IO指的是C语言的IO操作&#xff0c;文件IO一般指的是Linux系统调用的IO操作。标准O因为是C语言提供的标准库&#xff0c;所以可以在其他操作系统平台编译后可以执行&#xff0c;但是文件IO只能在Linux下使用&#x…

设计编程网站集:真空成型工艺+真空成型机DIY

真空成型工艺 真空成型工艺是一种广泛应用于制造领域的工艺&#xff0c;主要用于制造复杂形状的塑料制品。真空成型工艺具有成本低、生产效率高、制品质量稳定等优点&#xff0c;因此在汽车、电子、医疗器械等行业得到广泛应用&#xff08;还可以用来制作面具&#xff0c;哈哈哈…

满上! —— 十年之约#22(ROI 48%)

原创 | 刘教链 空头在忍耐了很久之后&#xff0c;趁五一劳动节东方放假发动突袭&#xff0c;把BTC&#xff08;比特币&#xff09;打到6万刀以下。这使得我们终于终结了7个月七连涨的趋势&#xff0c;确定4月以收跌结束。 4月开盘70k&#xff0c;最高72.8k&#xff0c;最低59.6…

[随记]Mac安装Docker及运行开源Penpot

下载Docker Desktop for Mac&#xff1a;https://www.docker.com/products/docker-desktop/ 安装Docker Desktop for Mac&#xff0c;安装完成后&#xff0c;启动Docker&#xff0c;然后在终端输入&#xff1a; docker version 在Mac电脑的Desktop&#xff0c;随便创建一个文…

springBootAdmin监控

简介 用于对 Spring Boot 应用的管理和监控。可以用来监控服务是否健康、是否在线、以及一些jvm数据等等 Spring Boot Admin 分为服务端(spring-boot-admin-server)和客户端(spring-boot-admin-client)&#xff0c;服务端和客户端之间采用 http 通讯方式实现数据交互&#xf…

Java中使用Redis实现分布式锁的三种方式

1. 导语 随着软件开发领域的不断演进,并发性已经成为一个至关重要的方面,特别是在资源跨多个进程共享的分布式系统中。 在Java中,管理并发性对于确保数据一致性和防止竞态条件至关重要。 Redis作为一个强大的内存数据存储,为在Java应用程序中实现分布式锁提供了一种高效的…

LeetCode-网络延迟时间(Dijkstra算法)

每日一题 今天刷到一道有关的图的题&#xff0c;需要求单源最短路径&#xff0c;因此使用Dijkstra算法。 题目要求 有 n 个网络节点&#xff0c;标记为 1 到 n。 给你一个列表 times&#xff0c;表示信号经过 有向 边的传递时间。 times[i] (ui, vi, wi)&#xff0c;其中 …