Hmm, nicht sicher, ob ich vorher gesehen habe, aber man kann die Typeconverter zur Laufzeit mit einem TypeDescriptor hinzufügen, so dass meine Beispielklassen gegeben:
public class MyType
{
public string Name;
}
public class MyTypeConverter : TypeConverter
{
public override bool CanConvertFrom(ITypeDescriptorContext context, Type sourceType)
{
if (sourceType == typeof(string))
return true;
return base.CanConvertFrom(context, sourceType);
}
public override object ConvertFrom(ITypeDescriptorContext context, System.Globalization.CultureInfo culture, object value)
{
if (value.GetType() == typeof(string))
return new MyType() { Name = (string) value };
return base.ConvertFrom(context, culture, value);
}
}
ich dann eine Methode haben könnte:
public void AssignTypeConverter<IType, IConverterType>()
{
TypeDescriptor.AddAttributes(typeof(IType), new TypeConverterAttribute(typeof(IConverterType)));
}
AssignTypeConverter<MyType, MyTypeConverter>();
Hoffe, dass hilft.
Dies jedoch ** funktioniert nicht für XAML **, da XAML keine Komponentenänderungen zur Laufzeit berücksichtigt. Ich habe einen Weg gefunden (https://wathhecode.wordpress.com/2015/02/14/generic-typeconverter/) mit einem 'TypeConverter', der seine Implementierung auf einen Konverter umleitet, der mit' TypeDescriptor' geladen wurde. –