DeepObjectDetectClass.cs 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. using MvvmScaffoldFrame48.DLL.ImageAlgorithm;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Drawing;
  5. using System.Drawing.Imaging;
  6. using System.IO;
  7. using System.Linq;
  8. using System.Text;
  9. using System.Threading;
  10. using System.Threading.Tasks;
  11. using System.Windows;
  12. using System.Windows.Input;
  13. using System.Windows.Media.Imaging;
  14. using System.Xml.Linq;
  15. using VisionDesigner.MVDCNNDetect;
  16. namespace MvvmScaffoldFrame48.ViewModel.ViewModel
  17. {
  18. public class DeepObjectDetectClass : BaseViewModel
  19. {
  20. #region 界面绑定属性
  21. private BitmapImage _showImage;
  22. public BitmapImage ShowImage
  23. {
  24. get { return _showImage; }
  25. set
  26. {
  27. if (_showImage != value)
  28. {
  29. _showImage = value;
  30. OnPropertyChanged(nameof(ShowImage));
  31. }
  32. }
  33. }
  34. #endregion
  35. #region 界面绑定事件
  36. public ICommand TestCommand{ get; set; }
  37. #endregion
  38. #region 属性
  39. private CPUDeepObjectDetectClass cPUDeepObject = new CPUDeepObjectDetectClass();
  40. #endregion
  41. #region 绑定用Action方法
  42. public void Test(object obj)
  43. {
  44. List<Bitmap> bitmaps = new List<Bitmap>();
  45. // 创建一个 Bitmap 对象
  46. Bitmap bitmap = new Bitmap("D:\\work\\MvvmScaffoldFrame48\\MvvmScaffoldFrame48\\MvvmScaffoldFrame48\\testfile\\testimage\\2025-08-04-13-28-45-807.jpg");
  47. cPUDeepObject.LoadImage(bitmap);
  48. cPUDeepObject.LoadDeepModel("D:\\work\\MvvmScaffoldFrame48\\MvvmScaffoldFrame48\\MvvmScaffoldFrame48\\testfile\\model\\Detect_20250818T1328175385.bin");
  49. var result = cPUDeepObject.RunDetect();
  50. foreach (var item in result)
  51. {
  52. if (item.LabelName == "A好药")
  53. {
  54. continue;
  55. }
  56. Rectangle rectangle = new Rectangle(Convert.ToInt32(item.Box.CenterX - (item.Box.Width / 2)), Convert.ToInt32(item.Box.CenterY - (item.Box.Height / 2)), Convert.ToInt32(item.Box.Width), Convert.ToInt32(item.Box.Height));
  57. bitmaps.Add(ImageAlgorithmTools.CropBitmap(bitmap, rectangle));
  58. }
  59. //PrintRectToBitmap(result, ref bitmap);
  60. // 将 Bitmap 转换为 BitmapImage
  61. //BitmapImage bitmapImage = ImageAlgorithmTools.ConvertToBitmapImage(bitmap);
  62. //ShowImage = bitmapImage;
  63. Task.Run(async () =>
  64. {
  65. foreach (var item in bitmaps)
  66. {
  67. await Application.Current.Dispatcher.InvokeAsync(() => {
  68. BitmapImage bitmapImage = ImageAlgorithmTools.ConvertToBitmapImage(item);
  69. ShowImage = bitmapImage;
  70. });
  71. Thread.Sleep(500);
  72. }
  73. });
  74. }
  75. #endregion
  76. #region 绑定用Predicate方法
  77. private bool CanTrue(object obj)
  78. {
  79. return true;
  80. }
  81. private bool CanFalse(object obj)
  82. {
  83. return false;
  84. }
  85. #endregion
  86. #region 其他方法
  87. public DeepObjectDetectClass()
  88. {
  89. TestCommand = new RelayCommand(Test, CanTrue);
  90. }
  91. public void PrintRectToBitmap(List<CNNDetectPredInfo> RectData , ref Bitmap bitmap)
  92. {
  93. using (Graphics g = Graphics.FromImage(bitmap))
  94. {
  95. var redPen = new Pen(Color.Red, 2);
  96. var GreenPen = new Pen(Color.SeaGreen, 2);
  97. foreach (var item in RectData)
  98. {
  99. int roix = Convert.ToInt32(item.Box.CenterX - (item.Box.Width/2));
  100. int roiy = Convert.ToInt32(item.Box.CenterY - (item.Box.Height/2));
  101. g.DrawRectangle(item.LabelName== "A坏药"?redPen:GreenPen, new Rectangle(roix, roiy, (int)item.Box.Width, (int)item.Box.Height));
  102. }
  103. }
  104. }
  105. #endregion
  106. }
  107. }