Подтвердить что ты не робот

Android - камера как детектор движения

Как реализовать простой детектор движения с использованием передней камеры и Android SDK?

Пример сценария будет таким: устройство стоит на подставке и воспроизводит фильм. Если перед ним появляется человек, даже не касаясь его - он меняет фильм.

4b9b3361

Ответ 1

Вот учебник о том, как сделать фотографию с помощью камеры.

Если вы делаете снимок каждую секунду, а затем уменьшаете его до размера примерно 8x8 пикселей, вы можете легко сравнить две фотографии и выяснить, произошло ли что-то, чтобы инициировать ваше действие.

Причина, по которой вы должны уменьшить его, заключается в следующем:

  1. Это меньше ошибок, подверженных шуму, создаваемому камерой
  2. Это будет намного быстрее, чем сравнение всего изображения.

Ответ 3

Я решил, что нужно делать снимки каждые n секунд, масштабировать их до 10*10 пикселей и находить разницу между ними. Вот реализация kotlin:

private fun detectMotion(bitmap1: Bitmap, bitmap2: Bitmap) {
    val difference =
        getDifferencePercent(bitmap1.apply { scale(16, 12) }, bitmap2.apply { scale(16, 12) })
    if (difference > 10) { // customize accuracy
        // motion detected
    }
}

private fun getDifferencePercent(img1: Bitmap, img2: Bitmap): Double {
    if (img1.width != img2.width || img1.height != img2.height) {
        val f = "(%d,%d) vs. (%d,%d)".format(img1.width, img1.height, img2.width, img2.height)
        throw IllegalArgumentException("Images must have the same dimensions: $f")
    }
    var diff = 0L
    for (y in 0 until img1.height) {
        for (x in 0 until img1.width) {
            diff += pixelDiff(img1.getPixel(x, y), img2.getPixel(x, y))
        }
    }
    val maxDiff = 3L * 255 * img1.width * img1.height
    return 100.0 * diff / maxDiff
}

private fun pixelDiff(rgb1: Int, rgb2: Int): Int {
    val r1 = (rgb1 shr 16) and 0xff
    val g1 = (rgb1 shr 8) and 0xff
    val b1 = rgb1 and 0xff
    val r2 = (rgb2 shr 16) and 0xff
    val g2 = (rgb2 shr 8) and 0xff
    val b2 = rgb2 and 0xff
    return abs(r1 - r2) + abs(g1 - g2) + abs(b1 - b2)
}