BackgroundSubtractor.cs 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6. using bbiwarg.Images;
  7. using Emgu.CV;
  8. using Emgu.CV.Structure;
  9. using Emgu.CV.VideoSurveillance;
  10. namespace bbiwarg.Preprocessing
  11. {
  12. class BackgroundSubtractor
  13. {
  14. private BackgroundSubtractorMOG subtractor;
  15. public BackgroundSubtractor()
  16. {
  17. subtractor = new BackgroundSubtractorMOG(0, 0, 0.0, 0.0); // defaults
  18. }
  19. public void update(Image<Bgr, byte> currentColorImage)
  20. {
  21. subtractor.Update(currentColorImage);
  22. }
  23. public Image<Gray, short> getForeground(Image<Gray, short> image)
  24. {
  25. Image<Gray, short> foreground = image.Clone();
  26. foreground = foreground.And(subtractor.ForegroundMask.Convert<short>(delegate(byte b) { if (b == 0) return 0; else return short.MaxValue; }));
  27. int numNonZero = 0;
  28. for (int i = 0; i < image.Width; ++i)
  29. for (int j = 0; j < image.Height; ++j)
  30. if (subtractor.ForegroundMask.Data[j, i, 0] != 0)
  31. ++numNonZero;
  32. Console.WriteLine("non zero: " + numNonZero);
  33. return subtractor.ForegroundMask.Convert<short>(delegate(byte b) { return (b == 0) ? (short) 0 : (short) 100; });
  34. }
  35. }
  36. }