mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-11 02:18:29 -04:00
Merge branch 'master' of https://code.google.com/p/ardupilot-mega
This commit is contained in:
commit
87683aae93
@ -680,9 +680,6 @@
|
|||||||
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
|
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
|
||||||
</None>
|
</None>
|
||||||
<None Include="app.config" />
|
<None Include="app.config" />
|
||||||
<None Include="arducopter-fgmodel.zip">
|
|
||||||
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
|
|
||||||
</None>
|
|
||||||
<None Include="arducopter-xplane.zip">
|
<None Include="arducopter-xplane.zip">
|
||||||
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
|
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
|
||||||
</None>
|
</None>
|
||||||
|
@ -32,6 +32,8 @@ namespace ArdupilotMega
|
|||||||
public Camera()
|
public Camera()
|
||||||
{
|
{
|
||||||
InitializeComponent();
|
InitializeComponent();
|
||||||
|
|
||||||
|
doCalc();
|
||||||
}
|
}
|
||||||
|
|
||||||
void doCalc()
|
void doCalc()
|
||||||
|
@ -48,7 +48,9 @@ namespace ArdupilotMega
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public class GMapMarkerRect : GMapMarker
|
public class GMapMarkerRect : GMapMarker
|
||||||
{
|
{
|
||||||
public Pen Pen;
|
public Pen Pen = new Pen(Brushes.White, 2);
|
||||||
|
|
||||||
|
public Color Color { get { return Pen.Color; } set { Pen.Color = value; } }
|
||||||
|
|
||||||
public GMapMarker InnerMarker;
|
public GMapMarker InnerMarker;
|
||||||
|
|
||||||
@ -58,8 +60,6 @@ namespace ArdupilotMega
|
|||||||
public GMapMarkerRect(PointLatLng p)
|
public GMapMarkerRect(PointLatLng p)
|
||||||
: base(p)
|
: base(p)
|
||||||
{
|
{
|
||||||
Pen = new Pen(Brushes.White, 2);
|
|
||||||
|
|
||||||
Pen.DashStyle = DashStyle.Dash;
|
Pen.DashStyle = DashStyle.Dash;
|
||||||
|
|
||||||
// do not forget set Size of the marker
|
// do not forget set Size of the marker
|
||||||
@ -75,9 +75,9 @@ namespace ArdupilotMega
|
|||||||
if (wprad == 0 || MainMap == null)
|
if (wprad == 0 || MainMap == null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
// undo autochange in mouse over
|
||||||
if (Pen.Color == Color.Blue)
|
if (Pen.Color == Color.Blue)
|
||||||
Pen.Color = Color.White;
|
Pen.Color = Color.White;
|
||||||
|
|
||||||
|
|
||||||
double width = (MainMap.Manager.GetDistance(MainMap.FromLocalToLatLng(0, 0), MainMap.FromLocalToLatLng(MainMap.Width, 0)) * 1000.0);
|
double width = (MainMap.Manager.GetDistance(MainMap.FromLocalToLatLng(0, 0), MainMap.FromLocalToLatLng(MainMap.Width, 0)) * 1000.0);
|
||||||
double height = (MainMap.Manager.GetDistance(MainMap.FromLocalToLatLng(0, 0), MainMap.FromLocalToLatLng(MainMap.Height, 0)) * 1000.0);
|
double height = (MainMap.Manager.GetDistance(MainMap.FromLocalToLatLng(0, 0), MainMap.FromLocalToLatLng(MainMap.Height, 0)) * 1000.0);
|
||||||
@ -177,6 +177,7 @@ namespace ArdupilotMega
|
|||||||
public double Lng = 0;
|
public double Lng = 0;
|
||||||
public double Alt = 0;
|
public double Alt = 0;
|
||||||
public string Tag = "";
|
public string Tag = "";
|
||||||
|
public Color color = Color.White;
|
||||||
|
|
||||||
public PointLatLngAlt(double lat, double lng, double alt, string tag)
|
public PointLatLngAlt(double lat, double lng, double alt, string tag)
|
||||||
{
|
{
|
||||||
@ -263,7 +264,43 @@ namespace ArdupilotMega
|
|||||||
CIRCLE = 7,
|
CIRCLE = 7,
|
||||||
POSITION = 8
|
POSITION = 8
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static void linearRegression()
|
||||||
|
{
|
||||||
|
double[] values = { 4.8, 4.8, 4.5, 3.9, 4.4, 3.6, 3.6, 2.9, 3.5, 3.0, 2.5, 2.2, 2.6, 2.1, 2.2 };
|
||||||
|
|
||||||
|
double xAvg = 0;
|
||||||
|
double yAvg = 0;
|
||||||
|
|
||||||
|
for (int x = 0; x < values.Length; x++)
|
||||||
|
{
|
||||||
|
xAvg += x;
|
||||||
|
yAvg += values[x];
|
||||||
|
}
|
||||||
|
|
||||||
|
xAvg = xAvg / values.Length;
|
||||||
|
yAvg = yAvg / values.Length;
|
||||||
|
|
||||||
|
|
||||||
|
double v1 = 0;
|
||||||
|
double v2 = 0;
|
||||||
|
|
||||||
|
for (int x = 0; x < values.Length; x++)
|
||||||
|
{
|
||||||
|
v1 += (x - xAvg) * (values[x] - yAvg);
|
||||||
|
v2 += Math.Pow(x - xAvg, 2);
|
||||||
|
}
|
||||||
|
|
||||||
|
double a = v1 / v2;
|
||||||
|
double b = yAvg - a * xAvg;
|
||||||
|
|
||||||
|
Console.WriteLine("y = ax + b");
|
||||||
|
Console.WriteLine("a = {0}, the slope of the trend line.", Math.Round(a, 2));
|
||||||
|
Console.WriteLine("b = {0}, the intercept of the trend line.", Math.Round(b, 2));
|
||||||
|
|
||||||
|
Console.ReadLine();
|
||||||
|
}
|
||||||
|
|
||||||
#if MAVLINK10
|
#if MAVLINK10
|
||||||
|
|
||||||
public static bool translateMode(string modein, ref MAVLink.__mavlink_set_mode_t mode)
|
public static bool translateMode(string modein, ref MAVLink.__mavlink_set_mode_t mode)
|
||||||
|
@ -432,7 +432,7 @@ namespace ArdupilotMega.GCSViews
|
|||||||
{
|
{
|
||||||
if (plla == null || plla.Lng == 0 || plla.Lat == 0)
|
if (plla == null || plla.Lng == 0 || plla.Lat == 0)
|
||||||
break;
|
break;
|
||||||
addpolygonmarker(plla.Tag, plla.Lng, plla.Lat, (int)plla.Alt);
|
addpolygonmarker(plla.Tag, plla.Lng, plla.Lat, (int)plla.Alt,plla.color);
|
||||||
}
|
}
|
||||||
|
|
||||||
RegeneratePolygon();
|
RegeneratePolygon();
|
||||||
@ -525,7 +525,7 @@ namespace ArdupilotMega.GCSViews
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addpolygonmarker(string tag, double lng, double lat, int alt)
|
private void addpolygonmarker(string tag, double lng, double lat, int alt, Color? color)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
@ -537,13 +537,18 @@ namespace ArdupilotMega.GCSViews
|
|||||||
|
|
||||||
GMapMarkerRect mBorders = new GMapMarkerRect(point);
|
GMapMarkerRect mBorders = new GMapMarkerRect(point);
|
||||||
{
|
{
|
||||||
mBorders.InnerMarker = m;
|
|
||||||
mBorders.MainMap = gMapControl1;
|
mBorders.InnerMarker = m;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
mBorders.wprad = (int)float.Parse(ArdupilotMega.MainV2.config["TXT_WPRad"].ToString());
|
mBorders.wprad = (int)float.Parse(ArdupilotMega.MainV2.config["TXT_WPRad"].ToString());
|
||||||
}
|
}
|
||||||
catch { }
|
catch { }
|
||||||
|
mBorders.MainMap = gMapControl1;
|
||||||
|
if (color.HasValue)
|
||||||
|
{
|
||||||
|
mBorders.Color = color.Value;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
polygons.Markers.Add(m);
|
polygons.Markers.Add(m);
|
||||||
|
@ -884,7 +884,7 @@ namespace ArdupilotMega.GCSViews
|
|||||||
/// <param name="lng"></param>
|
/// <param name="lng"></param>
|
||||||
/// <param name="lat"></param>
|
/// <param name="lat"></param>
|
||||||
/// <param name="alt"></param>
|
/// <param name="alt"></param>
|
||||||
private void addpolygonmarker(string tag, double lng, double lat, int alt)
|
private void addpolygonmarker(string tag, double lng, double lat, int alt, Color? color)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
@ -900,6 +900,10 @@ namespace ArdupilotMega.GCSViews
|
|||||||
mBorders.InnerMarker = m;
|
mBorders.InnerMarker = m;
|
||||||
mBorders.wprad = (int)float.Parse(TXT_WPRad.Text);
|
mBorders.wprad = (int)float.Parse(TXT_WPRad.Text);
|
||||||
mBorders.MainMap = MainMap;
|
mBorders.MainMap = MainMap;
|
||||||
|
if (color.HasValue)
|
||||||
|
{
|
||||||
|
mBorders.Color = color.Value;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
objects.Markers.Add(m);
|
objects.Markers.Add(m);
|
||||||
@ -955,7 +959,7 @@ namespace ArdupilotMega.GCSViews
|
|||||||
if (objects != null) // during startup
|
if (objects != null) // during startup
|
||||||
{
|
{
|
||||||
pointlist.Add(new PointLatLngAlt(double.Parse(TXT_homelat.Text), double.Parse(TXT_homelng.Text), (int)double.Parse(TXT_homealt.Text), "Home"));
|
pointlist.Add(new PointLatLngAlt(double.Parse(TXT_homelat.Text), double.Parse(TXT_homelng.Text), (int)double.Parse(TXT_homealt.Text), "Home"));
|
||||||
addpolygonmarker("Home", double.Parse(TXT_homelng.Text), double.Parse(TXT_homelat.Text), 0);
|
addpolygonmarker("Home", double.Parse(TXT_homelng.Text), double.Parse(TXT_homelat.Text), 0, null);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -1029,8 +1033,14 @@ namespace ArdupilotMega.GCSViews
|
|||||||
if (cell4 == "?" || cell3 == "?")
|
if (cell4 == "?" || cell3 == "?")
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
pointlist.Add(new PointLatLngAlt(double.Parse(cell3), double.Parse(cell4), (int)double.Parse(cell2) + homealt, (a + 1).ToString()));
|
|
||||||
addpolygonmarker((a + 1).ToString(), double.Parse(cell4), double.Parse(cell3), (int)double.Parse(cell2));
|
if (command == (byte)MAVLink.MAV_CMD.LOITER_TIME || command == (byte)MAVLink.MAV_CMD.LOITER_TURNS || command == (byte)MAVLink.MAV_CMD.LOITER_UNLIM) {
|
||||||
|
pointlist.Add(new PointLatLngAlt(double.Parse(cell3), double.Parse(cell4), (int)double.Parse(cell2) + homealt, (a + 1).ToString()){ color = Color.LightBlue });
|
||||||
|
addpolygonmarker((a + 1).ToString(), double.Parse(cell4), double.Parse(cell3), (int)double.Parse(cell2) , Color.LightBlue);
|
||||||
|
} else {
|
||||||
|
pointlist.Add(new PointLatLngAlt(double.Parse(cell3), double.Parse(cell4), (int)double.Parse(cell2) + homealt, (a + 1).ToString()));
|
||||||
|
addpolygonmarker((a + 1).ToString(), double.Parse(cell4), double.Parse(cell3), (int)double.Parse(cell2) ,null);
|
||||||
|
}
|
||||||
|
|
||||||
avglong += double.Parse(Commands.Rows[a].Cells[Lon.Index].Value.ToString());
|
avglong += double.Parse(Commands.Rows[a].Cells[Lon.Index].Value.ToString());
|
||||||
avglat += double.Parse(Commands.Rows[a].Cells[Lat.Index].Value.ToString());
|
avglat += double.Parse(Commands.Rows[a].Cells[Lat.Index].Value.ToString());
|
||||||
|
@ -257,14 +257,18 @@ namespace ArdupilotMega.GCSViews
|
|||||||
{
|
{
|
||||||
System.Diagnostics.ProcessStartInfo _procstartinfo = new System.Diagnostics.ProcessStartInfo();
|
System.Diagnostics.ProcessStartInfo _procstartinfo = new System.Diagnostics.ProcessStartInfo();
|
||||||
_procstartinfo.WorkingDirectory = Path.GetDirectoryName(Application.ExecutablePath);
|
_procstartinfo.WorkingDirectory = Path.GetDirectoryName(Application.ExecutablePath);
|
||||||
_procstartinfo.Arguments = "--realtime --suspend --nice --simulation-rate=50 --logdirectivefile=jsbsim/fgout.xml --script=jsbsim/rascal_test.xml";
|
_procstartinfo.Arguments = "--realtime --suspend --nice --simulation-rate=1000 --logdirectivefile=jsbsim/fgout.xml --script=jsbsim/rascal_test.xml";
|
||||||
_procstartinfo.FileName = "JSBSim.exe";
|
_procstartinfo.FileName = "JSBSim.exe";
|
||||||
// Path.GetDirectoryName(Application.ExecutablePath) + Path.DirectorySeparatorChar +
|
// Path.GetDirectoryName(Application.ExecutablePath) + Path.DirectorySeparatorChar +
|
||||||
|
|
||||||
_procstartinfo.UseShellExecute = true;
|
_procstartinfo.UseShellExecute = true;
|
||||||
|
//_procstartinfo.RedirectStandardOutput = true;
|
||||||
|
|
||||||
|
|
||||||
System.Diagnostics.Process.Start(_procstartinfo);
|
System.Diagnostics.Process.Start(_procstartinfo);
|
||||||
|
|
||||||
|
System.Threading.Thread.Sleep(2000);
|
||||||
|
|
||||||
SITLSEND = new UdpClient(simIP, 5501);
|
SITLSEND = new UdpClient(simIP, 5501);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -543,11 +547,15 @@ namespace ArdupilotMega.GCSViews
|
|||||||
udpdata = new byte[udpdata.Length];
|
udpdata = new byte[udpdata.Length];
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
int recv = SimulatorRECV.ReceiveFrom(udpdata, ref Remote);
|
while (SimulatorRECV.Available > 0)
|
||||||
|
{
|
||||||
|
int recv = SimulatorRECV.ReceiveFrom(udpdata, ref Remote);
|
||||||
|
|
||||||
RECVprocess(udpdata, recv, comPort);
|
RECVprocess(udpdata, recv, comPort);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (Exception ex) { //OutputLog.AppendText("Xplanes Data Problem - You need DATA IN/OUT 3, 4, 17, 18, 19, 20\n" + ex.Message + "\n");
|
||||||
}
|
}
|
||||||
catch (Exception ex) { OutputLog.AppendText("Xplanes Data Problem - You need DATA IN/OUT 3, 4, 17, 18, 19, 20\n" + ex.Message + "\n"); }
|
|
||||||
}
|
}
|
||||||
if (MavLink != null && MavLink.Client != null && MavLink.Client.Connected && MavLink.Available > 0)
|
if (MavLink != null && MavLink.Client != null && MavLink.Client.Connected && MavLink.Available > 0)
|
||||||
{
|
{
|
||||||
@ -583,7 +591,7 @@ namespace ArdupilotMega.GCSViews
|
|||||||
|
|
||||||
if (hzcounttime.Second != DateTime.Now.Second)
|
if (hzcounttime.Second != DateTime.Now.Second)
|
||||||
{
|
{
|
||||||
//Console.WriteLine("SIM hz {0}", hzcount);
|
Console.WriteLine("SIM hz {0}", hzcount);
|
||||||
hzcount = 0;
|
hzcount = 0;
|
||||||
hzcounttime = DateTime.Now;
|
hzcounttime = DateTime.Now;
|
||||||
}
|
}
|
||||||
@ -619,18 +627,23 @@ namespace ArdupilotMega.GCSViews
|
|||||||
{
|
{
|
||||||
JSBSimSEND = new TcpClient();
|
JSBSimSEND = new TcpClient();
|
||||||
JSBSimSEND.Client.NoDelay = true;
|
JSBSimSEND.Client.NoDelay = true;
|
||||||
JSBSimSEND.Connect(simIP, simPort);
|
JSBSimSEND.Connect("127.0.0.1", simPort);
|
||||||
OutputLog.AppendText("Sending to port TCP " + simPort + " (planner->sim)\n");
|
OutputLog.AppendText("Sending to port TCP " + simPort + " (planner->sim)\n");
|
||||||
|
|
||||||
System.Threading.Thread.Sleep(2000);
|
//JSBSimSEND.Client.Send(System.Text.Encoding.ASCII.GetBytes("set position/h-agl-ft 0\r\n"));
|
||||||
|
|
||||||
JSBSimSEND.Client.Send(System.Text.Encoding.ASCII.GetBytes("info\n"));
|
JSBSimSEND.Client.Send(System.Text.Encoding.ASCII.GetBytes("set position/lat-gc-deg " + MainV2.HomeLocation.Lat + "\r\n"));
|
||||||
|
JSBSimSEND.Client.Send(System.Text.Encoding.ASCII.GetBytes("set position/long-gc-deg " + MainV2.HomeLocation.Lng + "\r\n"));
|
||||||
|
|
||||||
JSBSimSEND.Client.Send(System.Text.Encoding.ASCII.GetBytes("set attitude/phi-rad 0\n"));
|
JSBSimSEND.Client.Send(System.Text.Encoding.ASCII.GetBytes("set attitude/phi-rad 0\r\n"));
|
||||||
JSBSimSEND.Client.Send(System.Text.Encoding.ASCII.GetBytes("set attitude/theta-rad 0\n"));
|
JSBSimSEND.Client.Send(System.Text.Encoding.ASCII.GetBytes("set attitude/theta-rad 0\r\n"));
|
||||||
JSBSimSEND.Client.Send(System.Text.Encoding.ASCII.GetBytes("resume\n"));
|
JSBSimSEND.Client.Send(System.Text.Encoding.ASCII.GetBytes("set attitude/psi-rad 0\r\n"));
|
||||||
|
|
||||||
|
JSBSimSEND.Client.Send(System.Text.Encoding.ASCII.GetBytes("info\r\n"));
|
||||||
|
|
||||||
|
JSBSimSEND.Client.Send(System.Text.Encoding.ASCII.GetBytes("resume\r\n"));
|
||||||
}
|
}
|
||||||
catch { }
|
catch { Console.WriteLine("JSB console fail"); }
|
||||||
}
|
}
|
||||||
|
|
||||||
private void SetupUDPXplanes()
|
private void SetupUDPXplanes()
|
||||||
@ -1125,30 +1138,37 @@ namespace ArdupilotMega.GCSViews
|
|||||||
|
|
||||||
if (RAD_JSBSim.Checked && chkSensor.Checked)
|
if (RAD_JSBSim.Checked && chkSensor.Checked)
|
||||||
{
|
{
|
||||||
|
byte[] buffer = new byte[1500];
|
||||||
|
while (JSBSimSEND.Client.Available > 5)
|
||||||
|
{
|
||||||
|
int read = JSBSimSEND.Client.Receive(buffer);
|
||||||
|
}
|
||||||
|
|
||||||
byte[] sitlout = new byte[16 * 8 + 1 * 4]; // 16 * double + 1 * int
|
byte[] sitlout = new byte[16 * 8 + 1 * 4]; // 16 * double + 1 * int
|
||||||
int a = 0;
|
int a = 0;
|
||||||
|
|
||||||
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.latitude), a, sitlout, a, 8);
|
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.latitude * rad2deg), a, sitlout, a, 8);
|
||||||
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.longitude), 0, sitlout, a += 8, 8);
|
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.longitude * rad2deg), 0, sitlout, a += 8, 8);
|
||||||
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.altitude), 0, sitlout, a += 8, 8);
|
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.altitude), 0, sitlout, a += 8, 8);
|
||||||
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.psi), 0, sitlout, a += 8, 8);
|
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.psi * rad2deg), 0, sitlout, a += 8, 8);
|
||||||
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.v_north), 0, sitlout, a += 8, 8);
|
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.v_north * ft2m), 0, sitlout, a += 8, 8);
|
||||||
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.v_east), 0, sitlout, a += 8, 8);
|
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.v_east * ft2m), 0, sitlout, a += 8, 8);
|
||||||
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.A_X_pilot), 0, sitlout, a += 8, 8);
|
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.A_X_pilot * ft2m), 0, sitlout, a += 8, 8);
|
||||||
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.A_Y_pilot), 0, sitlout, a += 8, 8);
|
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.A_Y_pilot * ft2m), 0, sitlout, a += 8, 8);
|
||||||
|
|
||||||
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.A_Z_pilot), 0, sitlout, a += 8, 8);
|
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.A_Z_pilot * ft2m), 0, sitlout, a += 8, 8);
|
||||||
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.phidot), 0, sitlout, a += 8, 8);
|
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.phidot * rad2deg), 0, sitlout, a += 8, 8);
|
||||||
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.thetadot), 0, sitlout, a += 8, 8);
|
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.thetadot * rad2deg), 0, sitlout, a += 8, 8);
|
||||||
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.psidot), 0, sitlout, a += 8, 8);
|
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.psidot * rad2deg), 0, sitlout, a += 8, 8);
|
||||||
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.phi), 0, sitlout, a += 8, 8);
|
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.phi * rad2deg), 0, sitlout, a += 8, 8);
|
||||||
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.theta), 0, sitlout, a += 8, 8);
|
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.theta * rad2deg), 0, sitlout, a += 8, 8);
|
||||||
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.psi), 0, sitlout, a += 8, 8);
|
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.psi * rad2deg), 0, sitlout, a += 8, 8);
|
||||||
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.vcas), 0, sitlout, a += 8, 8);
|
Array.Copy(BitConverter.GetBytes((double)lastfdmdata.vcas * ft2m), 0, sitlout, a += 8, 8);
|
||||||
|
|
||||||
|
// Console.WriteLine(lastfdmdata.theta);
|
||||||
|
|
||||||
Array.Copy(BitConverter.GetBytes((int)0x4c56414e), 0, sitlout, a += 8, 4);
|
Array.Copy(BitConverter.GetBytes((int)0x4c56414e), 0, sitlout, a += 8, 4);
|
||||||
|
|
||||||
SITLSEND.Send(sitlout, sitlout.Length);
|
SITLSEND.Send(sitlout, sitlout.Length);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
|
@ -277,8 +277,8 @@ namespace hud
|
|||||||
if (DateTime.Now.Second != countdate.Second)
|
if (DateTime.Now.Second != countdate.Second)
|
||||||
{
|
{
|
||||||
countdate = DateTime.Now;
|
countdate = DateTime.Now;
|
||||||
//Console.WriteLine("HUD " + count + " hz drawtime " + (huddrawtime / count) + " gl " + opengl);
|
Console.WriteLine("HUD " + count + " hz drawtime " + (huddrawtime / count) + " gl " + opengl);
|
||||||
if ((huddrawtime / count) > 500)
|
if ((huddrawtime / count) > 1000)
|
||||||
opengl = false;
|
opengl = false;
|
||||||
|
|
||||||
count = 0;
|
count = 0;
|
||||||
|
@ -121,10 +121,11 @@ namespace ArdupilotMega
|
|||||||
{
|
{
|
||||||
MethodInvoker m = delegate()
|
MethodInvoker m = delegate()
|
||||||
{
|
{
|
||||||
CHK_logs.Items.Clear();
|
//CHK_logs.Items.Clear();
|
||||||
for (int a = 1; a <= logcount; a++)
|
//for (int a = 1; a <= logcount; a++)
|
||||||
|
if (!CHK_logs.Items.Contains(logcount))
|
||||||
{
|
{
|
||||||
CHK_logs.Items.Add(a);
|
CHK_logs.Items.Add(logcount);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
try
|
try
|
||||||
@ -189,23 +190,8 @@ namespace ArdupilotMega
|
|||||||
if (line.Contains("reset to FLY") || line.Contains("interactive setup") || line.Contains("CLI:") || line.Contains("Ardu"))
|
if (line.Contains("reset to FLY") || line.Contains("interactive setup") || line.Contains("CLI:") || line.Contains("Ardu"))
|
||||||
{
|
{
|
||||||
comPort.Write("logs\r");
|
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;
|
status = serialstatus.Done;
|
||||||
}
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case serialstatus.Closefile:
|
case serialstatus.Closefile:
|
||||||
sw.Close();
|
sw.Close();
|
||||||
@ -252,6 +238,21 @@ namespace ArdupilotMega
|
|||||||
break;
|
break;
|
||||||
case serialstatus.Done:
|
case serialstatus.Done:
|
||||||
//
|
//
|
||||||
|
if (line.Contains("start") && line.Contains("end"))
|
||||||
|
{
|
||||||
|
Regex regex2 = new Regex(@"^Log ([0-9]+),", RegexOptions.IgnoreCase);
|
||||||
|
if (regex2.IsMatch(line))
|
||||||
|
{
|
||||||
|
MatchCollection matchs = regex2.Matches(line);
|
||||||
|
logcount = int.Parse(matchs[0].Groups[1].Value);
|
||||||
|
genchkcombo(logcount);
|
||||||
|
//status = serialstatus.Done;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (line.Contains("No logs"))
|
||||||
|
{
|
||||||
|
status = serialstatus.Done;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case serialstatus.Reading:
|
case serialstatus.Reading:
|
||||||
if (line.Contains("packets read") || line.Contains("Done") || line.Contains("logs enabled"))
|
if (line.Contains("packets read") || line.Contains("Done") || line.Contains("logs enabled"))
|
||||||
@ -774,6 +775,7 @@ namespace ArdupilotMega
|
|||||||
System.Threading.Thread.Sleep(100);
|
System.Threading.Thread.Sleep(100);
|
||||||
TXT_seriallog.AppendText("!!Allow 30 seconds for erase\n");
|
TXT_seriallog.AppendText("!!Allow 30 seconds for erase\n");
|
||||||
status = serialstatus.Done;
|
status = serialstatus.Done;
|
||||||
|
CHK_logs.Items.Clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void BUT_redokml_Click(object sender, EventArgs e)
|
private void BUT_redokml_Click(object sender, EventArgs e)
|
||||||
|
@ -1599,7 +1599,7 @@ namespace ArdupilotMega
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (loadinglabel != null)
|
if (loadinglabel != null)
|
||||||
loadinglabel.Text = "Starting Updater";
|
updatelabel(loadinglabel,"Starting Updater");
|
||||||
Console.WriteLine("Start " + P.StartInfo.FileName + " with " + P.StartInfo.Arguments);
|
Console.WriteLine("Start " + P.StartInfo.FileName + " with " + P.StartInfo.Arguments);
|
||||||
P.Start();
|
P.Start();
|
||||||
try
|
try
|
||||||
@ -1746,6 +1746,9 @@ namespace ArdupilotMega
|
|||||||
if (loadinglabel != null)
|
if (loadinglabel != null)
|
||||||
updatelabel(loadinglabel, "Getting " + file);
|
updatelabel(loadinglabel, "Getting " + file);
|
||||||
|
|
||||||
|
// from head
|
||||||
|
long bytes = response.ContentLength;
|
||||||
|
|
||||||
// Create a request using a URL that can receive a post.
|
// Create a request using a URL that can receive a post.
|
||||||
request = WebRequest.Create(baseurl + file);
|
request = WebRequest.Create(baseurl + file);
|
||||||
// Set the Method property of the request to POST.
|
// Set the Method property of the request to POST.
|
||||||
@ -1756,8 +1759,7 @@ namespace ArdupilotMega
|
|||||||
Console.WriteLine(((HttpWebResponse)response).StatusDescription);
|
Console.WriteLine(((HttpWebResponse)response).StatusDescription);
|
||||||
// Get the stream containing content returned by the server.
|
// Get the stream containing content returned by the server.
|
||||||
dataStream = response.GetResponseStream();
|
dataStream = response.GetResponseStream();
|
||||||
|
|
||||||
long bytes = response.ContentLength;
|
|
||||||
long contlen = bytes;
|
long contlen = bytes;
|
||||||
|
|
||||||
byte[] buf1 = new byte[1024];
|
byte[] buf1 = new byte[1024];
|
||||||
@ -1776,7 +1778,7 @@ namespace ArdupilotMega
|
|||||||
if (dt.Second != DateTime.Now.Second)
|
if (dt.Second != DateTime.Now.Second)
|
||||||
{
|
{
|
||||||
if (loadinglabel != null)
|
if (loadinglabel != null)
|
||||||
updatelabel(loadinglabel, "Getting " + file + ": " + Math.Abs(bytes) + " bytes");//(((double)(contlen - bytes) / (double)contlen) * 100).ToString("0.0") + "%";
|
updatelabel(loadinglabel, "Getting " + file + ": " + (((double)(contlen - bytes) / (double)contlen) * 100).ToString("0.0") + "%"); //+ Math.Abs(bytes) + " bytes");
|
||||||
dt = DateTime.Now;
|
dt = DateTime.Now;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -26,6 +26,8 @@ namespace ArdupilotMega
|
|||||||
|
|
||||||
//MessageBox.Show("NOTE: This version may break advanced mission scripting");
|
//MessageBox.Show("NOTE: This version may break advanced mission scripting");
|
||||||
|
|
||||||
|
//Common.linearRegression();
|
||||||
|
|
||||||
Application.EnableVisualStyles();
|
Application.EnableVisualStyles();
|
||||||
Application.SetCompatibleTextRenderingDefault(false);
|
Application.SetCompatibleTextRenderingDefault(false);
|
||||||
try
|
try
|
||||||
|
@ -34,5 +34,5 @@ using System.Resources;
|
|||||||
// by using the '*' as shown below:
|
// by using the '*' as shown below:
|
||||||
// [assembly: AssemblyVersion("1.0.*")]
|
// [assembly: AssemblyVersion("1.0.*")]
|
||||||
[assembly: AssemblyVersion("1.0.0.0")]
|
[assembly: AssemblyVersion("1.0.0.0")]
|
||||||
[assembly: AssemblyFileVersion("1.1.18")]
|
[assembly: AssemblyFileVersion("1.1.19")]
|
||||||
[assembly: NeutralResourcesLanguageAttribute("")]
|
[assembly: NeutralResourcesLanguageAttribute("")]
|
||||||
|
@ -55,14 +55,14 @@
|
|||||||
<contact type="BOGEY" name="LEFT_MLG">
|
<contact type="BOGEY" name="LEFT_MLG">
|
||||||
<location unit="IN">
|
<location unit="IN">
|
||||||
<x> 33.1 </x>
|
<x> 33.1 </x>
|
||||||
<y> -9.9 </y>
|
<y> -12.9 </y>
|
||||||
<z> -13.1 </z>
|
<z> -13.1 </z>
|
||||||
</location>
|
</location>
|
||||||
<static_friction> 1.0 </static_friction>
|
<static_friction> 0.8 </static_friction>
|
||||||
<dynamic_friction> 0.8 </dynamic_friction>
|
<dynamic_friction> 0.5 </dynamic_friction>
|
||||||
<rolling_friction> 0.02 </rolling_friction>
|
<rolling_friction> 0.1 </rolling_friction>
|
||||||
<spring_coeff unit="LBS/FT"> 12 </spring_coeff>
|
<spring_coeff unit="LBS/FT"> 480 </spring_coeff>
|
||||||
<damping_coeff unit="LBS/FT/SEC"> 1 </damping_coeff>
|
<damping_coeff unit="LBS/FT/SEC"> 100 </damping_coeff>
|
||||||
<max_steer unit="DEG"> 0.0 </max_steer>
|
<max_steer unit="DEG"> 0.0 </max_steer>
|
||||||
<brake_group> NONE </brake_group>
|
<brake_group> NONE </brake_group>
|
||||||
<retractable>0</retractable>
|
<retractable>0</retractable>
|
||||||
@ -70,14 +70,14 @@
|
|||||||
<contact type="BOGEY" name="RIGHT_MLG">
|
<contact type="BOGEY" name="RIGHT_MLG">
|
||||||
<location unit="IN">
|
<location unit="IN">
|
||||||
<x> 33.1 </x>
|
<x> 33.1 </x>
|
||||||
<y> 9.9 </y>
|
<y> 12.9 </y>
|
||||||
<z> -13.1 </z>
|
<z> -13.1 </z>
|
||||||
</location>
|
</location>
|
||||||
<static_friction> 1.0 </static_friction>
|
<static_friction> 0.8 </static_friction>
|
||||||
<dynamic_friction> 0.8 </dynamic_friction>
|
<dynamic_friction> 0.5 </dynamic_friction>
|
||||||
<rolling_friction> 0.02 </rolling_friction>
|
<rolling_friction> 0.1 </rolling_friction>
|
||||||
<spring_coeff unit="LBS/FT"> 12 </spring_coeff>
|
<spring_coeff unit="LBS/FT"> 480 </spring_coeff>
|
||||||
<damping_coeff unit="LBS/FT/SEC"> 1 </damping_coeff>
|
<damping_coeff unit="LBS/FT/SEC"> 100 </damping_coeff>
|
||||||
<max_steer unit="DEG"> 0.0 </max_steer>
|
<max_steer unit="DEG"> 0.0 </max_steer>
|
||||||
<brake_group> NONE </brake_group>
|
<brake_group> NONE </brake_group>
|
||||||
<retractable>0</retractable>
|
<retractable>0</retractable>
|
||||||
@ -86,18 +86,13 @@
|
|||||||
<location unit="IN">
|
<location unit="IN">
|
||||||
<x> 68.9 </x>
|
<x> 68.9 </x>
|
||||||
<y> 0 </y>
|
<y> 0 </y>
|
||||||
<!-- this sets the position of the tail wheel much
|
<z> -3 </z>
|
||||||
lower than it should be, so that we start with
|
|
||||||
zero pitch, which makes for a better simulation
|
|
||||||
of ground start on the accelerometers/gyros in
|
|
||||||
ArduPlane -->
|
|
||||||
<z> -7.8 </z>
|
|
||||||
</location>
|
</location>
|
||||||
<static_friction> 1.0 </static_friction>
|
<static_friction> 8.0 </static_friction>
|
||||||
<dynamic_friction> 0.8 </dynamic_friction>
|
<dynamic_friction> 5.0 </dynamic_friction>
|
||||||
<rolling_friction> 0.02 </rolling_friction>
|
<rolling_friction> 0.1 </rolling_friction>
|
||||||
<spring_coeff unit="LBS/FT"> 12 </spring_coeff>
|
<spring_coeff unit="LBS/FT"> 480 </spring_coeff>
|
||||||
<damping_coeff unit="LBS/FT/SEC"> 1 </damping_coeff>
|
<damping_coeff unit="LBS/FT/SEC"> 100 </damping_coeff>
|
||||||
<max_steer unit="DEG"> 360.0 </max_steer>
|
<max_steer unit="DEG"> 360.0 </max_steer>
|
||||||
<brake_group> NONE </brake_group>
|
<brake_group> NONE </brake_group>
|
||||||
<retractable>0</retractable>
|
<retractable>0</retractable>
|
||||||
|
@ -123,16 +123,18 @@ dynamics model, and external 3D model.
|
|||||||
<script>
|
<script>
|
||||||
setlistener("/sim/signals/fdm-initialized", func {
|
setlistener("/sim/signals/fdm-initialized", func {
|
||||||
var left = screen.display.new(20, 10);
|
var left = screen.display.new(20, 10);
|
||||||
left.add("/surface-positions/right-aileron-pos-norm");
|
left.add("/apm/aileron");
|
||||||
left.add("/surface-positions/elevator-pos-norm");
|
left.add("/apm/elevator");
|
||||||
left.add("/surface-positions/rudder-pos-norm");
|
left.add("/apm/rudder");
|
||||||
left.add("/engines/engine/rpm");
|
left.add("/apm/throttle");
|
||||||
|
|
||||||
var right = screen.display.new(-250, 20);
|
var right = screen.display.new(-250, 20);
|
||||||
right.add("/orientation/pitch-deg");
|
right.add("/apm/pitch");
|
||||||
right.add("/orientation/roll-deg");
|
right.add("/apm/roll");
|
||||||
right.add("/position/altitude-agl-ft");
|
right.add("/apm/altitude");
|
||||||
right.add("/velocities/airspeed-kt");
|
right.add("/apm/heading");
|
||||||
|
right.add("/apm/airspeed");
|
||||||
|
right.add("/apm/groundspeed");
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
</rascal>
|
</rascal>
|
||||||
|
@ -86,7 +86,7 @@
|
|||||||
<location unit="IN">
|
<location unit="IN">
|
||||||
<x> 68.9 </x>
|
<x> 68.9 </x>
|
||||||
<y> 0 </y>
|
<y> 0 </y>
|
||||||
<z> -6.6 </z>
|
<z> -3 </z>
|
||||||
</location>
|
</location>
|
||||||
<static_friction> 0.8 </static_friction>
|
<static_friction> 0.8 </static_friction>
|
||||||
<dynamic_friction> 0.5 </dynamic_friction>
|
<dynamic_friction> 0.5 </dynamic_friction>
|
||||||
|
@ -38,3 +38,35 @@ var update_airdata = func( dt ) {
|
|||||||
|
|
||||||
setprop("/accelerations/airspeed-ktps", accel_filt);
|
setprop("/accelerations/airspeed-ktps", accel_filt);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
round10 = func(v) {
|
||||||
|
if (v == nil) return 0;
|
||||||
|
return 0.1*int(v*10);
|
||||||
|
}
|
||||||
|
|
||||||
|
round100 = func(v) {
|
||||||
|
if (v == nil) return 0;
|
||||||
|
return 0.01*int(v*100);
|
||||||
|
}
|
||||||
|
|
||||||
|
var update_vars = func( dt ) {
|
||||||
|
asl_ft = getprop("/position/altitude-ft");
|
||||||
|
ground = getprop("/position/ground-elev-ft");
|
||||||
|
agl_m = (asl_ft - ground) * 0.3048;
|
||||||
|
|
||||||
|
setprop("/apm/altitude", round10(agl_m));
|
||||||
|
|
||||||
|
setprop("/apm/pitch", round10(getprop("/orientation/pitch-deg")));
|
||||||
|
setprop("/apm/roll", round10(getprop("/orientation/roll-deg")));
|
||||||
|
setprop("/apm/heading", round10(getprop("/orientation/heading-deg")));
|
||||||
|
|
||||||
|
setprop("/apm/aileron", round100(getprop("/surface-positions/right-aileron-pos-norm")));
|
||||||
|
setprop("/apm/elevator", round100(getprop("/surface-positions/elevator-pos-norm")));
|
||||||
|
setprop("/apm/rudder", round100(getprop("/surface-positions/rudder-pos-norm")));
|
||||||
|
setprop("/apm/throttle", round10(getprop("/engines/engine/rpm")));
|
||||||
|
|
||||||
|
setprop("/apm/groundspeed", round10(0.514444444*getprop("/instrumentation/gps/indicated-ground-speed-kt")));
|
||||||
|
|
||||||
|
# airspeed-kt is actually in feet per second (FDM NET bug)
|
||||||
|
setprop("/apm/airspeed", round10(0.3048*getprop("/velocities/airspeed-kt")));
|
||||||
|
}
|
||||||
|
@ -10,6 +10,7 @@ var main_loop = func {
|
|||||||
last_time = time;
|
last_time = time;
|
||||||
|
|
||||||
update_airdata( dt );
|
update_airdata( dt );
|
||||||
|
update_vars( dt );
|
||||||
update_ugear( dt );
|
update_ugear( dt );
|
||||||
|
|
||||||
settimer(main_loop, 0);
|
settimer(main_loop, 0);
|
||||||
|
@ -71,20 +71,21 @@ Arducotper UAV Model
|
|||||||
</payload>
|
</payload>
|
||||||
<nasal>
|
<nasal>
|
||||||
<arducopter>
|
<arducopter>
|
||||||
|
<file>Aircraft/arducopter/quad.nas</file>
|
||||||
<script>
|
<script>
|
||||||
setlistener("/sim/signals/fdm-initialized", func {
|
setlistener("/sim/signals/fdm-initialized", func {
|
||||||
var left = screen.display.new(20, 10);
|
var left = screen.display.new(20, 10);
|
||||||
left.add("/engines/engine[0]/rpm");
|
left.add("/apm/motor_right");
|
||||||
left.add("/engines/engine[1]/rpm");
|
left.add("/apm/motor_left");
|
||||||
left.add("/engines/engine[2]/rpm");
|
left.add("/apm/motor_front");
|
||||||
left.add("/engines/engine[3]/rpm");
|
left.add("/apm/motor_back");
|
||||||
|
|
||||||
var right = screen.display.new(-250, 20);
|
var right = screen.display.new(-250, 20);
|
||||||
right.add("/position/altitude-agl-ft");
|
right.add("/apm/altitude");
|
||||||
right.add("/orientation/roll-deg");
|
right.add("/apm/roll");
|
||||||
right.add("/orientation/pitch-deg");
|
right.add("/apm/pitch");
|
||||||
right.add("/orientation/heading-deg");
|
right.add("/apm/heading");
|
||||||
right.add("/instrumentation/gps/indicated-ground-speed-kt");
|
right.add("/apm/airspeed");
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
</arducopter>
|
</arducopter>
|
||||||
|
@ -193,9 +193,9 @@
|
|||||||
</DO_SET_SERVO>
|
</DO_SET_SERVO>
|
||||||
<DO_REPEAT_SERVO>
|
<DO_REPEAT_SERVO>
|
||||||
<P1>Ser No</P1>
|
<P1>Ser No</P1>
|
||||||
<P2>Repeat#</P2>
|
<P2>PWM</P2>
|
||||||
<P3>Delay (s)</P3>
|
<P3>Repeat#</P3>
|
||||||
<P4>PWM</P4>
|
<P4>Delay (s)</P4>
|
||||||
<X></X>
|
<X></X>
|
||||||
<Y></Y>
|
<Y></Y>
|
||||||
<Z></Z>
|
<Z></Z>
|
||||||
@ -431,9 +431,9 @@
|
|||||||
</DO_SET_SERVO>
|
</DO_SET_SERVO>
|
||||||
<DO_REPEAT_SERVO>
|
<DO_REPEAT_SERVO>
|
||||||
<P1>Ser No</P1>
|
<P1>Ser No</P1>
|
||||||
<P2>Repeat#</P2>
|
<P2>PWM</P2>
|
||||||
<P3>Delay (s)</P3>
|
<P3>Repeat#</P3>
|
||||||
<P4>PWM</P4>
|
<P4>Delay (s)</P4>
|
||||||
<X></X>
|
<X></X>
|
||||||
<Y></Y>
|
<Y></Y>
|
||||||
<Z></Z>
|
<Z></Z>
|
||||||
|
@ -193,9 +193,9 @@
|
|||||||
</DO_SET_SERVO>
|
</DO_SET_SERVO>
|
||||||
<DO_REPEAT_SERVO>
|
<DO_REPEAT_SERVO>
|
||||||
<P1>Ser No</P1>
|
<P1>Ser No</P1>
|
||||||
<P2>Repeat#</P2>
|
<P2>PWM</P2>
|
||||||
<P3>Delay (s)</P3>
|
<P3>Repeat#</P3>
|
||||||
<P4>PWM</P4>
|
<P4>Delay (s)</P4>
|
||||||
<X></X>
|
<X></X>
|
||||||
<Y></Y>
|
<Y></Y>
|
||||||
<Z></Z>
|
<Z></Z>
|
||||||
@ -431,9 +431,9 @@
|
|||||||
</DO_SET_SERVO>
|
</DO_SET_SERVO>
|
||||||
<DO_REPEAT_SERVO>
|
<DO_REPEAT_SERVO>
|
||||||
<P1>Ser No</P1>
|
<P1>Ser No</P1>
|
||||||
<P2>Repeat#</P2>
|
<P2>PWM</P2>
|
||||||
<P3>Delay (s)</P3>
|
<P3>Repeat#</P3>
|
||||||
<P4>PWM</P4>
|
<P4>Delay (s)</P4>
|
||||||
<X></X>
|
<X></X>
|
||||||
<Y></Y>
|
<Y></Y>
|
||||||
<Z></Z>
|
<Z></Z>
|
||||||
|
Loading…
Reference in New Issue
Block a user