Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / wpf / src / Framework / System / Windows / Data / ValueConversionAttribute.cs / 1305600 / 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
- LicenseProviderAttribute.cs
- EpmTargetTree.cs
- BitmapEncoder.cs
- InkCanvasSelection.cs
- ToolboxItem.cs
- BrowserCapabilitiesCodeGenerator.cs
- StrokeNodeOperations.cs
- TempFiles.cs
- MenuItemCollectionEditorDialog.cs
- FamilyMapCollection.cs
- WebColorConverter.cs
- SqlInternalConnection.cs
- DBSqlParserTableCollection.cs
- DefaultWorkflowSchedulerService.cs
- DataObjectAttribute.cs
- CapabilitiesSection.cs
- DataTableNewRowEvent.cs
- LockCookie.cs
- FileVersionInfo.cs
- RtfControlWordInfo.cs
- SafeThemeHandle.cs
- ConfigXmlSignificantWhitespace.cs
- HttpRuntime.cs
- CategoryState.cs
- PropertyCondition.cs
- WebBrowser.cs
- TimelineGroup.cs
- InputLangChangeEvent.cs
- CachedTypeface.cs
- SafeLocalMemHandle.cs
- UnsafeNativeMethods.cs
- WeakReference.cs
- Assert.cs
- ComboBox.cs
- PropertyGridCommands.cs
- XmlUtil.cs
- SQLBinaryStorage.cs
- CompilerCollection.cs
- ArrangedElement.cs
- WS2007FederationHttpBinding.cs
- BinaryUtilClasses.cs
- EntitySqlException.cs
- PointCollectionValueSerializer.cs
- SortDescriptionCollection.cs
- BridgeDataReader.cs
- CodeTypeReferenceCollection.cs
- AnnotationDocumentPaginator.cs
- Inline.cs
- ResponseStream.cs
- PointAnimationBase.cs
- TextDecorationCollection.cs
- WorkflowPersistenceService.cs
- DomainUpDown.cs
- XmlSchemaComplexContentExtension.cs
- CommonDialog.cs
- FieldDescriptor.cs
- EmbeddedMailObject.cs
- ScriptResourceInfo.cs
- XamlGridLengthSerializer.cs
- PropertyTab.cs
- IdentitySection.cs
- DynamicResourceExtensionConverter.cs
- SharedPerformanceCounter.cs
- ControlUtil.cs
- UInt16Converter.cs
- ContextDataSourceContextData.cs
- DoubleCollectionValueSerializer.cs
- PropertyChangingEventArgs.cs
- FrameworkElement.cs
- LogPolicy.cs
- RemoteWebConfigurationHost.cs
- CommittableTransaction.cs
- OleDbInfoMessageEvent.cs
- MissingMemberException.cs
- DefaultHttpHandler.cs
- AggregateException.cs
- ResourceDescriptionAttribute.cs
- ArrayExtension.cs
- activationcontext.cs
- XmlAnyAttributeAttribute.cs
- WindowsBrush.cs
- bindurihelper.cs
- DynamicDataRoute.cs
- TextFormatter.cs
- DataGridPagerStyle.cs
- GridViewRow.cs
- SymbolType.cs
- RewritingValidator.cs
- EventSourceCreationData.cs
- SecurityRequiresReviewAttribute.cs
- TextTreeTextBlock.cs
- ValidatorUtils.cs
- InstanceLockQueryResult.cs
- MembershipUser.cs
- ToolboxCategory.cs
- HtmlSelect.cs
- HtmlTableRow.cs
- CompressionTransform.cs
- TraceUtility.cs
- XmlIlGenerator.cs