mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-03 22:48:29 -04:00
218 lines
7.7 KiB
C#
218 lines
7.7 KiB
C#
|
using System;
|
|||
|
using System.Collections.Generic;
|
|||
|
using System.ComponentModel;
|
|||
|
using System.Data;
|
|||
|
using System.Drawing;
|
|||
|
using System.Text;
|
|||
|
using System.Windows.Forms;
|
|||
|
using ZedGraph;
|
|||
|
using GMap.NET;
|
|||
|
using System.Xml; // GE xml alt reader
|
|||
|
|
|||
|
namespace ArdupilotMega
|
|||
|
{
|
|||
|
public partial class ElevationProfile : Form
|
|||
|
{
|
|||
|
List<PointLatLngAlt> gelocs = new List<PointLatLngAlt>();
|
|||
|
List<PointLatLngAlt> planlocs = new List<PointLatLngAlt>();
|
|||
|
PointPairList list1 = new PointPairList();
|
|||
|
PointPairList list2 = new PointPairList();
|
|||
|
int distance = 0;
|
|||
|
double homealt = 0;
|
|||
|
|
|||
|
public ElevationProfile(List<PointLatLngAlt> locs, double homealt)
|
|||
|
{
|
|||
|
InitializeComponent();
|
|||
|
|
|||
|
planlocs = locs;
|
|||
|
|
|||
|
if (planlocs.Count <= 1)
|
|||
|
{
|
|||
|
MessageBox.Show("Please plan something first");
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
// get total distance
|
|||
|
distance = 0;
|
|||
|
PointLatLngAlt lastloc = null;
|
|||
|
foreach (PointLatLngAlt loc in planlocs)
|
|||
|
{
|
|||
|
if (lastloc != null) {
|
|||
|
distance += (int)loc.GetDistance(lastloc);
|
|||
|
}
|
|||
|
lastloc = loc;
|
|||
|
}
|
|||
|
|
|||
|
this.homealt = homealt / MainV2.cs.multiplierdist;
|
|||
|
|
|||
|
Form frm = Common.LoadingBox("Loading", "Downloading Google Earth Data");
|
|||
|
|
|||
|
gelocs = getGEAltPath(planlocs);
|
|||
|
|
|||
|
frm.Close();
|
|||
|
}
|
|||
|
|
|||
|
private void ElevationProfile_Load(object sender, EventArgs e)
|
|||
|
{
|
|||
|
if (planlocs.Count <= 1)
|
|||
|
{
|
|||
|
this.Close();
|
|||
|
return;
|
|||
|
}
|
|||
|
// GE plot
|
|||
|
double a = 0;
|
|||
|
double increment = (distance / (gelocs.Count - 1));
|
|||
|
|
|||
|
foreach (PointLatLngAlt geloc in gelocs)
|
|||
|
{
|
|||
|
list2.Add(a,geloc.Alt);
|
|||
|
|
|||
|
Console.WriteLine(geloc.Lng + "," + geloc.Lat + "," + geloc.Alt);
|
|||
|
|
|||
|
a+=increment;
|
|||
|
}
|
|||
|
// Planner Plot
|
|||
|
a=0;
|
|||
|
int count = 0;
|
|||
|
PointLatLngAlt lastloc = null;
|
|||
|
foreach (PointLatLngAlt planloc in planlocs)
|
|||
|
{
|
|||
|
if (lastloc != null)
|
|||
|
{
|
|||
|
a += planloc.GetDistance(lastloc);
|
|||
|
}
|
|||
|
|
|||
|
list1.Add(a, planloc.Alt / MainV2.cs.multiplierdist, 0, planloc.Tag); // homealt
|
|||
|
|
|||
|
lastloc = planloc;
|
|||
|
count++;
|
|||
|
}
|
|||
|
// draw graph
|
|||
|
CreateChart(zg1);
|
|||
|
}
|
|||
|
|
|||
|
List<PointLatLngAlt> getGEAltPath(List<PointLatLngAlt> list)
|
|||
|
{
|
|||
|
double alt = 0;
|
|||
|
double lat = 0;
|
|||
|
double lng = 0;
|
|||
|
|
|||
|
int pos = 0;
|
|||
|
|
|||
|
List<PointLatLngAlt> answer = new List<PointLatLngAlt>();
|
|||
|
|
|||
|
//http://code.google.com/apis/maps/documentation/elevation/
|
|||
|
//http://maps.google.com/maps/api/elevation/xml
|
|||
|
string coords = "";
|
|||
|
|
|||
|
foreach (PointLatLngAlt loc in list)
|
|||
|
{
|
|||
|
coords = coords + loc.Lat.ToString(new System.Globalization.CultureInfo("en-US")) + "," + loc.Lng.ToString(new System.Globalization.CultureInfo("en-US")) + "|";
|
|||
|
}
|
|||
|
coords = coords.Remove(coords.Length - 1);
|
|||
|
|
|||
|
if (list.Count <= 2 || coords.Length > (2048 - 256) || distance > 50000)
|
|||
|
{
|
|||
|
MessageBox.Show("To many/few WP's or to Big a Distance " + (distance/1000) + "km");
|
|||
|
return answer;
|
|||
|
}
|
|||
|
|
|||
|
try
|
|||
|
{
|
|||
|
using (XmlTextReader xmlreader = new XmlTextReader("http://maps.google.com/maps/api/elevation/xml?path=" + coords + "&samples=" + (distance / 100).ToString(new System.Globalization.CultureInfo("en-US")) + "&sensor=false"))
|
|||
|
{
|
|||
|
while (xmlreader.Read())
|
|||
|
{
|
|||
|
xmlreader.MoveToElement();
|
|||
|
switch (xmlreader.Name)
|
|||
|
{
|
|||
|
case "elevation":
|
|||
|
alt = double.Parse(xmlreader.ReadString(), new System.Globalization.CultureInfo("en-US"));
|
|||
|
Console.WriteLine("DO it " + lat + " " + lng + " " + alt);
|
|||
|
PointLatLngAlt loc = new PointLatLngAlt(lat,lng,alt,"");
|
|||
|
answer.Add(loc);
|
|||
|
pos++;
|
|||
|
break;
|
|||
|
case "lat":
|
|||
|
lat = double.Parse(xmlreader.ReadString(), new System.Globalization.CultureInfo("en-US"));
|
|||
|
break;
|
|||
|
case "lng":
|
|||
|
lng = double.Parse(xmlreader.ReadString(), new System.Globalization.CultureInfo("en-US"));
|
|||
|
break;
|
|||
|
default:
|
|||
|
break;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
catch { MessageBox.Show("Error getting GE data"); }
|
|||
|
|
|||
|
return answer;
|
|||
|
}
|
|||
|
|
|||
|
public void CreateChart(ZedGraphControl zgc)
|
|||
|
{
|
|||
|
GraphPane myPane = zgc.GraphPane;
|
|||
|
|
|||
|
// Set the titles and axis labels
|
|||
|
myPane.Title.Text = "Elevation above ground";
|
|||
|
myPane.XAxis.Title.Text = "Distance (m)";
|
|||
|
myPane.YAxis.Title.Text = "Elevation (m)";
|
|||
|
|
|||
|
LineItem myCurve;
|
|||
|
|
|||
|
myCurve = myPane.AddCurve("Planner", list1, Color.Red, SymbolType.None);
|
|||
|
myCurve = myPane.AddCurve("GE", list2, Color.Green, SymbolType.None);
|
|||
|
|
|||
|
foreach (PointPair pp in list1)
|
|||
|
{
|
|||
|
// Add a another text item to to point out a graph feature
|
|||
|
TextObj text = new TextObj((string)pp.Tag, pp.X, pp.Y);
|
|||
|
// rotate the text 90 degrees
|
|||
|
text.FontSpec.Angle = 90;
|
|||
|
text.FontSpec.FontColor = Color.White;
|
|||
|
// Align the text such that the Right-Center is at (700, 50) in user scale coordinates
|
|||
|
text.Location.AlignH = AlignH.Right;
|
|||
|
text.Location.AlignV = AlignV.Center;
|
|||
|
// Disable the border and background fill options for the text
|
|||
|
text.FontSpec.Fill.IsVisible = false;
|
|||
|
text.FontSpec.Border.IsVisible = false;
|
|||
|
myPane.GraphObjList.Add(text);
|
|||
|
}
|
|||
|
|
|||
|
// Show the x axis grid
|
|||
|
myPane.XAxis.MajorGrid.IsVisible = true;
|
|||
|
|
|||
|
myPane.XAxis.Scale.Min = 0;
|
|||
|
myPane.XAxis.Scale.Max = distance;
|
|||
|
|
|||
|
// Make the Y axis scale red
|
|||
|
myPane.YAxis.Scale.FontSpec.FontColor = Color.Red;
|
|||
|
myPane.YAxis.Title.FontSpec.FontColor = Color.Red;
|
|||
|
// turn off the opposite tics so the Y tics don't show up on the Y2 axis
|
|||
|
myPane.YAxis.MajorTic.IsOpposite = false;
|
|||
|
myPane.YAxis.MinorTic.IsOpposite = false;
|
|||
|
// Don't display the Y zero line
|
|||
|
myPane.YAxis.MajorGrid.IsZeroLine = true;
|
|||
|
// Align the Y axis labels so they are flush to the axis
|
|||
|
myPane.YAxis.Scale.Align = AlignP.Inside;
|
|||
|
// Manually set the axis range
|
|||
|
//myPane.YAxis.Scale.Min = -1;
|
|||
|
//myPane.YAxis.Scale.Max = 1;
|
|||
|
|
|||
|
// Fill the axis background with a gradient
|
|||
|
//myPane.Chart.Fill = new Fill(Color.White, Color.LightGray, 45.0f);
|
|||
|
|
|||
|
// Calculate the Axis Scale Ranges
|
|||
|
try
|
|||
|
{
|
|||
|
zg1.AxisChange();
|
|||
|
}
|
|||
|
catch { }
|
|||
|
|
|||
|
|
|||
|
|
|||
|
}
|
|||
|
}
|
|||
|
}
|