python - 查找图像上的特定点

标签 python image opencv

我正在尝试编写一个程序来解决一个难题。我的尝试适用于我测试的示例拼图。现在我正在尝试制作一个真正的拼图。 这个新拼图的拼图 block 并没有真正正确的形状。

puzzle piece

我设法将图像变成黑白,最后变成 1 和 0 的数组,其中 1 表示作品,0 表示背景。我想找到一种方法来识别这些碎片的 4 个角、峰和深度的坐标。

points

我试图计算 1 附近 0 的数量,以查看边界中的最大曲线。但是形状不够光滑,无法正常工作。

counter = np.zeros((lenX,lenY),dtype=int)
for i in range(lenX):
    for j in range(lenY):
        if img[i,j]==1:
            counter[i,j] = count_white(img,i,j,lenX,lenY)

print(counter)
tpath = os.getcwd()+"/test.jpg"
print(cv2.imwrite(tpath, Image))
print("saved at : ",tpath)
np.savetxt("test.csv", counter, delimiter=",")

def count_white(img,x,y,lenX,lenY):
    X = [x-1,x,x+1,x+1,x+1,x,x-1,x-1]
    Y = [y-1,y-1,y-1,y,y+1,y+1,y+1,y]
    count = 0
    for i in range(len(X)):
        if X[i] < lenX and Y[i] < lenY:
            if img[X[i],Y[i]] == 0:
                count=count+1
    return count

有什么建议、引用或想法吗?

最佳答案

抱歉 C++ 代码,但它适用于您的情况:

cv::Mat gray = cv::imread("Sq01a.png", cv::IMREAD_GRAYSCALE);

gray = 255 - gray;


cv::Mat bin;
cv::threshold(gray, bin, 1, 255, cv::THRESH_BINARY);

cv::Mat bigBin(2 * bin.rows, 2 * bin.cols, CV_8UC1, cv::Scalar(0));
bin.copyTo(cv::Mat(bigBin, cv::Rect(bin.cols / 2, bin.rows / 2, bin.cols, bin.rows)));


std::vector<std::vector<cv::Point> > contours;
cv::findContours(bigBin, contours, cv::RETR_EXTERNAL, cv::CHAIN_APPROX_NONE);

if (contours.size() > 0)
{
    std::vector<cv::Point> tmp = contours[0];
    const cv::Point* elementPoints[1] = { &tmp[0] };
    int numberOfPoints = (int)tmp.size();
    cv::fillPoly(bigBin, elementPoints, &numberOfPoints, 1, cv::Scalar(255, 255, 255), 8);
}

int maxCorners = 20;
double qualityLevel = 0.01;
double minDistance = bigBin.cols / 8;
int blockSize = 5;
bool useHarrisDetector = true;
double k = 0.04;
std::vector<cv::Point2f> corners;
cv::goodFeaturesToTrack(bigBin, corners, maxCorners, qualityLevel, minDistance, cv::noArray(), blockSize, useHarrisDetector, k);

std::vector<cv::Point2f> resCorners;
std::vector<cv::Point2f> imgCorners = { cv::Point2f(0, 0), cv::Point2f(bigBin.cols, 0), cv::Point2f(bigBin.cols, bigBin.rows), cv::Point2f(0, bigBin.rows) };
for (auto imgCorn : imgCorners)
{
    size_t best_i = corners.size();
    float min_dist = bigBin.cols * bigBin.rows;
    for (size_t i = 0; i < corners.size(); ++i)
    {
        float dist = cv::norm(imgCorn - corners[i]);
        if (dist < min_dist)
        {
            best_i = i;
            min_dist = dist;
        }
    }
    if (best_i != corners.size())
    {
        resCorners.push_back(corners[best_i]);
    }
}
cv::Mat bigColor;
cv::cvtColor(bigBin, bigColor, cv::COLOR_GRAY2BGR);
for (auto corner : corners)
{
    cv::circle(bigColor, corner, 10, cv::Scalar(0, 0, 255.), 1);
}
for (auto corner : resCorners)
{
    cv::circle(bigColor, corner, 5, cv::Scalar(0, 255, 0), 2);
}

cv::imshow("gray", gray);
cv::imshow("bigColor", bigColor);
cv::waitKey(0);

此处红色圆圈 - Harris 的角,绿色 - 最接近图像角。可以吗?

Result:

关于python - 查找图像上的特定点,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54661766/

相关文章:

python - 将值添加到 PySpark 中的 DenseVector 中

python - 属性错误: "AbstractModel" object has no attribute "computeIIS"

javascript - 使用 javascript 和 jquery 将图像添加到 svg 文件

javascript - 如何防止背景图像在更改时闪烁

c++ - QtCreator 和 OpenCV

opencv - 使用 OpenCV + OpenSLAM 创建语义 map ?

python - Python 中的最大素数回文

python - 如何使用与其他两列匹配的Python填充数据集中的空值?

javascript - 使用javascript同步加载图像

java - 在 JavaCV 的 CanvasFrame 上显示一个组件