- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在编写一个小型图像分析程序,只是为了好玩。图像分析一直让我着迷。我正在尝试在扫描文档上定位区域。这些区域将由明确定义的黑色实心矩形(预先打印在页面上)标记。
我的问题是定位矩形。我知道 SIFT\SURF 找到“特征”,但我正在尝试寻找特定的东西。这就是我想做的。我不确定这是“正确”的方式还是有更好的主意。
首先使用一些库,我会将图像变成灰度,也许是 PGM,因为这是我在学校习惯使用的。对于分析,我首先计划通过 OpenCV 中最先进的去歪斜算法或我发现的其他算法来运行图像。一旦我得到了校正后的图像,我就会将它设置在某个相当高的阈值处。矩形将是纯黑色的,因此我使用了相当高的阈值。然后,我将通过实验确定一个大小合适的黑色矩形以在图像上滑动。在图像上滑动我的矩形时,我将确定最大百分比像素相同的区域。我会有一个截止点,比如说 90%。如果我的窗口中 90% 的像素都是黑色的,那么我一定找到了一个矩形。我的推理是,一个真正的黑色矩形滑过“几乎”黑色矩形的东西很可能是黑色矩形。由于我对图像进行了校正,因此我可以假设矩形“足够”垂直上下。然后我可以跟踪在图像上找到矩形的 (x,y) 偏移量并标记它们。
有人会建议更好的方法吗?
最佳答案
有许多可能有效的方法。 (一个人可以很容易地想出 10 种或更多的方法。)
cv::minAreaRect , 或
cv::boundingRect也可能有效,如果去歪斜像宣传的那样有效。
这个想法是基于这样的假设,即黑色矩形足够大,以至于它们在水平和垂直投影剖面上都留下了“凹陷”,尽管图像中有其他噪声对象,但仍可以检测到。
dim
= 0 或 1 分别缩减为一行或一列,申请 cv::threshold分别到水平和垂直投影剖面。
对于现在阈值为零/非零的每个配置文件,找到零的游程。这些是可能包含深色矩形的行范围和列范围。
对于每个候选行范围和列范围的组合,计算平均像素值来判断它是否是一个真正的暗矩形。
关于image - 在图像上定位 "black rectangles"- 与语言无关,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22901391/
当我调用 png.Decode(imageFile) 时,它返回类型 image.Image。但我找不到将其转换为 image.NRGBA 或 image.RGBA 的记录方式,我可以在其上调用 At
image/jpeg 和 image/png 包有 Decode 和 Encode 函数,可以读取和写入 jpeg 和 png 图像,但 image/gif 包没有 - 只有 Decode 和 Dec
我正在尝试从一系列任意的非调色板图像创建动画 GIF。为了创建调色板图像,我需要以某种方式想出一个调色板。 // RGBA, etc. images from somewhere else var f
我在今年夏天的空闲时间使用 Go 镜像包进行一些练习。 package main import ( "os" "image" "image/png" "image/co
关闭。这个问题需要debugging details .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 1年前关闭。 Improve this question 今天
我正在尝试在 TilePane 中列出图像。当我尝试创建图像 new ImageView("address"); 时出现错误,地址如下: "file:D:/Chrysanthemum.jpeg/" 以
我有一个用于为画廊选择图像的表单,我希望允许用户仅选择 jpg、gif 和 png 图像格式。 现在,为了测试,我将图像的扩展名更改为 .bmp,例如“image1.bmp”,当我在输入文件中单击以选
我有创建图像的代码:(m_img 是 javafx.scene.image.Image) Image m_img = new Image("file:" + p_Fil.getAbsoluteFile
假设我有一个这样的 8 位灰度图像: var pixels []byte = ... width := 100 height := 100 如何将其转换为实现 image.Image 的东西? 最佳答
这段代码是我在localhost:8088 URL上的索引/主页的一部分,如果我想将用户发送到url localhost:8088/image/1,我应该写href='image/{{$image->
我正在尝试对图像进行简单的裁剪。这是代码 from PIL.Image import Image def get_image_half(image, half="upper"): if hal
我在这个问题上花了一整天,但在堆栈溢出中没有看到答案! 我试过了但是没用: >> pil_image = Image.frombytes('RGBA', wand_image.size, wa
所以,我是那些以始终使用最新版本的浏览器而自豪的人之一(当然 Internet Explorer 除外 - 我说的不是那个浏览器)。 我遇到了 this awesome CSS3 website详细介
如果 image_tag 无法从 url 加载图像,我想呈现默认图像: 因此,如果 image_tag 无法从 url 加载图像: 然后呈现默认值: 这将生成结果 HTML: 关于image -
我正在创建一个类似横幅的组件,并将图像设置为组件的背景,但我无法让它工作。我尝试了网上发布的不同建议,但没有成功,目前我不确定我的错误是否在 react 代码中,或者是 webpack 没有正确加载文
如何解决 Dart 中的这种歧义错误。 import 'dart:io'; import 'package:flutter/material.dart'; import 'package:camera
Center( child: CachedNetworkImage( imageUrl: "http:/ sosme link he
设置 www.website.com/sds/(index.htm) 以便鼠标悬停在不同位置时显示图像。 出于某种原因,当您将鼠标悬停在蓝色气球上时,图像 2.jpg 和 3.jpg(在蓝色气球上来回
社交网络在共享 URL 时可以很好地从网站中提取标题和描述,但对于图像,仍然需要创建自定义元标记:property="og:image" name="twitter:image" itemprop="
我正在尝试写一个简短的,它将读取一个 PNG 文件,并将一个 channel 与另一个 channel (R,G,B) 交换作为可能的选择。 但是,我无法找到如何从 image.At(x,y) 返回的
我是一名优秀的程序员,十分优秀!