OpenCV рисования прямоугольника из контуров - PullRequest
0 голосов
/ 18 января 2019

Я пытаюсь обнаружить движущиеся объекты, рисуя вокруг них прямоугольник, используя openCV в Android-приложении с BackgroundSubtractorMOG2 объектом.

Я уже извлек маску переднего плана и нашел контуры, но кажется, что Imgproc.rectangle() не рисует прямоугольники.

override fun onCameraFrame(inputFrame: CvCameraViewFrame?): Mat? {
        val minContourWidth = 35
        val minContourHeight = 35
        val threshold = 100.0
        val kernel = Imgproc.getStructuringElement(Imgproc.MORPH_ELLIPSE, Size(5.0, 5.0))

        frame = inputFrame?.rgba()
        backSub?.apply(frame, fgMask)
        Imgproc.morphologyEx(fgMask, fgMask, Imgproc.MORPH_CLOSE, kernel) // fill holes
        Imgproc.morphologyEx(fgMask, fgMask, Imgproc.MORPH_OPEN, kernel) //remove noise
        Imgproc.dilate(fgMask, fgMask, kernel)

        val cannyOutput = Mat()
        Imgproc.Canny(fgMask, cannyOutput, threshold, threshold * 2)
        val contours = ArrayList<MatOfPoint>()
        val hierarchy = Mat()
        Imgproc.findContours(cannyOutput, contours, hierarchy, Imgproc.RETR_EXTERNAL, Imgproc.CHAIN_APPROX_TC89_L1)
        hierarchy.release()
        Log.i(TAG, "contours size: " + contours.size)

        for(contour in contours) {

            val approxCurve = MatOfPoint2f()
            val contour2f = MatOfPoint2f()
            contour.convertTo(contour2f, CvType.CV_32FC2)
            val approxDistance = Imgproc.arcLength(contour2f, true) * 0.02
            Imgproc.approxPolyDP(contour2f, approxCurve, approxDistance, true)
            val points = MatOfPoint()
            approxCurve.convertTo(points, CvType.CV_8UC4)
            val rect = Imgproc.boundingRect(points)

            Imgproc.rectangle(frame, Point(rect.x.toDouble(), rect.y.toDouble()),
                Point((rect.x + rect.width).toDouble(), (rect.y + rect.height).toDouble()), Scalar(255.0, 0.0, 0.0, 255.0), 3)
        }

        return frame
    }

Ссылка на мой репозиторий

1 Ответ

0 голосов
/ 19 января 2019

Я наконец заставил это работать, оказалось, что мне пришлось изменить contour.convertTo(contour2f, CvType.CV_32FC2) на approxCurve.convertTo(points, CvType.CV_32SC2) в соответствии с этим ответом на opencv Q & A forum.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...