APM Planner

fix CAPM update firmware error
This commit is contained in:
Hazy 2012-02-26 19:14:08 +08:00
parent f27e9f9ca1
commit 71b73a669c
4 changed files with 91 additions and 69 deletions

View File

@ -445,6 +445,7 @@
<DependentUpon>temp.cs</DependentUpon> <DependentUpon>temp.cs</DependentUpon>
</Compile> </Compile>
<Compile Include="Radio\Uploader.cs" /> <Compile Include="Radio\Uploader.cs" />
<Compile Include="Utility.cs" />
<EmbeddedResource Include="Controls\ProgressReporterDialogue.resx"> <EmbeddedResource Include="Controls\ProgressReporterDialogue.resx">
<DependentUpon>ProgressReporterDialogue.cs</DependentUpon> <DependentUpon>ProgressReporterDialogue.cs</DependentUpon>
</EmbeddedResource> </EmbeddedResource>

View File

@ -173,27 +173,21 @@ namespace ArdupilotMega.GCSViews
CultureInfo ci = null; CultureInfo ci = null;
foreach (string name in new string[] { "en-US", "zh-Hans", "zh-TW", "ru-RU", "Fr", "Pl", "it-IT", "es-ES" }) foreach (string name in new string[] { "en-US", "zh-Hans", "zh-TW", "ru-RU", "Fr", "Pl", "it-IT", "es-ES" })
{ {
ci = MainV2.getcultureinfo(name); ci = CultureInfoEx.GetCultureInfo(name);
if (ci != null) if (ci != null)
languages.Add(ci); languages.Add(ci);
} }
CMB_language.DisplayMember = "DisplayName"; CMB_language.DisplayMember = "DisplayName";
CMB_language.DataSource = languages; CMB_language.DataSource = languages;
bool match = false;
for (int i = 0; i < languages.Count && !match; i++)
{
ci = Thread.CurrentThread.CurrentUICulture; ci = Thread.CurrentThread.CurrentUICulture;
while (!ci.Equals(CultureInfo.InvariantCulture)) for (int i = 0; i < languages.Count; i++)
{ {
if (ci.Equals(languages[i])) if (ci.IsChildOf(languages[i]))
{ {
CMB_language.SelectedIndex = i; CMB_language.SelectedIndex = i;
match = true;
break; break;
} }
ci = ci.Parent;
}
} }
CMB_language.SelectedIndexChanged += CMB_language_SelectedIndexChanged; CMB_language.SelectedIndexChanged += CMB_language_SelectedIndexChanged;
@ -599,12 +593,12 @@ namespace ArdupilotMega.GCSViews
continue; continue;
if (index2 != -1) if (index2 != -1)
line = line.Replace(',','.'); line = line.Replace(',', '.');
string name = line.Substring(0, index); string name = line.Substring(0, index);
float value = float.Parse(line.Substring(index + 1), new System.Globalization.CultureInfo("en-US")); float value = float.Parse(line.Substring(index + 1), new System.Globalization.CultureInfo("en-US"));
MAVLink.modifyParamForDisplay(true,name,ref value); MAVLink.modifyParamForDisplay(true, name, ref value);
// set param table as well // set param table as well
foreach (DataGridViewRow row in Params.Rows) foreach (DataGridViewRow row in Params.Rows)
@ -813,7 +807,8 @@ namespace ArdupilotMega.GCSViews
{ {
DsError.ThrowExceptionForHR(hr); DsError.ThrowExceptionForHR(hr);
} }
catch (Exception ex) { catch (Exception ex)
{
MessageBox.Show("Can not add video source\n" + ex.ToString()); MessageBox.Show("Can not add video source\n" + ex.ToString());
return; return;
} }

View File

@ -138,7 +138,7 @@ namespace ArdupilotMega
xmlconfig(false); xmlconfig(false);
if (config.ContainsKey("language") && !string.IsNullOrEmpty((string)config["language"])) if (config.ContainsKey("language") && !string.IsNullOrEmpty((string)config["language"]))
changelanguage(getcultureinfo((string)config["language"])); changelanguage(CultureInfoEx.GetCultureInfo((string)config["language"]));
if (!MONO) // windows only if (!MONO) // windows only
{ {
@ -2011,51 +2011,13 @@ namespace ArdupilotMega
{ {
ComponentResourceManager rm = new ComponentResourceManager(view.GetType()); ComponentResourceManager rm = new ComponentResourceManager(view.GetType());
foreach (Control ctrl in view.Controls) foreach (Control ctrl in view.Controls)
applyresource(rm, ctrl); rm.ApplyResource(ctrl);
rm.ApplyResources(view, "$this"); rm.ApplyResources(view, "$this");
} }
} }
} }
} }
private void applyresource(ComponentResourceManager rm, Control ctrl)
{
rm.ApplyResources(ctrl, ctrl.Name);
foreach (Control subctrl in ctrl.Controls)
applyresource(rm, subctrl);
if (ctrl.ContextMenu != null)
applyresource(rm, ctrl.ContextMenu);
if (ctrl is DataGridView)
{
foreach (DataGridViewColumn col in (ctrl as DataGridView).Columns)
rm.ApplyResources(col, col.Name);
}
}
private void applyresource(ComponentResourceManager rm, Menu menu)
{
rm.ApplyResources(menu, menu.Name);
foreach (MenuItem submenu in menu.MenuItems)
applyresource(rm, submenu);
}
public static CultureInfo getcultureinfo(string name)
{
try
{
return new CultureInfo(name);
}
catch (Exception)
{
return null;
}
}
private void MainV2_FormClosing(object sender, FormClosingEventArgs e) private void MainV2_FormClosing(object sender, FormClosingEventArgs e)
{ {
config["MainHeight"] = this.Height; config["MainHeight"] = this.Height;

View File

@ -0,0 +1,64 @@
//this file contains some simple extension methods
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Globalization;
using System.ComponentModel;
using System.Windows.Forms;
namespace ArdupilotMega
{
static class CultureInfoEx
{
public static CultureInfo GetCultureInfo(string name)
{
try { return new CultureInfo(name); }
catch (Exception) { return null; }
}
public static bool IsChildOf(this CultureInfo cX, CultureInfo cY)
{
if (cX == null || cY == null)
return false;
CultureInfo c = cX;
while (!c.Equals(CultureInfo.InvariantCulture))
{
if (c.Equals(cY))
return true;
c = c.Parent;
}
return false;
}
}
static class ComponentResourceManagerEx
{
public static void ApplyResource(this ComponentResourceManager rm, Control ctrl)
{
rm.ApplyResources(ctrl, ctrl.Name);
foreach (Control subctrl in ctrl.Controls)
ApplyResource(rm, subctrl);
if (ctrl.ContextMenu != null)
ApplyResource(rm, ctrl.ContextMenu);
if (ctrl is DataGridView)
{
foreach (DataGridViewColumn col in (ctrl as DataGridView).Columns)
rm.ApplyResources(col, col.Name);
}
}
public static void ApplyResource(this ComponentResourceManager rm, Menu menu)
{
rm.ApplyResources(menu, menu.Name);
foreach (MenuItem submenu in menu.MenuItems)
ApplyResource(rm, submenu);
}
}
}