Hmm, no estoy seguro de que he visto esto antes, pero se puede añadir el TypeConverterAttribute en tiempo de ejecución utilizando un TypeDescriptor, por lo que dado mis clases de muestra:
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);
}
}
Podría entonces tener un método:
public void AssignTypeConverter<IType, IConverterType>()
{
TypeDescriptor.AddAttributes(typeof(IType), new TypeConverterAttribute(typeof(IConverterType)));
}
AssignTypeConverter<MyType, MyTypeConverter>();
Espero que ayude.
Esto, sin embargo, ** no funciona para XAML **, ya que XAML no tiene en cuenta modificaciones de componentes en el tiempo de ejecución. [Encontré una forma de evitar esto] (https://whathecode.wordpress.com/2015/02/14/generic-typeconverter/) usando un 'TypeConverter' que redirige su implementación a un convertidor cargado usando' TypeDescriptor'. –