在这个问答中回答的问题是,当我们有一个带有枚举属性的ViewModel时,我们如何使用mvvmcross在我们的UI项目上显示颜色,而不需要有颜色属性,并且没有每个平台的ValueConverter。
发布于 2013-04-08 18:44:48
假设您有一个视图模型,如下所示
public enum MyEnum
{
Value1,
Value2
}
public class MyViewModel : MvxViewModel
{
public MyEnum MyEnumProp { get... set...}
}
假设你想为Value1显示天青颜色,为Value2显示黑色,你可以在你的核心项目上实现这个转换器。
public class MyEnumToColorConverter: MvxValueConverter<MyEnum, object>
{
protected override object Convert (Multiplier value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
MvxColor mvxColor = null;
switch (value) {
case MyEnum.Value1:
mvxColor = new MvxColor(240,255,255);
break;
case MyEnum.Value2:
mvxColor = new MvxColor(0,0,0);
break;
default:
mvxColor = new MvxColor(0,0,0);
break;
}
var nativeColorConv = Mvx.Resolve<IMvxNativeColor>();
return nativeColorConv.ToNative (mvxColor);
}
}
诀窍是调用Mvx.Resolve<IMvxNativeColor>()
。在您的UI项目中,如果您已经加载了正确的Color插件,那么您将自动获得适合您的平台的正确的Color实现。
记住将这一行添加到您的Setup.cs中(如果您添加了颜色插件Nuget包,则不需要,它会自动将其添加到Bootstrap文件夹中)。
Cirrious.MvvmCross.Plugins.Color.PluginLoader.Instance.EnsureLoaded();
https://stackoverflow.com/questions/15877139
复制相似问题