- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
当我尝试使用 Visual Studio 2008
运行查找方 block 代码时,出现以下错误。
1>ANPR.obj : error LNK2001: unresolved external symbol "public: virtual class cv::GlBuffer __thiscall cv::_InputArray::getGlBuffer(void)const " (?getGlBuffer@_InputArray@cv@@UBE?AVGlBuffer@2@XZ)
1>ANPR.obj : error LNK2001: unresolved external symbol "public: virtual class cv::GlTexture __thiscall cv::_InputArray::getGlTexture(void)const " (?getGlTexture@_InputArray@cv@@UBE?AVGlTexture@2@XZ)
1>ANPR.obj : error LNK2001: unresolved external symbol "public: virtual class cv::gpu::GpuMat __thiscall cv::_InputArray::getGpuMat(void)const " (?getGpuMat@_InputArray@cv@@UBE?AVGpuMat@gpu@2@XZ)
代码:
#include <cv.h>
#include <highgui.h>
using namespace cv;
double angle( cv::Point pt1, cv::Point pt2, cv::Point pt0 )
{
double dx1 = pt1.x - pt0.x;
double dy1 = pt1.y - pt0.y;
double dx2 = pt2.x - pt0.x;
double dy2 = pt2.y - pt0.y;
return (dx1*dx2 + dy1*dy2)/sqrt((dx1*dx1 + dy1*dy1)*(dx2*dx2 + dy2*dy2) + 1e-10);
}
void find_squares(Mat& image, vector<vector<Point> >& squares)
{
// blur will enhance edge detection
Mat blurred(image);
medianBlur(image, blurred, 9);
Mat gray0(blurred.size(), CV_8U), gray;
vector<vector<Point> > contours;
// find squares in every color plane of the image
for (int c = 0; c < 3; c++)
{
int ch[] = {c, 0};
mixChannels(&blurred, 1, &gray0, 1, ch, 1);
// try several threshold levels
const int threshold_level = 2;
for (int l = 0; l < threshold_level; l++)
{
// Use Canny instead of zero threshold level!
// Canny helps to catch squares with gradient shading
if (l == 0)
{
Canny(gray0, gray, 10, 20, 3); //
// Dilate helps to remove potential holes between edge segments
dilate(gray, gray, Mat(), Point(-1,-1));
}
else
{
gray = gray0 >= (l+1) * 255 / threshold_level;
}
// Find contours and store them in a list
findContours(gray, contours, CV_RETR_LIST, CV_CHAIN_APPROX_SIMPLE);
// Test contours
vector<Point> approx;
for (size_t i = 0; i < contours.size(); i++)
{
// approximate contour with accuracy proportional
// to the contour perimeter
approxPolyDP(Mat(contours[i]), approx, arcLength(Mat(contours[i]), true)*0.02, true);
// Note: absolute value of an area is used because
// area may be positive or negative - in accordance with the
// contour orientation
if (approx.size() == 4 &&
fabs(contourArea(Mat(approx))) > 1000 &&
isContourConvex(Mat(approx)))
{
double maxCosine = 0;
for (int j = 2; j < 5; j++)
{
double cosine = fabs(angle(approx[j%4], approx[j-2], approx[j-1]));
maxCosine = MAX(maxCosine, cosine);
}
if (maxCosine < 0.3)
squares.push_back(approx);
}
}
}
}
}
int main()
{
Mat img = imread("peppers.jpg");
cvtColor(img, img, CV_RGB2GRAY);
vector<vector<Point> > squares;
find_squares(img, squares);
std::cout << "squares size: " << squares.size() << std::endl;
getchar();
return 0;
}
有人可以帮我解决这个问题吗?我尝试了 openCV 2.4.2。它给出了相同的链接错误。谢谢
最佳答案
这些错误与链接过程有关,您提到的符号属于 opencv_core 库。
确保您已将此库添加为项目的依赖项。转到配置属性> 链接器> 输入并添加:opencv_core242.lib
有关如何配置 Visual Studio 和 OpenCV 的更多说明,check this thread .
关于c++ - openCV 2.3.1 findContours函数链接错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14507362/
我刚开始学习 Emgu 和 OpenCV。所以这可能是一个愚蠢的问题。当我查看 Emgu 文档(参见链接 http://www.emgu.com/wiki/files/3.1.0/document/h
我在以下代码查找轮廓的运行时遇到段错误。我提到了this在此表格上发帖,但对我帮助不大。我知道 findContours 有一些问题这是 findContours 的另一期.请检查这两个链接并帮助我解
我正在使用这样的函数; Mat large = imread(path+name); Mat rgb; if (large.rows > 2500 || large.cols > 1250) {
我正在尝试检测一个球并为其划定边界。显示错误 segmentation fault (core dumped) 错误就在这里, vector > contours; vector hierar
我想使用 haar cascade 来计算汽车数量。 #import libraries of python opencv import numpy as np import cv2 import g
我正在使用 Android OpenCV。我有一个方形标记图像。我必须找出实时提要中标记的四个角的位置及其索引的位置。我能够在帧大小为 640*480 的实时馈送中获得这四个点的位置。但是索引位置的问
我写了一段代码,在单 channel 空白图像中绘制圆、线和矩形。在那之后,我只是找出图像中的轮廓,并且我正确地得到了所有轮廓。但是在找到轮廓后,我的源图像变得扭曲了。为什么会这样?任何人都可以帮助我
我们正在使用 opencv for android 实现 OCR,一切都很顺利,直到使用 Imgproc.findcontours() 查找轮廓的部分它返回的轮廓与输入图像中的顺序不同IE :输入图像
这个问题在这里已经有了答案: What is the algorithm that opencv uses for finding contours? (2 个答案) 关闭 7 年前。 OpenCV
我有下面的图片,并尝试用这些线找到最大的 OpenCV 矩形 std::vector > contours; cv::findContours(result,contours,CV_RETR_LIST
我是 C++ 和 opencv 的新手。我写了一个简单的程序,您可以在下面找到它,但是当我运行它时,我总是会抛出异常 findContours(img, ctr, CV_RETR_LIST, CV_C
我尝试在二进制图像中找到轮廓,但是当尝试执行cvFindContours时,它给了我该错误消息 Traceback (most recent call last): File "convert.py"
我正在尝试实现一个在二进制图像中找到轮廓并过滤掉小轮廓的函数。 这是我的代码和示例图像。这是一个 super 简单的功能,可以去除小面积的 Blob 。但我不断得到“边缘轮廓”而不是区域轮廓。 :S
我遇到了一个奇怪的行为,虽然我可以解决它,但我想知道这是为什么。 当我使用 cv2.findContours 时,它会修改原始图像,即使我没有将它传递给函数。这是一个可以找到图片的最小示例here .
我想问如何在 blob(findcontours)上检测人类或行人?我尝试学习如何使用 findcontours() 来检测框架上的任何对象,如下所示: #include"stdafx.h" #inc
提供一些上下文: 我正在尝试获取这张图片中的盒子数量, 我上面的图像存储在ndarray blank_img中。 如果我运行以下命令: v = np.median(blank_img) sigma =
Cow browncow; vector Cows; Mat temp; threshold.copyTo(temp); vector > contours; vector hierarchy; f
我试过 findContours 有 2 张图片。实际上,它们是一体的。一个是彩色图像(jpg),另一个是由 MS Paint 从颜色创建的(导出为单色图像 - bmp): #include "cv.
我是opencv和Java的初学者。我想学习Imgproc.findContours()方法的用法和功能。我没有任何资料可以学习。谁能详细解释一下它的工作原理。或有人可以建议我作为学习它的合适资源。
当我们想根据某个阈值查找给定图像的轮廓时,我们使用cv2.findContours()函数,该函数除其他外返回轮廓列表(表示图片轮廓的数组的Pythonic列表)。 这是use of the func
我是一名优秀的程序员,十分优秀!