mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-11 10:28:29 -04:00
ArdupilotMegaPlanner: Added new APPROACH flight mode and added infrastructure necessary to make it private (ie. not a user selectable mode).
This commit is contained in:
parent
baf8218b58
commit
dcef88c3ba
@ -222,6 +222,8 @@
|
|||||||
<Compile Include="Antenna\Tracker.Designer.cs">
|
<Compile Include="Antenna\Tracker.Designer.cs">
|
||||||
<DependentUpon>Tracker.cs</DependentUpon>
|
<DependentUpon>Tracker.cs</DependentUpon>
|
||||||
</Compile>
|
</Compile>
|
||||||
|
<Compile Include="Attributes\DisplayTextAttribute.cs" />
|
||||||
|
<Compile Include="Attributes\PrivateAttribute.cs" />
|
||||||
<Compile Include="CodeGen.cs" />
|
<Compile Include="CodeGen.cs" />
|
||||||
<Compile Include="Controls\BackstageView\BackstageView.cs">
|
<Compile Include="Controls\BackstageView\BackstageView.cs">
|
||||||
<SubType>UserControl</SubType>
|
<SubType>UserControl</SubType>
|
||||||
@ -540,6 +542,7 @@
|
|||||||
<Compile Include="Radio\Uploader.cs" />
|
<Compile Include="Radio\Uploader.cs" />
|
||||||
<Compile Include="LangUtility.cs" />
|
<Compile Include="LangUtility.cs" />
|
||||||
<Compile Include="ThemeManager.cs" />
|
<Compile Include="ThemeManager.cs" />
|
||||||
|
<Compile Include="Utilities\EnumTranslator.cs" />
|
||||||
<EmbeddedResource Include="Antenna\Tracker.resx">
|
<EmbeddedResource Include="Antenna\Tracker.resx">
|
||||||
<DependentUpon>Tracker.cs</DependentUpon>
|
<DependentUpon>Tracker.cs</DependentUpon>
|
||||||
</EmbeddedResource>
|
</EmbeddedResource>
|
||||||
|
@ -0,0 +1,44 @@
|
|||||||
|
#region Using Statements
|
||||||
|
|
||||||
|
using System;
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
namespace ArdupilotMega.Attributes
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Used to decorate a type or type member with display text.
|
||||||
|
/// </summary>
|
||||||
|
[AttributeUsage(AttributeTargets.All, Inherited = false, AllowMultiple = false)]
|
||||||
|
public sealed class DisplayTextAttribute : Attribute
|
||||||
|
{
|
||||||
|
|
||||||
|
private readonly string _text;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Initializes a new instance of the <see cref="DisplayTextAttribute"/> class.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="text">The text.</param>
|
||||||
|
/// <exception cref="ArgumentException">
|
||||||
|
/// Thrown when <paramref name="text"/> is null or empty.
|
||||||
|
/// </exception>
|
||||||
|
public DisplayTextAttribute(string text)
|
||||||
|
{
|
||||||
|
if (String.IsNullOrEmpty(text))
|
||||||
|
{
|
||||||
|
throw new ArgumentException("\"text\" is required.");
|
||||||
|
}
|
||||||
|
_text = text;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets the text.
|
||||||
|
/// </summary>
|
||||||
|
/// <value>The text.</value>
|
||||||
|
public string Text
|
||||||
|
{
|
||||||
|
get { return _text; }
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
35
Tools/ArdupilotMegaPlanner/Attributes/PrivateAttribute.cs
Normal file
35
Tools/ArdupilotMegaPlanner/Attributes/PrivateAttribute.cs
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
#region Using Statements
|
||||||
|
|
||||||
|
using System;
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
namespace ArdupilotMega.Attributes
|
||||||
|
{
|
||||||
|
[AttributeUsage(AttributeTargets.All, Inherited = false, AllowMultiple = false)]
|
||||||
|
public sealed class PrivateAttribute : Attribute
|
||||||
|
{
|
||||||
|
private readonly bool _isPrivate;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Initializes a new instance of the <see cref="PrivateAttribute"/> class.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="isPrivate">if set to <c>true</c> [is private].</param>
|
||||||
|
public PrivateAttribute(bool isPrivate)
|
||||||
|
{
|
||||||
|
_isPrivate = isPrivate;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets a value indicating whether this instance is private.
|
||||||
|
/// </summary>
|
||||||
|
/// <value>
|
||||||
|
/// <c>true</c> if this instance is private; otherwise, <c>false</c>.
|
||||||
|
/// </value>
|
||||||
|
public bool IsPrivate
|
||||||
|
{
|
||||||
|
get { return _isPrivate; }
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
@ -8,6 +8,7 @@ using System.Windows.Forms;
|
|||||||
using AGaugeApp;
|
using AGaugeApp;
|
||||||
using System.IO.Ports;
|
using System.IO.Ports;
|
||||||
using System.Threading;
|
using System.Threading;
|
||||||
|
using ArdupilotMega.Attributes;
|
||||||
using GMap.NET;
|
using GMap.NET;
|
||||||
using GMap.NET.WindowsForms;
|
using GMap.NET.WindowsForms;
|
||||||
using GMap.NET.WindowsForms.Markers;
|
using GMap.NET.WindowsForms.Markers;
|
||||||
@ -319,28 +320,48 @@ namespace ArdupilotMega
|
|||||||
|
|
||||||
public enum ac2modes
|
public enum ac2modes
|
||||||
{
|
{
|
||||||
|
[DisplayText("Stabilize")]
|
||||||
STABILIZE = 0, // hold level position
|
STABILIZE = 0, // hold level position
|
||||||
|
[DisplayText("Acro")]
|
||||||
ACRO = 1, // rate control
|
ACRO = 1, // rate control
|
||||||
|
[DisplayText("Altitude Hold")]
|
||||||
ALT_HOLD = 2, // AUTO control
|
ALT_HOLD = 2, // AUTO control
|
||||||
|
[DisplayText("Auto")]
|
||||||
AUTO = 3, // AUTO control
|
AUTO = 3, // AUTO control
|
||||||
|
[DisplayText("Guided")]
|
||||||
GUIDED = 4, // AUTO control
|
GUIDED = 4, // AUTO control
|
||||||
|
[DisplayText("Loiter")]
|
||||||
LOITER = 5, // Hold a single location
|
LOITER = 5, // Hold a single location
|
||||||
|
[DisplayText("Return to Launch")]
|
||||||
RTL = 6, // AUTO control
|
RTL = 6, // AUTO control
|
||||||
|
[DisplayText("Circle")]
|
||||||
CIRCLE = 7,
|
CIRCLE = 7,
|
||||||
|
[DisplayText("Position Hold")]
|
||||||
POSITION = 8,
|
POSITION = 8,
|
||||||
|
[DisplayText("Land")]
|
||||||
LAND = 9, // AUTO control
|
LAND = 9, // AUTO control
|
||||||
OF_LOITER = 10
|
[Private(true)]
|
||||||
|
APPROACH = 10,
|
||||||
|
OF_LOITER = 11
|
||||||
}
|
}
|
||||||
|
|
||||||
public enum ac2ch7modes
|
public enum ac2ch7modes
|
||||||
{
|
{
|
||||||
|
[DisplayText("Do Nothing")]
|
||||||
CH7_DO_NOTHING = 0,
|
CH7_DO_NOTHING = 0,
|
||||||
|
[DisplayText("Set Hover")]
|
||||||
CH7_SET_HOVER = 1,
|
CH7_SET_HOVER = 1,
|
||||||
|
[DisplayText("Flip")]
|
||||||
CH7_FLIP = 2,
|
CH7_FLIP = 2,
|
||||||
|
[DisplayText("Simple Mode")]
|
||||||
CH7_SIMPLE_MODE = 3,
|
CH7_SIMPLE_MODE = 3,
|
||||||
|
[DisplayText("Return to Launch")]
|
||||||
CH7_RTL = 4,
|
CH7_RTL = 4,
|
||||||
|
[DisplayText("Automatic Trim")]
|
||||||
CH7_AUTO_TRIM = 5,
|
CH7_AUTO_TRIM = 5,
|
||||||
|
[DisplayText("ADC Filter")]
|
||||||
CH7_ADC_FILTER = 6,
|
CH7_ADC_FILTER = 6,
|
||||||
|
[DisplayText("Save Waypoint")]
|
||||||
CH7_SAVE_WP = 7
|
CH7_SAVE_WP = 7
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3,6 +3,7 @@ using System.Collections.Generic;
|
|||||||
using System.Reflection;
|
using System.Reflection;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
using System.ComponentModel;
|
using System.ComponentModel;
|
||||||
|
using ArdupilotMega.Utilities;
|
||||||
using log4net;
|
using log4net;
|
||||||
|
|
||||||
namespace ArdupilotMega
|
namespace ArdupilotMega
|
||||||
@ -503,34 +504,37 @@ namespace ArdupilotMega
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case (byte)(100 + Common.ac2modes.STABILIZE):
|
case (byte)(100 + Common.ac2modes.STABILIZE):
|
||||||
mode = "Stabilize";
|
mode = EnumTranslator.GetDisplayText(Common.ac2modes.STABILIZE);
|
||||||
break;
|
break;
|
||||||
case (byte)(100 + Common.ac2modes.ACRO):
|
case (byte)(100 + Common.ac2modes.ACRO):
|
||||||
mode = "Acro";
|
mode = EnumTranslator.GetDisplayText(Common.ac2modes.ACRO);
|
||||||
break;
|
break;
|
||||||
case (byte)(100 + Common.ac2modes.ALT_HOLD):
|
case (byte)(100 + Common.ac2modes.ALT_HOLD):
|
||||||
mode = "Alt Hold";
|
mode = EnumTranslator.GetDisplayText(Common.ac2modes.ALT_HOLD);
|
||||||
break;
|
break;
|
||||||
case (byte)(100 + Common.ac2modes.AUTO):
|
case (byte)(100 + Common.ac2modes.AUTO):
|
||||||
mode = "Auto";
|
mode = EnumTranslator.GetDisplayText(Common.ac2modes.AUTO);
|
||||||
break;
|
break;
|
||||||
case (byte)(100 + Common.ac2modes.GUIDED):
|
case (byte)(100 + Common.ac2modes.GUIDED):
|
||||||
mode = "Guided";
|
mode = EnumTranslator.GetDisplayText(Common.ac2modes.GUIDED);
|
||||||
break;
|
break;
|
||||||
case (byte)(100 + Common.ac2modes.LOITER):
|
case (byte)(100 + Common.ac2modes.LOITER):
|
||||||
mode = "Loiter";
|
mode = EnumTranslator.GetDisplayText(Common.ac2modes.LOITER);
|
||||||
break;
|
break;
|
||||||
case (byte)(100 + Common.ac2modes.RTL):
|
case (byte)(100 + Common.ac2modes.RTL):
|
||||||
mode = "RTL";
|
mode = EnumTranslator.GetDisplayText(Common.ac2modes.RTL);
|
||||||
break;
|
break;
|
||||||
case (byte)(100 + Common.ac2modes.CIRCLE):
|
case (byte)(100 + Common.ac2modes.CIRCLE):
|
||||||
mode = "Circle";
|
mode = EnumTranslator.GetDisplayText(Common.ac2modes.CIRCLE);
|
||||||
break;
|
break;
|
||||||
case (byte)(100 + Common.ac2modes.LAND):
|
case (byte)(100 + Common.ac2modes.LAND):
|
||||||
mode = "Land";
|
mode = EnumTranslator.GetDisplayText(Common.ac2modes.LAND);
|
||||||
|
break;
|
||||||
|
case (byte)(100 + Common.ac2modes.APPROACH):
|
||||||
|
mode = EnumTranslator.GetDisplayText(Common.ac2modes.APPROACH);
|
||||||
break;
|
break;
|
||||||
case (byte)(100 + Common.ac2modes.POSITION):
|
case (byte)(100 + Common.ac2modes.POSITION):
|
||||||
mode = "Position";
|
mode = EnumTranslator.GetDisplayText(Common.ac2modes.POSITION);
|
||||||
break;
|
break;
|
||||||
case (byte)ArdupilotMega.MAVLink.MAV_MODE.MAV_MODE_MANUAL:
|
case (byte)ArdupilotMega.MAVLink.MAV_MODE.MAV_MODE_MANUAL:
|
||||||
mode = "Manual";
|
mode = "Manual";
|
||||||
|
@ -7,6 +7,7 @@ using System.Linq;
|
|||||||
using System.Text;
|
using System.Text;
|
||||||
using System.Windows.Forms;
|
using System.Windows.Forms;
|
||||||
using ArdupilotMega.Controls.BackstageView;
|
using ArdupilotMega.Controls.BackstageView;
|
||||||
|
using ArdupilotMega.Utilities;
|
||||||
|
|
||||||
namespace ArdupilotMega.GCSViews.ConfigurationView
|
namespace ArdupilotMega.GCSViews.ConfigurationView
|
||||||
{
|
{
|
||||||
@ -165,12 +166,31 @@ namespace ArdupilotMega.GCSViews.ConfigurationView
|
|||||||
CMB_fmode5.Items.Clear();
|
CMB_fmode5.Items.Clear();
|
||||||
CMB_fmode6.Items.Clear();
|
CMB_fmode6.Items.Clear();
|
||||||
|
|
||||||
CMB_fmode1.Items.AddRange(Enum.GetNames(typeof(Common.apmmodes)));
|
var flightModes = EnumTranslator.Translate<Common.apmmodes>();
|
||||||
CMB_fmode2.Items.AddRange(Enum.GetNames(typeof(Common.apmmodes)));
|
|
||||||
CMB_fmode3.Items.AddRange(Enum.GetNames(typeof(Common.apmmodes)));
|
CMB_fmode1.DataSource = flightModes;
|
||||||
CMB_fmode4.Items.AddRange(Enum.GetNames(typeof(Common.apmmodes)));
|
CMB_fmode1.ValueMember = "Value";
|
||||||
CMB_fmode5.Items.AddRange(Enum.GetNames(typeof(Common.apmmodes)));
|
CMB_fmode1.DisplayMember = "Value";
|
||||||
CMB_fmode6.Items.AddRange(Enum.GetNames(typeof(Common.apmmodes)));
|
|
||||||
|
CMB_fmode2.DataSource = flightModes;
|
||||||
|
CMB_fmode2.ValueMember = "Value";
|
||||||
|
CMB_fmode2.DisplayMember = "Value";
|
||||||
|
|
||||||
|
CMB_fmode3.DataSource = flightModes;
|
||||||
|
CMB_fmode3.ValueMember = "Value";
|
||||||
|
CMB_fmode3.DisplayMember = "Value";
|
||||||
|
|
||||||
|
CMB_fmode4.DataSource = flightModes;
|
||||||
|
CMB_fmode4.ValueMember = "Value";
|
||||||
|
CMB_fmode4.DisplayMember = "Value";
|
||||||
|
|
||||||
|
CMB_fmode5.DataSource = flightModes;
|
||||||
|
CMB_fmode5.ValueMember = "Value";
|
||||||
|
CMB_fmode5.DisplayMember = "Value";
|
||||||
|
|
||||||
|
CMB_fmode6.DataSource = flightModes;
|
||||||
|
CMB_fmode6.ValueMember = "Value";
|
||||||
|
CMB_fmode6.DisplayMember = "Value";
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
@ -193,12 +213,31 @@ namespace ArdupilotMega.GCSViews.ConfigurationView
|
|||||||
CMB_fmode5.Items.Clear();
|
CMB_fmode5.Items.Clear();
|
||||||
CMB_fmode6.Items.Clear();
|
CMB_fmode6.Items.Clear();
|
||||||
|
|
||||||
CMB_fmode1.Items.AddRange(Enum.GetNames(typeof(Common.ac2modes)));
|
var flightModes = EnumTranslator.Translate<Common.apmmodes>();
|
||||||
CMB_fmode2.Items.AddRange(Enum.GetNames(typeof(Common.ac2modes)));
|
|
||||||
CMB_fmode3.Items.AddRange(Enum.GetNames(typeof(Common.ac2modes)));
|
CMB_fmode1.DataSource = flightModes;
|
||||||
CMB_fmode4.Items.AddRange(Enum.GetNames(typeof(Common.ac2modes)));
|
CMB_fmode1.ValueMember = "Value";
|
||||||
CMB_fmode5.Items.AddRange(Enum.GetNames(typeof(Common.ac2modes)));
|
CMB_fmode1.DisplayMember = "Value";
|
||||||
CMB_fmode6.Items.AddRange(Enum.GetNames(typeof(Common.ac2modes)));
|
|
||||||
|
CMB_fmode2.DataSource = flightModes;
|
||||||
|
CMB_fmode2.ValueMember = "Value";
|
||||||
|
CMB_fmode2.DisplayMember = "Value";
|
||||||
|
|
||||||
|
CMB_fmode3.DataSource = flightModes;
|
||||||
|
CMB_fmode3.ValueMember = "Value";
|
||||||
|
CMB_fmode3.DisplayMember = "Value";
|
||||||
|
|
||||||
|
CMB_fmode4.DataSource = flightModes;
|
||||||
|
CMB_fmode4.ValueMember = "Value";
|
||||||
|
CMB_fmode4.DisplayMember = "Value";
|
||||||
|
|
||||||
|
CMB_fmode5.DataSource = flightModes;
|
||||||
|
CMB_fmode5.ValueMember = "Value";
|
||||||
|
CMB_fmode5.DisplayMember = "Value";
|
||||||
|
|
||||||
|
CMB_fmode6.DataSource = flightModes;
|
||||||
|
CMB_fmode6.ValueMember = "Value";
|
||||||
|
CMB_fmode6.DisplayMember = "Value";
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
120
Tools/ArdupilotMegaPlanner/Utilities/EnumTranslator.cs
Normal file
120
Tools/ArdupilotMegaPlanner/Utilities/EnumTranslator.cs
Normal file
@ -0,0 +1,120 @@
|
|||||||
|
#region Using Statements
|
||||||
|
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Reflection;
|
||||||
|
using ArdupilotMega.Attributes;
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
namespace ArdupilotMega.Utilities
|
||||||
|
{
|
||||||
|
public static class EnumTranslator
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Translates this instance.
|
||||||
|
/// </summary>
|
||||||
|
/// <typeparam name="T"></typeparam>
|
||||||
|
/// <returns></returns>
|
||||||
|
public static Dictionary<int, string> Translate<T>()
|
||||||
|
{
|
||||||
|
return Translate<T>(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Translates the specified check private.
|
||||||
|
/// </summary>
|
||||||
|
/// <typeparam name="T"></typeparam>
|
||||||
|
/// <param name="checkPrivate">if set to <c>true</c> [check private].</param>
|
||||||
|
/// <returns></returns>
|
||||||
|
public static Dictionary<int, string> Translate<T>(bool checkPrivate)
|
||||||
|
{
|
||||||
|
return Translate<T>(string.Empty, checkPrivate);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Translates the specified default text.
|
||||||
|
/// </summary>
|
||||||
|
/// <typeparam name="T"></typeparam>
|
||||||
|
/// <param name="defaultText">The default text.</param>
|
||||||
|
/// <param name="checkPrivate">if set to <c>true</c> [check private].</param>
|
||||||
|
/// <returns></returns>
|
||||||
|
public static Dictionary<int, string> Translate<T>(string defaultText, bool checkPrivate)
|
||||||
|
{
|
||||||
|
return Translate<T>(defaultText, checkPrivate, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Translates the specified default text.
|
||||||
|
/// </summary>
|
||||||
|
/// <typeparam name="T"></typeparam>
|
||||||
|
/// <param name="defaultText">The default text.</param>
|
||||||
|
/// <param name="checkPrivate">if set to <c>true</c> [check private].</param>
|
||||||
|
/// <param name="sorting">if set to <c>true</c> [sorting].</param>
|
||||||
|
/// <returns></returns>
|
||||||
|
public static Dictionary<int, string> Translate<T>(string defaultText, bool checkPrivate, bool sorting)
|
||||||
|
{
|
||||||
|
var types = new Dictionary<int, string>();
|
||||||
|
var tempTypes = new Dictionary<int, string>();
|
||||||
|
if (!String.IsNullOrEmpty(defaultText)) types.Add(-1, defaultText);
|
||||||
|
foreach (FieldInfo fieldInfo in typeof(T).GetFields(BindingFlags.Static | BindingFlags.GetField | BindingFlags.Public))
|
||||||
|
{
|
||||||
|
bool add = true;
|
||||||
|
string displayText = string.Empty;
|
||||||
|
T type = (T)fieldInfo.GetValue(typeof(T));
|
||||||
|
object[] displayTextObjectArr = fieldInfo.GetCustomAttributes(typeof(DisplayTextAttribute), true);
|
||||||
|
displayText = (displayTextObjectArr.Length > 0)
|
||||||
|
? ((DisplayTextAttribute)displayTextObjectArr[0]).Text
|
||||||
|
: type.ToString();
|
||||||
|
if (checkPrivate)
|
||||||
|
{
|
||||||
|
object[] privateAttributeObjectArr = fieldInfo.GetCustomAttributes(typeof(PrivateAttribute), true);
|
||||||
|
if (privateAttributeObjectArr.Length > 0)
|
||||||
|
{
|
||||||
|
add = !((PrivateAttribute)privateAttributeObjectArr[0]).IsPrivate;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (add)
|
||||||
|
{
|
||||||
|
tempTypes.Add(Convert.ToInt32(type), displayText);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (sorting)
|
||||||
|
{
|
||||||
|
foreach(var x in tempTypes.OrderBy(x => x.Value).ToDictionary(x => x.Key, x => x.Value)){ types.Add(x.Key, x.Value); }
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
foreach (var x in tempTypes.ToDictionary(x => x.Key, x => x.Value)) { types.Add(x.Key, x.Value); }
|
||||||
|
}
|
||||||
|
return types;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets the display text.
|
||||||
|
/// </summary>
|
||||||
|
/// <typeparam name="T"></typeparam>
|
||||||
|
/// <param name="value">The value.</param>
|
||||||
|
/// <returns></returns>
|
||||||
|
public static string GetDisplayText<T>(T value)
|
||||||
|
{
|
||||||
|
var displayText = string.Empty;
|
||||||
|
var fieldInfo = value.GetType().GetField(value.ToString());
|
||||||
|
if(fieldInfo != null)
|
||||||
|
{
|
||||||
|
T type = (T)fieldInfo.GetValue(typeof(T));
|
||||||
|
if(type != null)
|
||||||
|
{
|
||||||
|
object[] displayTextObjectArr = fieldInfo.GetCustomAttributes(typeof(DisplayTextAttribute), true);
|
||||||
|
displayText = (displayTextObjectArr.Length > 0)
|
||||||
|
? ((DisplayTextAttribute)displayTextObjectArr[0]).Text
|
||||||
|
: type.ToString();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return displayText;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user