diff --git a/ArduCopter/system.pde b/ArduCopter/system.pde index c6f7e397d5..2b287016f5 100644 --- a/ArduCopter/system.pde +++ b/ArduCopter/system.pde @@ -199,6 +199,10 @@ static void init_ardupilot() } #endif +// agmatthews USERHOOKS +#ifdef USERHOOK_INIT + USERHOOK_INIT +#endif // Logging: // -------- // DataFlash log initialization diff --git a/Tools/ArdupilotMegaPlanner/GCSViews/Terminal.cs b/Tools/ArdupilotMegaPlanner/GCSViews/Terminal.cs index 9916791714..7051ee6006 100644 --- a/Tools/ArdupilotMegaPlanner/GCSViews/Terminal.cs +++ b/Tools/ArdupilotMegaPlanner/GCSViews/Terminal.cs @@ -168,6 +168,8 @@ namespace ArdupilotMega.GCSViews comPort.ReadBufferSize = 1024 * 1024; + comPort.PortName = MainV2.comportname; + comPort.Open(); System.Threading.Thread t11 = new System.Threading.Thread(delegate() diff --git a/Tools/ArdupilotMegaPlanner/Log.cs b/Tools/ArdupilotMegaPlanner/Log.cs index 01628a95ea..54fc20c46c 100644 --- a/Tools/ArdupilotMegaPlanner/Log.cs +++ b/Tools/ArdupilotMegaPlanner/Log.cs @@ -56,7 +56,7 @@ namespace ArdupilotMega public Log() { InitializeComponent(); - + Control.CheckForIllegalCrossThreadCalls = false; // so can update display from another thread } @@ -75,7 +75,8 @@ namespace ArdupilotMega comPort.DtrEnable = true; //comPort.Open(); } - catch (Exception) { + catch (Exception) + { MessageBox.Show("Error opening comport"); } @@ -99,7 +100,7 @@ namespace ArdupilotMega comPort_DataReceived((object)null, (SerialDataReceivedEventArgs)null); } } - catch (Exception ex) { Console.WriteLine("crash in comport reader "+ex.ToString()); } // cant exit unless told to + catch (Exception ex) { Console.WriteLine("crash in comport reader " + ex.ToString()); } // cant exit unless told to } Console.WriteLine("Comport thread close"); }); @@ -158,7 +159,8 @@ namespace ArdupilotMega if (!line.Contains("\n")) line = line + "\n"; } - catch { + catch + { line = comPort.ReadExisting(); //byte[] data = readline(comPort); //line = Encoding.ASCII.GetString(data, 0, data.Length); @@ -172,26 +174,26 @@ namespace ArdupilotMega { case serialstatus.Connecting: - if (line.Contains("reset to FLY") || line.Contains("interactive setup")) - { - comPort.Write("logs\r"); - } - if (line.Contains("logs")) - { - Regex regex2 = new Regex(@"^([0-9]+)", RegexOptions.IgnoreCase); - if (regex2.IsMatch(line)) - { - MatchCollection matchs = regex2.Matches(line); - logcount = int.Parse(matchs[0].Groups[0].Value); - genchkcombo(logcount); - status = serialstatus.Done; - } - } - if (line.Contains("No logs")) + if (line.Contains("reset to FLY") || line.Contains("interactive setup") || line.Contains("CLI:")) + { + comPort.Write("logs\r"); + } + if (line.Contains("logs")) + { + Regex regex2 = new Regex(@"^([0-9]+)", RegexOptions.IgnoreCase); + if (regex2.IsMatch(line)) { + MatchCollection matchs = regex2.Matches(line); + logcount = int.Parse(matchs[0].Groups[0].Value); + genchkcombo(logcount); status = serialstatus.Done; } - + } + if (line.Contains("No logs")) + { + status = serialstatus.Done; + } + break; case serialstatus.Closefile: sw.Close(); @@ -199,19 +201,25 @@ namespace ArdupilotMega MainV2.cs.firmware = MainV2.Firmwares.ArduPlane; + TXT_seriallog.AppendText("Createing KML for " + logfile); + while (tr.Peek() != -1) { processLine(tr.ReadLine()); } - - tr.Close(); - writeKML(logfile + ".kml"); + tr.Close(); + + try + { + writeKML(logfile + ".kml"); + } + catch { } // usualy invalid lat long error status = serialstatus.Done; break; case serialstatus.Createfile: receivedbytes = 0; - Directory.CreateDirectory(Path.GetDirectoryName(Application.ExecutablePath)+ Path.DirectorySeparatorChar +@"logs"); + Directory.CreateDirectory(Path.GetDirectoryName(Application.ExecutablePath) + Path.DirectorySeparatorChar + @"logs"); logfile = Path.GetDirectoryName(Application.ExecutablePath) + Path.DirectorySeparatorChar + @"logs" + Path.DirectorySeparatorChar + DateTime.Now.ToString("yyyy-MM-dd hh-mm") + " " + currentlog + ".log"; sw = new StreamWriter(logfile); status = serialstatus.Waiting; @@ -242,32 +250,32 @@ namespace ArdupilotMega } break; } - lock (thisLock) + lock (thisLock) + { + this.BeginInvoke((System.Threading.ThreadStart)delegate() + { + + Console.Write(line); + + TXT_seriallog.AppendText(line); + + // auto scroll + if (TXT_seriallog.TextLength >= 10000) { - this.BeginInvoke((System.Threading.ThreadStart)delegate() - { - - Console.Write(line); - - TXT_seriallog.AppendText(line); - - // auto scroll - if (TXT_seriallog.TextLength >= 10000) - { - TXT_seriallog.Text = TXT_seriallog.Text.Substring(TXT_seriallog.TextLength / 2); - } - - TXT_seriallog.SelectionStart = TXT_seriallog.Text.Length; - - TXT_seriallog.ScrollToCaret(); - - TXT_seriallog.Refresh(); - - }); - - - + TXT_seriallog.Text = TXT_seriallog.Text.Substring(TXT_seriallog.TextLength / 2); } + + TXT_seriallog.SelectionStart = TXT_seriallog.Text.Length; + + TXT_seriallog.ScrollToCaret(); + + TXT_seriallog.Refresh(); + + }); + + + + } } Console.WriteLine("exit while"); @@ -286,17 +294,20 @@ namespace ArdupilotMega { try { + Application.DoEvents(); + line = line.Replace(", ", ","); line = line.Replace(": ", ":"); - string[] items = line.Split(',',':'); + string[] items = line.Split(',', ':'); - if (items[0].Contains("CMD")) { + if (items[0].Contains("CMD")) + { if (flightdata.Count == 0) { if (int.Parse(items[2]) <= (int)MAVLink.MAV_CMD.LAST) // wps { - PointLatLngAlt temp = new PointLatLngAlt(double.Parse(items[5],new System.Globalization.CultureInfo("en-US")) / 10000000, double.Parse(items[6],new System.Globalization.CultureInfo("en-US")) / 10000000, double.Parse(items[4],new System.Globalization.CultureInfo("en-US")) / 100, items[1].ToString()); + PointLatLngAlt temp = new PointLatLngAlt(double.Parse(items[5], new System.Globalization.CultureInfo("en-US")) / 10000000, double.Parse(items[6], new System.Globalization.CultureInfo("en-US")) / 10000000, double.Parse(items[4], new System.Globalization.CultureInfo("en-US")) / 100, items[1].ToString()); cmd.Add(temp); } } @@ -305,7 +316,7 @@ namespace ArdupilotMega { positionindex++; modelist.Add(""); // i cant be bothered doing this properly - modelist.Add(""); + modelist.Add(""); modelist[positionindex] = (items[1]); } if (items[0].Contains("GPS") && items[2] == "1" && items[4] != "0" && items[4] != "-1" && lastline != line) // check gps line and fixed status @@ -317,9 +328,9 @@ namespace ArdupilotMega if (items.Length == 11 && items[6] == "0.0000") alt = double.Parse(items[7], new System.Globalization.CultureInfo("en-US")); - - position[positionindex].Add(new Point3D(double.Parse(items[5],new System.Globalization.CultureInfo("en-US")), double.Parse(items[4],new System.Globalization.CultureInfo("en-US")), alt)); + + position[positionindex].Add(new Point3D(double.Parse(items[5], new System.Globalization.CultureInfo("en-US")), double.Parse(items[4], new System.Globalization.CultureInfo("en-US")), alt)); oldlastpos = lastpos; lastpos = (position[positionindex][position[positionindex].Count - 1]); lastline = line; @@ -355,23 +366,23 @@ namespace ArdupilotMega { if (lastpos.X != 0 && oldlastpos != lastpos) { - Data dat = new Data(); + Data dat = new Data(); - runmodel = new Model(); + runmodel = new Model(); - runmodel.Location.longitude = lastpos.X; - runmodel.Location.latitude = lastpos.Y; - runmodel.Location.altitude = lastpos.Z; + runmodel.Location.longitude = lastpos.X; + runmodel.Location.latitude = lastpos.Y; + runmodel.Location.altitude = lastpos.Z; - runmodel.Orientation.roll = double.Parse(items[1], new System.Globalization.CultureInfo("en-US")) / -100; - runmodel.Orientation.tilt = double.Parse(items[2], new System.Globalization.CultureInfo("en-US")) / -100; - runmodel.Orientation.heading = double.Parse(items[3], new System.Globalization.CultureInfo("en-US")) / 100; + runmodel.Orientation.roll = double.Parse(items[1], new System.Globalization.CultureInfo("en-US")) / -100; + runmodel.Orientation.tilt = double.Parse(items[2], new System.Globalization.CultureInfo("en-US")) / -100; + runmodel.Orientation.heading = double.Parse(items[3], new System.Globalization.CultureInfo("en-US")) / 100; - dat.model = runmodel; - dat.ctun = ctunlast; - dat.ntun = ntunlast; + dat.model = runmodel; + dat.ctun = ctunlast; + dat.ntun = ntunlast; - flightdata.Add(dat); + flightdata.Add(dat); } } catch { } @@ -443,11 +454,11 @@ namespace ArdupilotMega stylecode = colours[g % (colours.Length - 1)].ToArgb(); Style style2 = new Style(); - Color color = Color.FromArgb(0xff, (stylecode >> 16) & 0xff,(stylecode >> 8) & 0xff,(stylecode >> 0) & 0xff); - Console.WriteLine("colour " + color.ToArgb().ToString("X") + " "+ color.ToKnownColor().ToString()); + Color color = Color.FromArgb(0xff, (stylecode >> 16) & 0xff, (stylecode >> 8) & 0xff, (stylecode >> 0) & 0xff); + Console.WriteLine("colour " + color.ToArgb().ToString("X") + " " + color.ToKnownColor().ToString()); style2.Add(new LineStyle(color, 4)); - + pm.AddStyle(style2); @@ -529,22 +540,27 @@ namespace ArdupilotMega } catch { } - pmplane.Point = new KmlPoint((float)model.Location.longitude, (float)model.Location.latitude, (float)model.Location.altitude); - pmplane.Point.AltitudeMode = altmode; + try + { - Link link = new Link(); - link.href = "block_plane_0.dae"; + pmplane.Point = new KmlPoint((float)model.Location.longitude, (float)model.Location.latitude, (float)model.Location.altitude); + pmplane.Point.AltitudeMode = altmode; - model.Link = link; + Link link = new Link(); + link.href = "block_plane_0.dae"; - pmplane.Model = model; + model.Link = link; - planes.Add(pmplane); + pmplane.Model = model; + + planes.Add(pmplane); + } + catch { } // bad lat long value lastmodel = mod.model; a++; - } + } kml.Document.Add(fldr); @@ -552,7 +568,7 @@ namespace ArdupilotMega // create kmz - aka zip file - FileStream fs = File.Open(filename.Replace(".log.kml",".kmz"),FileMode.Create); + FileStream fs = File.Open(filename.Replace(".log.kml", ".kmz"), FileMode.Create); ZipOutputStream zipStream = new ZipOutputStream(fs); zipStream.SetLevel(9); //0-9, 9 being the highest level of compression zipStream.UseZip64 = UseZip64.Off; // older zipfile @@ -632,7 +648,7 @@ namespace ArdupilotMega } } - private void downloadthread(int startlognum,int endlognum) + private void downloadthread(int startlognum, int endlognum) { for (int a = startlognum; a <= endlognum; a++) { @@ -642,8 +658,9 @@ namespace ArdupilotMega System.Threading.Thread.Sleep(100); comPort.Write(a.ToString() + "\r"); status = serialstatus.Createfile; - - while (status != serialstatus.Done) { + + while (status != serialstatus.Done) + { System.Threading.Thread.Sleep(100); } @@ -660,7 +677,7 @@ namespace ArdupilotMega System.Threading.Thread.Sleep(500); comPort.Write("dump "); System.Threading.Thread.Sleep(100); - comPort.Write(a.ToString()+"\r"); + comPort.Write(a.ToString() + "\r"); status = serialstatus.Createfile; while (status != serialstatus.Done) @@ -687,6 +704,7 @@ namespace ArdupilotMega System.Threading.Thread.Sleep(500); comPort.Write("erase\r"); System.Threading.Thread.Sleep(100); + TXT_seriallog.AppendText("!!Allow 30 seconds for erase\n"); status = serialstatus.Done; } @@ -699,7 +717,7 @@ namespace ArdupilotMega openFileDialog1.Multiselect = true; try { - openFileDialog1.InitialDirectory = Path.GetDirectoryName(Application.ExecutablePath) + Path.DirectorySeparatorChar + @"logs"+ Path.DirectorySeparatorChar ; + openFileDialog1.InitialDirectory = Path.GetDirectoryName(Application.ExecutablePath) + Path.DirectorySeparatorChar + @"logs" + Path.DirectorySeparatorChar; } catch { } // incase dir doesnt exist @@ -780,7 +798,7 @@ namespace ArdupilotMega { foreach (string logfile in openFileDialog1.FileNames) { - TXT_seriallog.AppendText("\n\nProcessing " + logfile+"\n"); + TXT_seriallog.AppendText("\n\nProcessing " + logfile + "\n"); this.Refresh(); try @@ -922,4 +940,4 @@ namespace ArdupilotMega } } -} +} \ No newline at end of file diff --git a/Tools/ArdupilotMegaPlanner/MainV2.cs b/Tools/ArdupilotMegaPlanner/MainV2.cs index 95f2199f23..fc89344aea 100644 --- a/Tools/ArdupilotMegaPlanner/MainV2.cs +++ b/Tools/ArdupilotMegaPlanner/MainV2.cs @@ -321,6 +321,13 @@ namespace ArdupilotMega RichTextBox txtr = (RichTextBox)ctl; txtr.BorderStyle = BorderStyle.None; } + else if (((Type)ctl.GetType()) == typeof(CheckedListBox)) + { + ctl.BackColor = Color.FromArgb(0x43, 0x44, 0x45); + ctl.ForeColor = Color.White; + CheckedListBox txtr = (CheckedListBox)ctl; + txtr.BorderStyle = BorderStyle.None; + } else if (((Type)ctl.GetType()) == typeof(TabPage)) { ctl.BackColor = Color.FromArgb(0x26, 0x27, 0x28); //Color.FromArgb(0x43, 0x44, 0x45); @@ -682,7 +689,7 @@ namespace ArdupilotMega private void CMB_serialport_SelectedIndexChanged(object sender, EventArgs e) { comportname = CMB_serialport.Text; - if (comportname == "UDP") + if (comportname == "UDP" || comportname == "TCP") CMB_baudrate.Enabled = false; else CMB_baudrate.Enabled = true; diff --git a/Tools/ArdupilotMegaPlanner/Properties/AssemblyInfo.cs b/Tools/ArdupilotMegaPlanner/Properties/AssemblyInfo.cs index 04800efbd9..f9d0b01b3a 100644 --- a/Tools/ArdupilotMegaPlanner/Properties/AssemblyInfo.cs +++ b/Tools/ArdupilotMegaPlanner/Properties/AssemblyInfo.cs @@ -34,5 +34,5 @@ using System.Resources; // by using the '*' as shown below: // [assembly: AssemblyVersion("1.0.*")] [assembly: AssemblyVersion("1.0.0.0")] -[assembly: AssemblyFileVersion("1.0.83")] +[assembly: AssemblyFileVersion("1.0.84")] [assembly: NeutralResourcesLanguageAttribute("")] diff --git a/Tools/ArdupilotMegaPlanner/bin/Release/ArdupilotMegaPlanner.application b/Tools/ArdupilotMegaPlanner/bin/Release/ArdupilotMegaPlanner.application index 408b405505..cb43d874f2 100644 --- a/Tools/ArdupilotMegaPlanner/bin/Release/ArdupilotMegaPlanner.application +++ b/Tools/ArdupilotMegaPlanner/bin/Release/ArdupilotMegaPlanner.application @@ -11,7 +11,7 @@ - xG04b9X6TXBWirLuQOgI+3TR8H0= + sVd4w+f3LroCsyok5UsAi4Bq9eI=