Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / Orcas / QFE / 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. /// [AttributeUsage(AttributeTargets.Class, AllowMultiple = true)] public sealed class ValueConversionAttribute : Attribute { //----------------------------------------------------- // // Constructors // //----------------------------------------------------- ////// [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; /// } /// } ///
////// 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. /// [AttributeUsage(AttributeTargets.Class, AllowMultiple = true)] public sealed class ValueConversionAttribute : Attribute { //----------------------------------------------------- // // Constructors // //----------------------------------------------------- ////// [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; /// } /// } ///
////// 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
- MetadataSection.cs
- DesignerActionPanel.cs
- LiteralControl.cs
- BitHelper.cs
- ToolBar.cs
- BufferBuilder.cs
- FormatException.cs
- RichTextBoxAutomationPeer.cs
- EmptyReadOnlyDictionaryInternal.cs
- EntitySqlQueryBuilder.cs
- EncoderParameters.cs
- SafeRightsManagementEnvironmentHandle.cs
- Vector.cs
- SmiContext.cs
- CorrelationToken.cs
- GraphicsContainer.cs
- ProxyGenerationError.cs
- IndependentAnimationStorage.cs
- PkcsMisc.cs
- PassportIdentity.cs
- DataError.cs
- TextRangeEditLists.cs
- TagNameToTypeMapper.cs
- Font.cs
- PeerNameRegistration.cs
- glyphs.cs
- Graph.cs
- DbInsertCommandTree.cs
- DoubleAnimationUsingPath.cs
- DictionaryItemsCollection.cs
- ShaderRenderModeValidation.cs
- XPathException.cs
- UpdateExpressionVisitor.cs
- ScriptMethodAttribute.cs
- PixelShader.cs
- propertytag.cs
- DataFormats.cs
- CodeTypeReferenceCollection.cs
- SchemaImporterExtensionElementCollection.cs
- DropDownButton.cs
- SoapAttributeAttribute.cs
- CatalogPartCollection.cs
- ColorTranslator.cs
- Duration.cs
- EditorPartCollection.cs
- PathParser.cs
- WorkflowExecutor.cs
- OutputWindow.cs
- TextFormatterContext.cs
- XmlUtil.cs
- TableCellCollection.cs
- ScopeCollection.cs
- JsonGlobals.cs
- GeometryValueSerializer.cs
- CompilerError.cs
- AttachedPropertyBrowsableAttribute.cs
- AnnotationHighlightLayer.cs
- ResizeGrip.cs
- SourceFilter.cs
- CategoryAttribute.cs
- DrawingCollection.cs
- jithelpers.cs
- DateTimeOffset.cs
- Vector3DConverter.cs
- StrokeNodeData.cs
- FrugalMap.cs
- DecimalAnimationUsingKeyFrames.cs
- ClientProxyGenerator.cs
- ProcessInputEventArgs.cs
- ChildrenQuery.cs
- SessionPageStatePersister.cs
- InternalCache.cs
- BindableTemplateBuilder.cs
- Misc.cs
- WaitHandleCannotBeOpenedException.cs
- GridViewEditEventArgs.cs
- XmlAttributes.cs
- ToolboxItemImageConverter.cs
- TraceRecord.cs
- Label.cs
- PrtCap_Public_Simple.cs
- MultiplexingFormatMapping.cs
- ByteFacetDescriptionElement.cs
- PagePropertiesChangingEventArgs.cs
- CellTreeNodeVisitors.cs
- VisualTreeUtils.cs
- CellTreeSimplifier.cs
- WebSysDefaultValueAttribute.cs
- SqlProvider.cs
- AddressHeaderCollection.cs
- DebugHandleTracker.cs
- ServiceHostingEnvironment.cs
- ContactManager.cs
- XmlWriter.cs
- XpsS0ValidatingLoader.cs
- UniformGrid.cs
- printdlgexmarshaler.cs
- WebPartCatalogCloseVerb.cs
- EntityClientCacheEntry.cs
- ResourceExpressionBuilder.cs