Как получить несколько строк из HoughLinesP (openCV) на Android? - PullRequest
0 голосов
/ 23 февраля 2020

Я бы хотел получить несколько строк из этого процесса.

override fun onCameraFrame(inputFrame: CvCameraViewFrame): Mat? {
    mRgba = inputFrame.rgba()

    // generate gray scale and blur
    Imgproc.cvtColor(mRgba, mRgbaFiltered, Imgproc.COLOR_BGR2GRAY)
    Imgproc.blur(mRgbaFiltered, mRgbaFiltered, Size(3.0, 3.0))

    // detect the edges
    val mMat = Mat()
    val ratio = 4

    // Find Canny Edges
    Imgproc.Canny(mRgbaFiltered, mMat, threshold, threshold * ratio.toDouble())

    // Find horizontal lines
    val lines = Mat()
    Imgproc.HoughLinesP(mMat, lines, 1.0, Math.PI / 180, 80, 100.0, 10.0)

    // Change Color to RGB
    Imgproc.cvtColor(mMat, mMat, Imgproc.COLOR_GRAY2BGR)

    // draw lines
    for (i in 0 until lines.cols()) {
        val `val` = lines[0, i]
        Imgproc.line(
            mMat,
            Point(`val`[0], `val`[1]),
            Point(`val`[2], `val`[3]),
            Scalar(0.0, 255.0, 0.0),
            1
        )
    }

    num_lines = lines.cols()
    updateHandler.postDelayed(updateRunnable, 500)

    return mMat
}

Однако я получаю только одну строку, как вы можете видеть ниже. Мне нужно нарисовать все линии .. И как я могу это сделать?

enter image description here

Ответы [ 2 ]

0 голосов
/ 23 февраля 2020

Вам нужно изменить его на ..

столбцы -> строки

строки [0, i] -> строки [i, 0]

// draw lines
for (i in 0 until lines.rows()) {
    val dArr = lines[i, 0]
    Imgproc.line(
        mMat,
        Point(dArr[0], dArr[1]),
        Point(dArr[2], dArr[3]),
        Scalar(0.0, 255.0, 0.0),
        1
    )
}
0 голосов
/ 23 февраля 2020

Я только что изменил параметры жесткой линии и хитрости.

Вот мой код:

#include <opencv2/highgui/highgui.hpp>
#include <opencv2/imgproc/imgproc.hpp>
using namespace std;
using namespace cv;

int main()
{
    Mat img = imread("/ur/image/directory/lines.png");

    imshow("Source",img);

    Mat dst, cdst;
    Canny(img, dst, 80, 250);
    cvtColor(dst, cdst, CV_GRAY2BGR);

    vector<Vec4i> lines;
    HoughLinesP(dst, lines, 1.0, CV_PI/180, 80, 100.0, 10.0 );
    for( size_t i = 0; i < lines.size(); i++ )
    {
        Vec4i l = lines[i];
        line( cdst, Point(l[0], l[1]), Point(l[2], l[3]), Scalar(0,0,255), 3, CV_AA);
    }
    imshow("Output", cdst);

    waitKey(0);
    return 0;
}

Результат:

enter image description here

...