Finger.cs 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Drawing;
  4. using System.Linq;
  5. using System.Text;
  6. using System.Threading.Tasks;
  7. using bbiwarg.Images;
  8. using bbiwarg.Utility;
  9. using bbiwarg.Graphics;
  10. using bbiwarg.Recognition.HandRecognition;
  11. using Emgu.CV;
  12. namespace bbiwarg.Recognition.FingerRecognition
  13. {
  14. class Finger
  15. {
  16. public Vector2D TipPoint { get { return SliceTrail.StartSlice.Mid; } }
  17. public Vector2D HandPoint { get { return SliceTrail.EndSlice.Mid; } }
  18. public Vector2D MidPoint { get { return SliceTrail.MidSlice.Mid; } }
  19. public Vector2D Direction { get { return LineSegment.Direction; } }
  20. public Vector2D TipDirection { get { return SliceTrail.getStartDirection(); } }
  21. public Vector2D HandDirection { get { return SliceTrail.getEndDirection(); } }
  22. public LineSegment2D LineSegment { get { return SliceTrail.LineSegment; } }
  23. public FingerSliceTrail SliceTrail { get; private set; }
  24. public Contour<Point> Contour { get { return SliceTrail.getContour(); } }
  25. public Finger(FingerSliceTrail sliceTrail)
  26. {
  27. SliceTrail = sliceTrail;
  28. }
  29. public float getSimilarity(Finger compareFinger)
  30. {
  31. LineSegment2D compareLineSegment = compareFinger.LineSegment;
  32. Line2D compareLine = compareLineSegment.Line;
  33. //check angle
  34. float angle = LineSegment.Line.getAngleBetween(compareLine);
  35. float angleSimilarity = Math.Max(1 - angle / Constants.FingerSimilarityMaxAngle, 0);
  36. //check parallel distance
  37. float parallelDistance = LineSegment.getParallelDistanceTo(compareLineSegment);
  38. float parallelDistanceSimilarity = Math.Max(1 - parallelDistance / Constants.FingerSimilarityMaxParallelDistance, 0);
  39. //check vertical distance
  40. float verticalDistance = LineSegment.getVerticalDistanceTo(compareLineSegment);
  41. float verticalDistanceSimilarity = Math.Max(1 - verticalDistance / Constants.FingerSimilarityMaxVerticalDistance, 0);
  42. return (angleSimilarity + parallelDistanceSimilarity + verticalDistanceSimilarity) / 3;
  43. }
  44. public void draw(OutputImage outputImage, bool tracked)
  45. {
  46. if (tracked)
  47. {
  48. outputImage.drawLineSegment(LineSegment, Constants.FingerTrackedColor);
  49. }
  50. else
  51. {
  52. for (int i = 0; i < SliceTrail.NumSlices; i++)
  53. {
  54. outputImage.drawLineSegment(SliceTrail[i].LineSegment, Constants.FingerSliceColor);
  55. }
  56. outputImage.drawLineSegment(LineSegment, Constants.FingerDetectedColor);
  57. outputImage.drawContour(Contour, Constants.FingerContourColor, 1);
  58. }
  59. }
  60. }
  61. }