SignalEmulation.cs 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. using DevExpress.XtraEditors;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.ComponentModel;
  5. using System.Data;
  6. using System.Drawing;
  7. using System.IO;
  8. using System.Linq;
  9. using System.Text;
  10. using System.Threading.Tasks;
  11. using System.Windows.Forms;
  12. using XdCxRhDW.Api;
  13. namespace XdCxRhDW.DataEmulation
  14. {
  15. public partial class SignalEmulation : DevExpress.XtraEditors.XtraForm
  16. {
  17. public SignalEmulation()
  18. {
  19. InitializeComponent();
  20. }
  21. private void btnOpenDir_Click(object sender, EventArgs e)
  22. {
  23. System.Diagnostics.Process.Start("explorer.exe", ".\\信号仿真\\");
  24. }
  25. private async void btnBuilder_ClickAsync(object sender, EventArgs e)
  26. {
  27. if (!long.TryParse(txtFsHz.Text, out long fsHz))
  28. {
  29. XtraMessageBox.Show("采样率非数字!");
  30. return;
  31. }
  32. if (!double.TryParse(txtDto1.Text, out double dt1))
  33. {
  34. XtraMessageBox.Show("时差1非数字!");
  35. return;
  36. }
  37. int.TryParse(txtSigLen.Text, out int brustCount);
  38. if (!double.TryParse(txtDfo1.Text, out double df1))
  39. {
  40. XtraMessageBox.Show("频差1非数字!");
  41. return;
  42. }
  43. if (!double.TryParse(txtDto2.Text, out double dt2))
  44. {
  45. XtraMessageBox.Show("时差2非数字!");
  46. return;
  47. }
  48. if (!double.TryParse(txtDfo2.Text, out double df2))
  49. {
  50. XtraMessageBox.Show("频差2非数字!");
  51. return;
  52. }
  53. if (fsHz <= 0 || fsHz > 100000000)
  54. {
  55. XtraMessageBox.Show("采样率范围(0,100000000]!");
  56. return;
  57. }
  58. if (brustCount <= 0 || brustCount > 500)
  59. {
  60. XtraMessageBox.Show("突发个数范围(0,500]");
  61. return;
  62. }
  63. btnBuild.Enabled = false;
  64. dt1 = dt1 / 1e6;
  65. dt2 = dt2 / 1e6;
  66. await Task.Run(() =>
  67. {
  68. Directory.CreateDirectory("信号仿真");
  69. var t1 = DateTime.Now;
  70. string f1, f2, f3;
  71. if (txtSplitTime.Checked)
  72. {
  73. f1 = $"信号仿真\\{t1:yyyyMMddHHmmss}_突发信号_{fsHz}_ch1.dat";
  74. f2 = $"信号仿真\\{t1.AddMinutes(5):yyyyMMddHHmmss}_突发信号_{fsHz}_ch1.dat";
  75. f3 = $"信号仿真\\{t1.AddMinutes(10):yyyyMMddHHmmss}_突发信号_{fsHz}_ch1.dat";
  76. }
  77. else
  78. {
  79. f1 = $"信号仿真\\{t1:yyyyMMddHHmmss}_突发信号_{fsHz}_ch1.dat";
  80. f2 = $"信号仿真\\{t1:yyyyMMddHHmmss}_突发信号_{fsHz}_ch2.dat";
  81. f3 = $"信号仿真\\{t1:yyyyMMddHHmmss}_突发信号_{fsHz}_ch3.dat";
  82. }
  83. DataEmulationHelper.GenBrustFiles(f1, f2, f3, fsHz, brustCount, dt1, df1, dt2, df2);
  84. });
  85. btnBuild.Enabled = true;
  86. }
  87. }
  88. }