remove type-specific functions for ChromeMetrics.Get; use FieldLoader

This commit is contained in:
Chris Forbes
2011-06-17 18:50:23 +12:00
committed by Paul Chote
parent 7095f293ff
commit 3409d8f046
4 changed files with 9 additions and 19 deletions

View File

@@ -20,8 +20,8 @@ namespace OpenRA.Widgets
public string Key = null;
public string Text = "";
public bool Depressed = false;
public int VisualHeight = ChromeMetrics.GetInt("ButtonDepth");
public string Font = ChromeMetrics.GetString("ButtonFont");
public int VisualHeight = ChromeMetrics.Get<int>("ButtonDepth");
public string Font = ChromeMetrics.Get<string>("ButtonFont");
public Func<string> GetText;
public Func<bool> IsDisabled = () => false;
public Action OnClick = () => {};

View File

@@ -19,7 +19,7 @@ namespace OpenRA.Widgets
{
public Func<bool> IsChecked = () => false;
public int BaseLine = 1;
public bool HasPressedState = ChromeMetrics.GetBool("CheckboxPressedState");
public bool HasPressedState = ChromeMetrics.Get<bool>("CheckboxPressedState");
public CheckboxWidget()
: base()

View File

@@ -30,19 +30,9 @@ namespace OpenRA.Widgets
data[n.Key] = n.Value.Value;
}
public static string GetString(string key)
public static T Get<T>(string key)
{
return data[key];
}
public static int GetInt(string key)
{
return int.Parse(data[key]);
}
public static bool GetBool(string key)
{
return bool.Parse(data[key]);
return (T)FieldLoader.GetValue( key, typeof(T), data[key] );
}
}
}

View File

@@ -19,7 +19,7 @@ namespace OpenRA.Widgets
public int ScrollbarWidth = 24;
public float ScrollVelocity = 4f;
public int ItemSpacing = 2;
public int ButtonDepth = ChromeMetrics.GetInt("ButtonDepth");
public int ButtonDepth = ChromeMetrics.Get<int>("ButtonDepth");
public string Background = "scrollpanel-bg";
public int ContentHeight = 0;
protected float ListOffset = 0;