FlightImport.cs 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  1. using DataSimulation.Repostory;
  2. using DataSimulation.Repostory.EFContext;
  3. using DataSimulation.Repostory.Model;
  4. using DevExpress.Utils.About;
  5. using DevExpress.XtraEditors;
  6. using DevExpress.XtraEditors.Controls;
  7. using DevExpress.XtraEditors.DXErrorProvider;
  8. using DevExpress.XtraGrid.Views.Grid;
  9. using DxHelper;
  10. using ExtensionsDev;
  11. using System;
  12. using System.Collections;
  13. using System.Collections.Generic;
  14. using System.ComponentModel;
  15. using System.Data;
  16. using System.Data.Entity;
  17. using System.Data.Entity.Migrations;
  18. using System.Drawing;
  19. using System.IO;
  20. using System.Linq;
  21. using System.Text;
  22. using System.Threading.Tasks;
  23. using System.Windows.Forms;
  24. namespace DataSimulation.Forms.EditForms
  25. {
  26. public partial class FlightImport : DevExpress.XtraEditors.XtraForm
  27. {
  28. public List<SimulationInfo> Addinfo;
  29. private List<SimulationInfo> simulationInfos;
  30. private List<FlightInfo> flightInfos = new List<FlightInfo>();
  31. public FlightImport(List<SimulationInfo> simulationInfos)
  32. {
  33. InitializeComponent();
  34. this.Text = "导入航迹";
  35. this.simulationInfos = simulationInfos;
  36. this.StartPosition = FormStartPosition.CenterParent;
  37. }
  38. private void Editor_Load(object sender, EventArgs e)
  39. {
  40. mapControl.UseDefalutOptions()
  41. .UseClearAll()
  42. .UseDistanceLine()
  43. .UseMarkDot()
  44. .UseExportImg()
  45. .UseExportXlsx()
  46. .UseExportCsv()
  47. .UseExportFlightLine()
  48. .SetMapLayerType(null);
  49. gridView1.SelectionChanged += GridView1_SelectionChanged;
  50. gridImprot.Init<FlightInfo>().UseSort().UseFilter().UseMultiSelect().UseRowNumber();
  51. gridView1.OptionsSelection.MultiSelectMode = GridMultiSelectMode.CheckBoxRowSelect;
  52. gridImprot.DataSource = flightInfos;
  53. gridView1.RefreshData();
  54. }
  55. private void GridView1_SelectionChanged(object sender, DevExpress.Data.SelectionChangedEventArgs e)
  56. {
  57. var ids = gridView1.GetSelectedRows();
  58. List<FlightInfo> selects = new List<FlightInfo>();
  59. foreach (var id in ids)
  60. {
  61. var item = gridView1.GetRow(id) as FlightInfo;
  62. selects.Add(item);
  63. }
  64. mapControl.SetFlightLine(selects);
  65. }
  66. private async void btnSave_Click(object sender, EventArgs e)
  67. {
  68. try
  69. {
  70. var fligths = mapControl.GetFlightLine<FlightInfo>();
  71. Addinfo = new List<SimulationInfo>();
  72. var sims = fligths.Select(f => new SimulationInfo() { SimulationName = f.FlightName, SimulationSpeed = f.Speed });
  73. Addinfo.AddRange(sims);
  74. using (SimulationPartContext db = SimulationPartContext.GetContext(sims.First().CreateTime))
  75. {
  76. var sinfos = db.SimulationInfos.AddRange(Addinfo);
  77. await db.SaveChangesAsync();
  78. List<SimulationPonit> ponits = new List<SimulationPonit>();
  79. foreach (var sinfo in sinfos)
  80. {
  81. var flight = fligths.FirstOrDefault(s => s.FlightName == sinfo.SimulationName);
  82. var fpoints = flight.flights.Select(f => new SimulationPonit()
  83. {
  84. SimulationId = sinfo.ID,
  85. SimulationLon = f.FlightLon,
  86. SimulationLat = f.FlightLat,
  87. });
  88. ponits.AddRange(fpoints);
  89. }
  90. db.SimulationPonits.AddRange(ponits);
  91. await db.SaveChangesAsync();
  92. }
  93. this.DialogResult = DialogResult.OK;
  94. }
  95. catch (Exception ex)
  96. {
  97. Serilog.Log.Error(ex, $"{this.Text}异常");
  98. DxHelper.MsgBoxHelper.ShowError($"{this.Text}异常");
  99. }
  100. }
  101. private List<FlightInfo> AnalysisFlight(string filePath)
  102. {
  103. List<FlightInfo> fs = new List<FlightInfo>();
  104. try
  105. {
  106. List<FightDataCsv> fights = new List<FightDataCsv>();
  107. var allLines = File.ReadAllLines(filePath);
  108. int count = 0;
  109. foreach (var item in allLines)
  110. {
  111. count++;
  112. if (count == 1) continue;
  113. var strs = item.Split(new string[] { "," }, StringSplitOptions.RemoveEmptyEntries);
  114. if (strs.Length != 4)
  115. {
  116. throw new Exception("格式错误");
  117. }
  118. FightDataCsv fight = new FightDataCsv();
  119. int i = 0;
  120. fight.FlightName = strs[i++];
  121. fight.Speed = Convert.ToDouble(strs[i++]);
  122. fight.FlightLon = Convert.ToDouble(strs[i++]);
  123. fight.FlightLat = Convert.ToDouble(strs[i++]);
  124. fights.Add(fight);
  125. }
  126. var groupfilghts = fights.GroupBy(f => f.FlightName);
  127. foreach (var flight in groupfilghts)
  128. {
  129. string name = flight.Key;
  130. if (simulationInfos.Any(m => m.SimulationName == name))
  131. {
  132. name = $"{name}{DateTime.Now:yyyyMMddHHmmss}";
  133. }
  134. double speed = flight.First().Speed;
  135. var fligths = flight.Select(f => new FlightData(f.FlightLon, f.FlightLat)).ToList();
  136. FlightInfo flightInfo = new FlightInfo(name, speed);
  137. flightInfo.flights.AddRange(fligths);
  138. fs.Add(flightInfo);
  139. }
  140. }
  141. catch (Exception ex)
  142. {
  143. Serilog.Log.Error(ex, $"导入航迹解析异常:{ex.Message}");
  144. DxHelper.MsgBoxHelper.ShowError($"导入航迹解析异常:{ex.Message}");
  145. }
  146. return fs;
  147. }
  148. private void btnFlight_Click(object sender, EventArgs e)
  149. {
  150. flightInfos.Clear();
  151. XtraOpenFileDialog xtraOpenFileDialog1 = new XtraOpenFileDialog();
  152. xtraOpenFileDialog1.Multiselect = false;
  153. xtraOpenFileDialog1.Filter = "CSV文件|*.csv";
  154. if (xtraOpenFileDialog1.ShowDialog() == DialogResult.OK)
  155. {
  156. string filePath = xtraOpenFileDialog1.FileName;
  157. var ff = AnalysisFlight(filePath);
  158. flightInfos.AddRange(ff);
  159. }
  160. gridView1.RefreshData();
  161. gridView1.SelectAll();
  162. mapControl.SetFlightLine(flightInfos);
  163. }
  164. }
  165. }