Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / Orcas / NetFXw7 / wpf / src / Framework / System / Windows / Data / ValueConversionAttribute.cs / 1 / ValueConversionAttribute.cs
//----------------------------------------------------------------------------
//
//
// Copyright (C) Microsoft Corporation. All rights reserved.
//
//
// Description: allows the author of a IValueConverter
// to specify what source and target property types the
// ValueConverter is capable of converting
//
// Specs: http://avalon/connecteddata/Specs/Data%20Binding.mht
//
//---------------------------------------------------------------------------
using System;
namespace System.Windows.Data
{
///
/// This attribute allows the author of a
/// to specify what source and target property types the ValueConverter is capable of converting.
/// This meta data is useful for designer tools to help categorize and match ValueConverters.
///
///
/// Add this custom attribute to your IValueConverter class definition.
///
/// [ValueConversion(typeof(Employee), typeof(Brush))]
/// class MyConverter : IValueConverter
/// {
/// public object Convert(object value, Type targetType, object parameter, CultureInfo culture)
/// {
/// if (value is Dev) return Brushes.Beige;
/// if (value is Employee) return Brushes.Salmon;
/// return Brushes.Yellow;
/// }
/// }
///
///
[AttributeUsage(AttributeTargets.Class, AllowMultiple = true)]
public sealed class ValueConversionAttribute : Attribute
{
//-----------------------------------------------------
//
// Constructors
//
//-----------------------------------------------------
///
/// Creates a new ValueConversionAttribute to indicate between
/// what types of a data binding source and target this ValueConverter can convert.
///
/// the expected source type this ValueConverter can handle
/// the target type to which this ValueConverter can convert to
public ValueConversionAttribute(Type sourceType, Type targetType)
{
if (sourceType == null)
throw new ArgumentNullException("sourceType");
if (targetType == null)
throw new ArgumentNullException("targetType");
_sourceType = sourceType;
_targetType = targetType;
}
///
/// The expected source type this ValueConverter can handle.
///
public Type SourceType
{
get { return _sourceType; }
}
///
/// The target type to which this ValueConverter can convert to.
///
public Type TargetType
{
get { return _targetType; }
}
///
/// The type of the optional ValueConverter Parameter object.
///
public Type ParameterType
{
get { return _parameterType; }
set { _parameterType = value; }
}
///
/// Returns the unique identifier for this Attribute.
///
// Type ID is used to remove redundant attributes by
// putting all attributes in a dictionary of [TypeId, Attribute].
// If you want AllowMultiple attributes to work with designers,
// you must override TypeId. The default implementation returns
// this.GetType(), which is appropriate for AllowMultiple = false, but
// not for AllowMultiple = true;
public override object TypeId
{
// the attribute itself will be used as a key to the dictionary
get { return this; }
}
///
/// Returns the hash code for this instance.
///
override public int GetHashCode()
{
// the default implementation does some funky enumeration over its fields
// we can do better and use the 2 mandatory fields source/targetType's hash codes
return _sourceType.GetHashCode() + _targetType.GetHashCode();
}
//--------------------------------------------
// Private members
//--------------------------------------------
private Type _sourceType;
private Type _targetType;
private Type _parameterType;
}
}
// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
// Copyright (c) Microsoft Corporation. All rights reserved.
//----------------------------------------------------------------------------
//
//
// Copyright (C) Microsoft Corporation. All rights reserved.
//
//
// Description: allows the author of a IValueConverter
// to specify what source and target property types the
// ValueConverter is capable of converting
//
// Specs: http://avalon/connecteddata/Specs/Data%20Binding.mht
//
//---------------------------------------------------------------------------
using System;
namespace System.Windows.Data
{
///
/// This attribute allows the author of a
/// to specify what source and target property types the ValueConverter is capable of converting.
/// This meta data is useful for designer tools to help categorize and match ValueConverters.
///
///
/// Add this custom attribute to your IValueConverter class definition.
///
/// [ValueConversion(typeof(Employee), typeof(Brush))]
/// class MyConverter : IValueConverter
/// {
/// public object Convert(object value, Type targetType, object parameter, CultureInfo culture)
/// {
/// if (value is Dev) return Brushes.Beige;
/// if (value is Employee) return Brushes.Salmon;
/// return Brushes.Yellow;
/// }
/// }
///
///
[AttributeUsage(AttributeTargets.Class, AllowMultiple = true)]
public sealed class ValueConversionAttribute : Attribute
{
//-----------------------------------------------------
//
// Constructors
//
//-----------------------------------------------------
///
/// Creates a new ValueConversionAttribute to indicate between
/// what types of a data binding source and target this ValueConverter can convert.
///
/// the expected source type this ValueConverter can handle
/// the target type to which this ValueConverter can convert to
public ValueConversionAttribute(Type sourceType, Type targetType)
{
if (sourceType == null)
throw new ArgumentNullException("sourceType");
if (targetType == null)
throw new ArgumentNullException("targetType");
_sourceType = sourceType;
_targetType = targetType;
}
///
/// The expected source type this ValueConverter can handle.
///
public Type SourceType
{
get { return _sourceType; }
}
///
/// The target type to which this ValueConverter can convert to.
///
public Type TargetType
{
get { return _targetType; }
}
///
/// The type of the optional ValueConverter Parameter object.
///
public Type ParameterType
{
get { return _parameterType; }
set { _parameterType = value; }
}
///
/// Returns the unique identifier for this Attribute.
///
// Type ID is used to remove redundant attributes by
// putting all attributes in a dictionary of [TypeId, Attribute].
// If you want AllowMultiple attributes to work with designers,
// you must override TypeId. The default implementation returns
// this.GetType(), which is appropriate for AllowMultiple = false, but
// not for AllowMultiple = true;
public override object TypeId
{
// the attribute itself will be used as a key to the dictionary
get { return this; }
}
///
/// Returns the hash code for this instance.
///
override public int GetHashCode()
{
// the default implementation does some funky enumeration over its fields
// we can do better and use the 2 mandatory fields source/targetType's hash codes
return _sourceType.GetHashCode() + _targetType.GetHashCode();
}
//--------------------------------------------
// Private members
//--------------------------------------------
private Type _sourceType;
private Type _targetType;
private Type _parameterType;
}
}
// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
// Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- DataObjectCopyingEventArgs.cs
- VariableValue.cs
- _DomainName.cs
- HotSpotCollectionEditor.cs
- DuplicateDetector.cs
- SqlNotificationRequest.cs
- ObjectReaderCompiler.cs
- SystemInfo.cs
- PropertySet.cs
- CapabilitiesPattern.cs
- InteropExecutor.cs
- SoapInteropTypes.cs
- IntSecurity.cs
- ChtmlTextWriter.cs
- ResourceCategoryAttribute.cs
- OrderedDictionary.cs
- Bitmap.cs
- HandoffBehavior.cs
- NetSectionGroup.cs
- ScaleTransform.cs
- log.cs
- PointLightBase.cs
- SortDescription.cs
- TextSpanModifier.cs
- CompiledQueryCacheEntry.cs
- EntityModelSchemaGenerator.cs
- BamlCollectionHolder.cs
- XmlName.cs
- DataTableCollection.cs
- EditorBrowsableAttribute.cs
- SourceFileInfo.cs
- XmlText.cs
- RuleAction.cs
- PolicyException.cs
- DescendantQuery.cs
- QuaternionRotation3D.cs
- SetStateDesigner.cs
- Schedule.cs
- NamespaceDecl.cs
- RectAnimationClockResource.cs
- WebRequestModulesSection.cs
- DataSourceCacheDurationConverter.cs
- StylusPoint.cs
- UserControlParser.cs
- Line.cs
- HMACSHA512.cs
- ListControl.cs
- Parser.cs
- PopOutPanel.cs
- SoapEnumAttribute.cs
- PowerStatus.cs
- DependencyObjectProvider.cs
- HtmlInputImage.cs
- LambdaCompiler.ControlFlow.cs
- CharacterHit.cs
- FrugalList.cs
- HostedBindingBehavior.cs
- ChannelManager.cs
- ExpressionBuilderContext.cs
- FontUnit.cs
- SafeNativeMethods.cs
- FocusTracker.cs
- ControlCommandSet.cs
- PointLight.cs
- SchemaImporterExtensionElementCollection.cs
- Process.cs
- Label.cs
- ColumnMapTranslator.cs
- Rect.cs
- InstancePersistence.cs
- DrawingGroupDrawingContext.cs
- ExecutedRoutedEventArgs.cs
- SqlFunctionAttribute.cs
- QilStrConcat.cs
- PerformanceCounterPermission.cs
- TypedReference.cs
- XmlConverter.cs
- _ServiceNameStore.cs
- SqlFlattener.cs
- AutoResetEvent.cs
- ValidationHelpers.cs
- CodeParameterDeclarationExpression.cs
- BuildResultCache.cs
- SelectionWordBreaker.cs
- MouseButtonEventArgs.cs
- GPRECTF.cs
- XmlSchemaValidator.cs
- DataGridTableCollection.cs
- XmlDataSource.cs
- AsyncOperationManager.cs
- ToolStripItemCollection.cs
- JsonWriter.cs
- Point3DAnimationBase.cs
- BuilderInfo.cs
- DLinqTableProvider.cs
- WorkBatch.cs
- NumericPagerField.cs
- AnnotationObservableCollection.cs
- SqlMethods.cs
- RequiredFieldValidator.cs