Как вернуть векториз JNI в Java? - PullRequest
0 голосов
/ 01 марта 2019

Я разрабатываю приложение для Android, чтобы найти самый большой контур из входного изображения.

Я нашел рабочий пример в c ++.

Я попытался адаптировать его к своему проекту, и яя пытаюсь сделать функцию JNI для возврата результатов.

Я застрял при возвращении списка найденных контуров из JNI в Java.

Вот мой код JNI, который неработает на данный момент

extern "C"
jobjectArray
Java_com_grimg_coffretpfe_Activities_CompareActivity_getQuadrilateral(
    JNIEnv *env,
    jobject /* this */,
    jlong grayscale,
    jlong output) {

Mat* mGray = (cv::Mat*) grayscale;
Mat* mOutput = (cv::Mat*) output;

Mat convexHull_mask(mGray->rows, mGray->cols, CV_8UC1);
convexHull_mask = Scalar(0);

vector<vector<Point>> contours;
findContours(*mGray, contours, RETR_EXTERNAL, CHAIN_APPROX_NONE);
vector<int> indices(contours.size());
iota(indices.begin(), indices.end(), 0);

sort(indices.begin(), indices.end(), [&contours](int lhs, int rhs) {
    return contours[lhs].size() > contours[rhs].size();
});

/// Find the convex hull object
vector<vector<Point> >hull(1);
convexHull(Mat(contours[indices[0]]), hull[0], false);

vector<Vec4i> lines;
HoughLinesP(convexHull_mask, lines, 1, CV_PI / 200, 50, 50, 10);

if (lines.size() == 4) // we found the 4 sides
{
    vector<Vec3f> params(4);
    for (int l = 0; l < 4; l++)
    {
        params.push_back(calcParams(Point(lines[l][0], lines[l][1]), Point(lines[l][2], lines[l][3])));
    }

    vector<Point> corners;
    for (int i = 0; i < params.size(); i++)
    {
        for (int j = i; j < params.size(); j++) // j starts at i so we don't have duplicated points
        {
            Point intersec = findIntersection(params[i], params[j]);
            if ((intersec.x > 0) && (intersec.y > 0) && (intersec.x < mGray->cols) && (intersec.y < mGray->rows))
            {
                cout << "corner: " << intersec << endl;
                corners.push_back(intersec);
            }
        }
    }

    if (corners.size() == 4) // we have the 4 final corners
    {
        return(corners);
    }
}

return(vector<Point>());

}

Возвращаемые значения неверны, как я могу изменить этот кусок кода, чтобы вернуть эти контуры?

...