Как реализовать простой детектор движения с использованием передней камеры и Android SDK?
Пример сценария будет таким: устройство стоит на подставке и воспроизводит фильм. Если перед ним появляется человек, даже не касаясь его - он меняет фильм.
Как реализовать простой детектор движения с использованием передней камеры и Android SDK?
Пример сценария будет таким: устройство стоит на подставке и воспроизводит фильм. Если перед ним появляется человек, даже не касаясь его - он меняет фильм.
Вот учебник о том, как сделать фотографию с помощью камеры.
Если вы делаете снимок каждую секунду, а затем уменьшаете его до размера примерно 8x8 пикселей, вы можете легко сравнить две фотографии и выяснить, произошло ли что-то, чтобы инициировать ваше действие.
Причина, по которой вы должны уменьшить его, заключается в следующем:
Вот мое приложение для обнаружения движения с открытым исходным кодом для Android.
Я решил, что нужно делать снимки каждые 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)
}