moment work
This commit is contained in:
@@ -1,4 +1,5 @@
|
|||||||
import 'dart:async';
|
import 'dart:async';
|
||||||
|
import 'dart:ffi';
|
||||||
import 'package:camera/camera.dart';
|
import 'package:camera/camera.dart';
|
||||||
import 'dart:typed_data';
|
import 'dart:typed_data';
|
||||||
|
|
||||||
@@ -25,11 +26,16 @@ class _CameraAppState extends State<CameraApp> {
|
|||||||
var image_height = 0;
|
var image_height = 0;
|
||||||
var posy = 0.0;
|
var posy = 0.0;
|
||||||
var posx = 0.0;
|
var posx = 0.0;
|
||||||
|
var count = 0.0;
|
||||||
|
static const alpha = 0.99;
|
||||||
|
static const thresh = 25;
|
||||||
Uint8List? previousImage;
|
Uint8List? previousImage;
|
||||||
Uint8List? diff;
|
Uint8List? diff;
|
||||||
Uint8List? dst;
|
Uint8List? dst;
|
||||||
|
Uint64List? diffValues;
|
||||||
Float32List? background;
|
Float32List? background;
|
||||||
Float64List? sums;
|
Float64List? diffWeightsX;
|
||||||
|
|
||||||
|
|
||||||
@override
|
@override
|
||||||
void initState() {
|
void initState() {
|
||||||
@@ -94,7 +100,8 @@ class _CameraAppState extends State<CameraApp> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void handleImage(CameraImage src) {
|
void handleImage(CameraImage src) {
|
||||||
sums = Float64List(src.height);
|
diffWeightsX = Float64List(src.width);
|
||||||
|
diffValues = Uint64List(src.width);
|
||||||
|
|
||||||
if (previousImage == null || background == null) {
|
if (previousImage == null || background == null) {
|
||||||
previousImage = Uint8List(src.planes[0].bytes.length);
|
previousImage = Uint8List(src.planes[0].bytes.length);
|
||||||
@@ -104,27 +111,42 @@ class _CameraAppState extends State<CameraApp> {
|
|||||||
image_width = src.width;
|
image_width = src.width;
|
||||||
image_height = src.height;
|
image_height = src.height;
|
||||||
} else {
|
} else {
|
||||||
for (var i = 0; i < src.width; i++) {
|
for (var i = 0; i < image_height; i++) {
|
||||||
for (var j = 0; j < src.height; j++) {
|
for (var j = 0; j < image_width; j++) {
|
||||||
//Background calculation
|
//Background calculation
|
||||||
background![i + j] = (background![i + j] * 0.99 +
|
background![i + j] = (background![i + j] * alpha +
|
||||||
src.planes[0].bytes[i + j].toDouble() * (1.0 - 0.99));
|
src.planes[0].bytes[i + j].toDouble() * (1.0 - alpha));
|
||||||
|
|
||||||
//Difference calculation
|
//Difference calculation
|
||||||
var diff_val =
|
diff![i + j] = (background![i + j].toInt() - src.planes[0].bytes[i + j]).abs();
|
||||||
(background![i + j].toInt() - src.planes[0].bytes[i + j]).abs();
|
if(diff![i + j] > thresh) {
|
||||||
if (diff_val > 50) {
|
diffWeightsX![i] += diff![i + j] * j;
|
||||||
diff![i + j] = diff_val;
|
diffValues![i] += diff![i + j];
|
||||||
} else {
|
|
||||||
diff![i + j] = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//Center of motion calc
|
|
||||||
sums[i] +=
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Processing
|
// Processing
|
||||||
print(diff![0]);
|
|
||||||
|
//Average X Position
|
||||||
|
posx = 0;
|
||||||
|
posy = 0;
|
||||||
|
var currentCount = 0;
|
||||||
|
var weightsY = 0;
|
||||||
|
for(var i = 0; i < diffWeightsX!.length; i++){
|
||||||
|
if(diffValues![i] > 0){
|
||||||
|
posx += (diffWeightsX![i]/diffValues![i])/diffWeightsX!.length;
|
||||||
|
weightsY += diffValues![i] * i;
|
||||||
|
currentCount += diffValues![i];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(currentCount > 0) {
|
||||||
|
posy = weightsY/currentCount;
|
||||||
|
}
|
||||||
|
|
||||||
|
count = count * alpha + (currentCount/(image_width * image_height * 255) * 100.0) * (1.0 - alpha);
|
||||||
|
print(count);
|
||||||
|
|
||||||
// End Processing
|
// End Processing
|
||||||
previousImage = src.planes[0].bytes;
|
previousImage = src.planes[0].bytes;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user