HistoryDataPage.xaml.cs 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400
  1. using CCDCount.DLL;
  2. using CCDCount.DLL.SqlDataClass;
  3. using CCDCount.MODEL.ConfigModel;
  4. using CCDCount.MODEL.ShuLiModel;
  5. using CCDCountWpf.Language;
  6. using System;
  7. using System.Collections.Generic;
  8. using System.Diagnostics;
  9. using System.Drawing;
  10. using System.IO;
  11. using System.Linq;
  12. using System.Text;
  13. using System.Threading.Tasks;
  14. using System.Windows;
  15. using System.Windows.Controls;
  16. using System.Windows.Data;
  17. using System.Windows.Documents;
  18. using System.Windows.Input;
  19. using System.Windows.Markup;
  20. using System.Windows.Media;
  21. using System.Windows.Media.Imaging;
  22. using System.Windows.Navigation;
  23. using System.Windows.Shapes;
  24. namespace CCDCountWpf.WpfPage
  25. {
  26. /// <summary>
  27. /// HistoryDataPage.xaml 的交互逻辑
  28. /// </summary>
  29. public partial class HistoryDataPage : Page
  30. {
  31. private static ActionMesSqliteDataClass actionMesSqliteDataClass = null;
  32. List<ActiveObjectClass> ErrorActive = null;
  33. List<ActiveObjectClass> NowPageError = null;
  34. int NowErrorNum = 0;
  35. int DataStartLine = 0;
  36. private int PageHeight = 2000;
  37. public HistoryDataPage()
  38. {
  39. InitializeComponent();
  40. DataContext = ShowMessageBus.ShowBinding;
  41. InitBatchItems();
  42. UpDateShowBinding();
  43. }
  44. private void PreviousBtn_Click(object sender, RoutedEventArgs e)
  45. {
  46. if (ShowMessageBus.ShowBinding.HistoryImageNum <= 1)
  47. {
  48. MessageBox.Show("已经是第一页");
  49. return;
  50. }
  51. ShowMessageBus.ShowBinding.HistoryImageNum -= 1;
  52. UpDateShowBinding();
  53. }
  54. private void NextBtn_Click(object sender, RoutedEventArgs e)
  55. {
  56. if (ShowMessageBus.ShowBinding.HistoryImageNum >= ShowMessageBus.ShowBinding.HistoryImageCount)
  57. {
  58. MessageBox.Show("已经是最后一页");
  59. return;
  60. }
  61. ShowMessageBus.ShowBinding.HistoryImageNum += 1;
  62. UpDateShowBinding();
  63. }
  64. private void UpDateShowBinding()
  65. {
  66. if (actionMesSqliteDataClass == null)
  67. {
  68. return;
  69. }
  70. Stopwatch stopwatch = Stopwatch.StartNew();
  71. BitmapImage ShowBitMap = null;
  72. Bitmap BitmapImage = null;
  73. List<ActiveObjectClass> ShowResult = actionMesSqliteDataClass.GetActiveObjectForPage((ShowMessageBus.ShowBinding.HistoryImageNum - 1) * PageHeight + DataStartLine, ShowMessageBus.ShowBinding.HistoryImageNum * PageHeight + DataStartLine);
  74. if (ShowResult.Count > 0)
  75. {
  76. int ThisImageStartLine = (int)ShowResult.Min(o => o.StartLine);
  77. int ImageHeight = (int)(ShowResult.Max(o => o.LastSeenLine) - ShowResult.Min(o => o.StartLine))+50;
  78. int ImageWidth = ShowResult.Max(o => o.ImageWidth);
  79. BitmapImage = new Bitmap(ImageWidth, ImageHeight <= PageHeight ? PageHeight : ImageHeight);
  80. using (Graphics g = Graphics.FromImage(BitmapImage))
  81. {
  82. g.Clear(System.Drawing.Color.White);
  83. var redPen = new System.Drawing.Pen(System.Drawing.Color.Red, 1);
  84. var bluePen = new System.Drawing.Pen(System.Drawing.Color.FromArgb(0, 146, 255), 1);
  85. var GreenPen = new System.Drawing.Pen(System.Drawing.Color.SeaGreen, 5);
  86. foreach (var item in ShowResult)
  87. {
  88. int roix = item.MinStartCol - 5;
  89. int roiy = (int)(item.StartLine - ThisImageStartLine) + 15;
  90. int roiheight = (int)(item.LastSeenLine - (long)item.StartLine) + 10;
  91. int roiwidth = item.MaxEndCol - item.MinStartCol + 10;
  92. g.DrawRectangle(GreenPen, new System.Drawing.Rectangle(roix, roiy, roiwidth, roiheight));
  93. Font font = new Font("Arial", 20);
  94. g.DrawString(item.Num.ToString(), font, System.Drawing.Brushes.Black, new System.Drawing.Point(roix - 20 * item.Num.ToString().Length, roiy - 20));
  95. if(item.StateCode!=0)
  96. {
  97. string ErrorMessage = "";
  98. if (item.StateCode == 1)
  99. ErrorMessage = "LONG";
  100. else if (item.StateCode == 2)
  101. ErrorMessage = "SHORT";
  102. else if (item.StateCode == 5)
  103. ErrorMessage = "BIG";
  104. else if (item.StateCode == 6)
  105. ErrorMessage = "SMALL";
  106. g.DrawString(ErrorMessage, font, System.Drawing.Brushes.Black, new System.Drawing.Point(roix - 20 * item.Num.ToString().Length, roiy - 50));
  107. }
  108. g.DrawString(item.Num.ToString(), font, System.Drawing.Brushes.Black, new System.Drawing.Point(roix - 20 * item.Num.ToString().Length, roiy - 20));
  109. foreach (var item1 in item.RowsData)
  110. {
  111. int yPos = (int)(item1.RowsCol - ThisImageStartLine + 20);
  112. g.DrawLine(item.StateCode == 0 ? bluePen : redPen, new System.Drawing.Point(item1.StartCol, yPos), new System.Drawing.Point(item1.EndCol, yPos));
  113. }
  114. }
  115. }
  116. }
  117. else
  118. {
  119. BitmapImage = new Bitmap(4096, PageHeight);
  120. using (Graphics g = Graphics.FromImage(BitmapImage))
  121. {
  122. g.Clear(System.Drawing.Color.White);
  123. }
  124. }
  125. Application.Current.Dispatcher.InvokeAsync(() =>
  126. {
  127. ShowBitMap = ConvertToBitmapImage(BitmapImage);
  128. ShowMessageBus.ShowBinding.HistoryImage = ShowBitMap;
  129. });
  130. stopwatch.Stop();
  131. Console.WriteLine($"{stopwatch.ElapsedMilliseconds}ms");
  132. NowPageError = ShowResult.Where(o => o.StateCode != 0).OrderBy(o => o.Num).ToList();
  133. }
  134. // Bitmap 转 BitmapImage 的辅助方法
  135. private BitmapImage ConvertToBitmapImage(Bitmap bitmap)
  136. {
  137. using (MemoryStream memory = new MemoryStream())
  138. {
  139. bitmap.Save(memory, System.Drawing.Imaging.ImageFormat.Png);
  140. memory.Position = 0;
  141. var bitmapImage = new BitmapImage();
  142. bitmapImage.BeginInit();
  143. bitmapImage.CacheOption = BitmapCacheOption.OnLoad;
  144. bitmapImage.StreamSource = memory;
  145. bitmapImage.EndInit();
  146. return bitmapImage;
  147. }
  148. }
  149. private void SkipBtn_Click(object sender, RoutedEventArgs e)
  150. {
  151. UpDateShowBinding();
  152. }
  153. /// <summary>
  154. /// 初始化批次列表
  155. /// </summary>
  156. private void InitBatchItems()
  157. {
  158. string folderPath = $"{AppDomain.CurrentDomain.BaseDirectory}DATA\\ActiveObjectData\\Cam{MessageBus.NowSettingLoadMainThread.cameraConfig.CamerNo}";
  159. if (!Directory.Exists(folderPath))
  160. {
  161. // 创建文件夹
  162. Directory.CreateDirectory(folderPath);
  163. }
  164. try
  165. {
  166. // 使用 DirectoryInfo 获取文件并按修改时间排序
  167. DirectoryInfo dirInfo = new DirectoryInfo(folderPath);
  168. FileInfo[] files = dirInfo.GetFiles("*.db", SearchOption.AllDirectories);
  169. // 按照修改时间排序(最新的在前)
  170. var sortedFiles = files.OrderByDescending(f => f.LastWriteTime).ToArray();
  171. ShowMessageBus.ShowBinding.BatchItems.Clear();
  172. foreach (FileInfo file in sortedFiles)
  173. {
  174. ShowMessageBus.ShowBinding.BatchItems.Add(System.IO.Path.GetFileNameWithoutExtension(file.Name).Split('_')[1]);
  175. }
  176. BatchNumComBox.SelectedIndex = 0;
  177. }
  178. catch
  179. { }
  180. }
  181. /// <summary>
  182. /// 初始化批号列表
  183. /// </summary>
  184. private void InitBatchItems(DateTime Mintime, DateTime MaxTime)
  185. {
  186. string folderPath = $"{AppDomain.CurrentDomain.BaseDirectory}DATA\\ActiveObjectData\\Cam{MessageBus.NowSettingLoadMainThread.cameraConfig.CamerNo}";
  187. if (!Directory.Exists(folderPath))
  188. {
  189. // 创建文件夹
  190. Directory.CreateDirectory(folderPath);
  191. }
  192. try
  193. {
  194. // 使用 DirectoryInfo 获取文件并按修改时间排序
  195. DirectoryInfo dirInfo = new DirectoryInfo(folderPath);
  196. FileInfo[] files = dirInfo.GetFiles("*.db", SearchOption.AllDirectories);
  197. // 按照修改时间排序(最新的在前)
  198. var sortedFiles = files.Where(f => f.CreationTime > Mintime && f.CreationTime < MaxTime.AddDays(1)).OrderByDescending(f => f.LastWriteTime).ToArray();
  199. ShowMessageBus.ShowBinding.BatchItems.Clear();
  200. foreach (FileInfo file in sortedFiles)
  201. {
  202. ShowMessageBus.ShowBinding.BatchItems.Add(System.IO.Path.GetFileNameWithoutExtension(file.Name).Split('_')[1]);
  203. }
  204. BatchNumComBox.SelectedIndex = 0;
  205. }
  206. catch
  207. { }
  208. }
  209. /// <summary>
  210. /// 初始化批号列表
  211. /// </summary>
  212. private void InitBatchItemsByMinTime(DateTime Mintime)
  213. {
  214. string folderPath = $"{AppDomain.CurrentDomain.BaseDirectory}DATA\\ActiveObjectData\\Cam{MessageBus.NowSettingLoadMainThread.cameraConfig.CamerNo}";
  215. if (!Directory.Exists(folderPath))
  216. {
  217. // 创建文件夹
  218. Directory.CreateDirectory(folderPath);
  219. }
  220. try
  221. {
  222. // 使用 DirectoryInfo 获取文件并按修改时间排序
  223. DirectoryInfo dirInfo = new DirectoryInfo(folderPath);
  224. FileInfo[] files = dirInfo.GetFiles("*.db", SearchOption.AllDirectories);
  225. // 按照修改时间排序(最新的在前)
  226. var sortedFiles = files.Where(f => f.CreationTime > Mintime).OrderByDescending(f => f.LastWriteTime).ToArray();
  227. ShowMessageBus.ShowBinding.BatchItems.Clear();
  228. foreach (FileInfo file in sortedFiles)
  229. {
  230. ShowMessageBus.ShowBinding.BatchItems.Add(System.IO.Path.GetFileNameWithoutExtension(file.Name).Split('_')[1]);
  231. }
  232. BatchNumComBox.SelectedIndex = 0;
  233. }
  234. catch
  235. { }
  236. }
  237. /// <summary>
  238. /// 初始化批号列表
  239. /// </summary>
  240. private void InitBatchItemsByMaxTime(DateTime MaxTime)
  241. {
  242. string folderPath = $"{AppDomain.CurrentDomain.BaseDirectory}DATA\\ActiveObjectData\\Cam{MessageBus.NowSettingLoadMainThread.cameraConfig.CamerNo}";
  243. if (!Directory.Exists(folderPath))
  244. {
  245. // 创建文件夹
  246. Directory.CreateDirectory(folderPath);
  247. }
  248. try
  249. {
  250. // 使用 DirectoryInfo 获取文件并按修改时间排序
  251. DirectoryInfo dirInfo = new DirectoryInfo(folderPath);
  252. FileInfo[] files = dirInfo.GetFiles("*.db", SearchOption.AllDirectories);
  253. // 按照修改时间排序(最新的在前)
  254. var sortedFiles = files.Where(f => f.CreationTime < MaxTime.AddDays(1)).OrderByDescending(f => f.LastWriteTime).ToArray();
  255. ShowMessageBus.ShowBinding.BatchItems.Clear();
  256. foreach (FileInfo file in sortedFiles)
  257. {
  258. ShowMessageBus.ShowBinding.BatchItems.Add(System.IO.Path.GetFileNameWithoutExtension(file.Name).Split('_')[1]);
  259. }
  260. BatchNumComBox.SelectedIndex = 0;
  261. }
  262. catch
  263. { }
  264. }
  265. private void BatchNumRecordMinTime_SelectedDateChanged(object sender, SelectionChangedEventArgs e)
  266. {
  267. if (BatchNumRecordMinTime.SelectedDate == null)
  268. {
  269. return;
  270. }
  271. else
  272. {
  273. if (BatchNumRecordMaxTime.SelectedDate == null)
  274. {
  275. InitBatchItemsByMinTime((DateTime)BatchNumRecordMinTime.SelectedDate);
  276. }
  277. else
  278. {
  279. InitBatchItems((DateTime)BatchNumRecordMinTime.SelectedDate, (DateTime)BatchNumRecordMaxTime.SelectedDate);
  280. }
  281. }
  282. }
  283. private void BatchNumRecordMaxTime_SelectedDateChanged(object sender, SelectionChangedEventArgs e)
  284. {
  285. if (BatchNumRecordMaxTime.SelectedDate == null)
  286. {
  287. return;
  288. }
  289. else
  290. {
  291. if (BatchNumRecordMinTime.SelectedDate == null)
  292. {
  293. InitBatchItemsByMaxTime((DateTime)BatchNumRecordMaxTime.SelectedDate);
  294. }
  295. else
  296. {
  297. InitBatchItems((DateTime)BatchNumRecordMinTime.SelectedDate, (DateTime)BatchNumRecordMaxTime.SelectedDate);
  298. }
  299. }
  300. }
  301. private void BatchNumRecordComBox_SelectionChanged(object sender, SelectionChangedEventArgs e)
  302. {
  303. if (BatchNumComBox.SelectedItem != null && BatchNumComBox.SelectedItem.ToString() != string.Empty)
  304. {
  305. string BatchNumber = BatchNumComBox.SelectedItem.ToString();
  306. actionMesSqliteDataClass = new ActionMesSqliteDataClass($"{AppDomain.CurrentDomain.BaseDirectory}DATA\\ActiveObjectData\\Cam{MessageBus.NowSettingLoadMainThread.cameraConfig.CamerNo}\\ActiveObjectData_{BatchNumber}.db");
  307. //actionMesSqliteDataClass = new ActionMesSqliteDataClass($"{AppDomain.CurrentDomain.BaseDirectory}DATA\\ActiveObjectData\\Cam{MessageBus.MainThreadS[0].cameraConfig.CamerNo}\\ActiveObjectData_20250908.db");
  308. actionMesSqliteDataClass.GetAllActionMinStartMaxEndLine(out int num, out int StartLine, out int EndLine);
  309. ShowMessageBus.ShowBinding.HistoryImageCount = (EndLine - StartLine) / PageHeight;
  310. DataStartLine = StartLine;
  311. ShowMessageBus.ShowBinding.HistoryImageNum = 1;
  312. UpDateShowBinding();
  313. ErrorActive = actionMesSqliteDataClass.GetAllErrorAction().OrderBy(o=>o.Num).ToList();
  314. }
  315. }
  316. private void Page_Loaded(object sender, RoutedEventArgs e)
  317. {
  318. BatchNumRecordMinTime.SelectedDate = DateTime.Today;
  319. BatchNumRecordMaxTime.SelectedDate = DateTime.Today;
  320. }
  321. private void PreviousErrorBtn_Click(object sender, RoutedEventArgs e)
  322. {
  323. if (ErrorActive != null)
  324. {
  325. if(NowErrorNum-1<0)
  326. {
  327. MessageBox.Show("已经是第一粒");
  328. }
  329. else
  330. {
  331. if(NowPageError.Count>0)
  332. {
  333. int LastErrNum = NowPageError.Where(o => o.StateCode != 0).OrderBy(o => o.Num).First().Num;
  334. NowErrorNum = ErrorActive.FindIndex(o => o.Num == LastErrNum);
  335. if(NowErrorNum-1>=0) NowErrorNum--;
  336. ShowMessageBus.ShowBinding.HistoryImageNum = ((int)(ErrorActive[NowErrorNum].StartLine - DataStartLine) / PageHeight) + 1;
  337. }
  338. else
  339. {
  340. ShowMessageBus.ShowBinding.HistoryImageNum = ((int)(ErrorActive[NowErrorNum].StartLine - DataStartLine) / PageHeight) + 1;
  341. if (NowErrorNum - 1 >= 0) NowErrorNum--;
  342. }
  343. UpDateShowBinding();
  344. }
  345. }
  346. }
  347. private void NextErrorBtn_Click(object sender, RoutedEventArgs e)
  348. {
  349. if (ErrorActive != null)
  350. {
  351. if (NowErrorNum+1 >= ErrorActive.Count)
  352. {
  353. MessageBox.Show("已经是最后一粒");
  354. }
  355. else
  356. {
  357. if (NowPageError.Count > 0)
  358. {
  359. int LastErrNum = NowPageError.Where(o => o.StateCode != 0).OrderBy(o => o.Num).Last().Num;
  360. NowErrorNum = ErrorActive.FindIndex(o => o.Num == LastErrNum);
  361. if (NowErrorNum + 1 <= ErrorActive.Count - 1) NowErrorNum++;
  362. ShowMessageBus.ShowBinding.HistoryImageNum = ((int)(ErrorActive[NowErrorNum].StartLine - DataStartLine) / PageHeight) + 1;
  363. }
  364. else
  365. {
  366. ShowMessageBus.ShowBinding.HistoryImageNum = ((int)(ErrorActive[NowErrorNum].StartLine - DataStartLine) / PageHeight) + 1;
  367. if (NowErrorNum + 1 <= ErrorActive.Count - 1) NowErrorNum++;
  368. }
  369. UpDateShowBinding();
  370. }
  371. }
  372. }
  373. }
  374. }