- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我想在下图中(以及其他一些类似的图像)中分别检测红色和绿色圆圈
我正在使用 opencv 和 python。
我试过使用 houghcircles,但即使在更改参数后也没有任何帮助。
任何关于如何做到这一点的建议都会有很大帮助。如果有人发送代码,我将不胜感激
最佳答案
您在评论中提到圆圈的大小始终相同。让我们利用这个事实。我的代码片段是用 C++ 语言编写的,但这应该不是问题,因为它们只是在这里显示要使用哪些 OpenCV 函数(以及如何使用)...
TL; DR 这样做:
现在,让我们开始吧!
第 1 步 - 模板图像
您需要一张显示与背景明显分开的圆圈的图片。您有两个选择(两者都同样好):
圆圈可以是任何颜色 - 唯一重要的是它与背景不同。
第 2 步 - 模板匹配
加载图像和模板图像并将它们转换为HSV color space .然后拆分 channel ,以便您只能使用饱和 channel :
using namespace std;
using namespace cv;
Mat im_rgb = imread("circles.jpg");
Mat tm_rgb = imread("template.jpg");
Mat im_hsv, tm_hsv;
cvtColor(im_rgb, im_hsv, CV_RGB2HSV);
cvtColor(tm_rgb, tm_hsv, CV_RGB2HSV);
vector<Mat> im_channels, tm_channels;
split(im_hsv, im_channels);
split(tm_hsv, tm_channels);
这就是圆圈和模板现在的样子:
接下来,您必须获取包含有关圆形边框 信息的图像。无论您如何实现这一点,您都必须对图像和模板饱和度 channel 应用完全相同的操作。我使用 sobel 运算符来完成工作。代码示例只展示了我对图像饱和 channel 所做的操作;模板饱和 channel 经历了完全相同的过程:
Mat im_f;
im_channels[1].convertTo(im_f, CV_32FC1);
GaussianBlur(im_f, im_f, Size(3, 3), 1, 1);
Mat sx, sy;
Sobel(im_f, sx, -1, 1, 0);
Sobel(im_f, sy, -1, 0, 1);
Mat image_input = abs(sx) + abs(sy);
现在,执行模板匹配。我建议您选择计算归一化相关系数的模板匹配类型:
Mat match_result;
matchTemplate(image_input, template_input, match_result, CV_TM_CCOEFF_NORMED);
这是模板匹配结果:
如果您将模板放在图像上的不同位置,此图像会告诉您模板与底层图像的关联程度。例如,像素 (0,0) 处的结果值对应于输入图像上位于 (0,0) 处的模板。
当模板放置在与底层图像匹配良好的位置时,相关系数很高。使用阈值方法丢弃信号峰值以外的所有内容(模板匹配的值将位于 [-1, 1] 区间内,您只对接近 1 的值感兴趣):
Mat thresholded;
threshold(match_result, thresholded, 0.8, 1.0, CV_THRESH_BINARY);
接下来,确定每个隔离区域内模板结果最大值的位置。为此,我建议您使用阈值图像作为 mask 。每个区域内只需要选择一个最大值。
这些位置告诉您必须将模板放置在哪里,以便它与圆圈最匹配。我绘制了从这些点开始并与模板图像具有相同宽度/高度的矩形:
第三步:圆圈的颜色
现在您知道模板应该放置在哪里,以便它们很好地覆盖圆圈。但是您仍然需要找出圆心在模板图像上的位置。您可以通过计算模板饱和 channel 的质心来做到这一点:
在图像上,圆心位于这些点:
Point circ_center_on_image = template_position + circ_center_on_template;
现在您只需检查这些点的红色 channel 强度是否大于绿色 channel 强度。如果是,则圆圈为红色,否则为绿色:
关于python - 检测红色和绿色圆圈,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42315959/
我需要移动一个对象,在我的例子中是给定路径上的一个字符串。实际上路径可以是半圆。如附图所示,字符串应该出现在另一个物体的后面,沿着路径移动并消失在第二个物体(两个图像)后面。我不知道如何开始...希望
我需要构建一个圆形(在 css 中),它有 2 行文本,可以根据选择的翻译改变长度并始终居中。 到目前为止我有这个: h3 { background-color: #fcd141; borde
是否可以在 CSS3 中使用 -webkit-border-radius 绘制一个圆,同时将宽度和高度限制为特定变量(例如 height:100px 和 width:100px) 所以当在圆圈内添加文
我正在尝试在方形图像上叠加一个圆圈。文本需要在圆圈中水平和垂直居中。 我几乎用正方形 div 做对了,但是一旦我将图像放入组合中,圆圈就会移动到图像下方。 我的代码。 .Container { w
使用 CSS,我有一个将图标放置在圆圈/圆盘中的显示。 这是我的例子: 但我很难将图标放在圆圈/圆盘的中心。 我已经搜索过 SO(找到 this post 但更改行高只会扩展圆盘/圆圈)和 Googl
我正在尝试在一行中制作几个带有文本的 css 圆圈。当我使用 circle 类来 img 时,圆圈是内联的,但我无法添加任何文本。当我使用 circle class 到 div 时,我可以添加文本,但
我尝试在单击“提交”按钮时显示 ProgessBar。它会在数据加载完成时隐藏。但是,progressBar 没有覆盖整个屏幕。相反,它被按钮覆盖。请引用屏幕截图,它应该更容易理解我的意思。 我要实现
这个问题在这里已经有了答案: Circle with two borders (4 个答案) 关闭 7 年前。 我有一个只有一个边框的圆圈,但我想知道是否有办法实现一个有两个不同颜色边框的圆圈。我有
我正尝试按照以下示例在 CSS 中创建一个带有镶嵌边框的圆圈: 我有以下 HTML 和 CSS,但它没有产生我需要的效果: .inlay-circle { width: 15rem; heig
我找到的每个指南都有相同的线条和填充颜色。我想要的只是一个带有红线和白色填充的圆圈。 我试过: .circle { border: red; background-color: #FF
我正在寻找一种用纯色和图像填充 SVG 圆圈的方法。 我现在尝试的是使用这段代码: 它用我的背景图片绘制
我目前正在组建一个将托管用户的网站。每个用户都会有一个个人资料页面,该页面将显示 SVG 圆数组,每个用户在数据库的用户表中自己的行中也有一个相应的 SVG_number。 例如,如果 User1 在
我正在尝试在 SVG 中创建三组圆圈。我给他们打电话circleA circleB和circleC我打算给它们涂上不同的颜色。 var circleA = [ [50,48],[106,35]
使用 snapsvg.io,我想知道是否可以添加可点击的链接,例如 My Link标记到 SVG 文本、圆圈或线条。 我这里的一个例子是文本: var s = Snap("#svg"); var te
所以这是我的一个小项目,只是为了好玩。我尝试使用 libgdx 在 Java 中重新创建随机 Walker。 现在我认为我的代码非常成功,因为它工作正常(也许)。 但是有一个问题,圆比其他轴更倾向于向
我想在 CSS 中创建一个在右边和底部有线条的圆。类似下图。我找到了一个 css code水平连接圆圈。我不知道如何垂直添加线条或类似于我附加的图像?
以下圆形标签位于标签内: 现在我必须将生成的圆圈附加到标签内,例如 更新: function createCircle(a) { var circle = document.
我希望圆圈类似于饼图,具有相同的不同颜色切片。出于某种原因,我画了一个圆,在带有颜色的一侧有弧形,中间有一个白色八边形。 for(var i=0;i<8;i++){ ctx.beginPath
我有一个场景,我必须在样条图中创建标记/圆圈。我使用 highcharts 创建了样条图表,图表的代码如下。 我的输出应该如下所示。我已经在图像中标记了预期的圆圈: $(function ()
给定以下示例: 是否有可能检测到网络中的环路 (I1, I2,I3, C6, C7, I5)? 我试过:simple_cycles → 它适用于 3 个节点,但不能超过 3 个。 我需要检测包含所有节
我是一名优秀的程序员,十分优秀!