2010-06-18 10 views

Antwort

17

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.

+0

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. –

3

Sie können immer noch TypeConverterAttribute verwenden und seinen Konstruktor verwenden, der einen vollständig qualifizierten Namen akzeptiert. Siehe MSDN.

+0

Müsste das nicht immer noch die Assembly mit dem Typkonverter referenzieren? – Spike

+0

Nein, Assembly, das den Typkonverter enthält, wird zur Laufzeit über Type.GetType (http://msdn.microsoft.com/en-us/library/w3f99sx1.aspx) geladen. – Patko

+0

@Spike, nein, weil der Typ Converter-Typ durch den Namen und nicht durch typeof (...) referenziert werden kann. – yoyo

Verwandte Themen