Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / Orcas / SP / wpf / src / Framework / System / Windows / DataTemplate.cs / 2 / DataTemplate.cs
//---------------------------------------------------------------------------- // //// Copyright (C) Microsoft Corporation. All rights reserved. // // // Description: DataTemplate describes how to display a single data item. // // Specs: http://avalon/coreui/Specs%20%20Property%20Engine/Styling%20Revisited.doc // //--------------------------------------------------------------------------- using System.ComponentModel; using System.Windows.Controls; using System.Windows.Markup; namespace System.Windows { ////// DataTemplate describes how to display a single data item. /// [DictionaryKeyProperty("DataTemplateKey")] public class DataTemplate : FrameworkTemplate { #region Constructors //------------------------------------------------------------------- // // Constructors // //------------------------------------------------------------------- ////// DataTemplate Constructor /// public DataTemplate() { } ////// DataTemplate Constructor /// public DataTemplate(object dataType) { Exception ex = TemplateKey.ValidateDataType(dataType, "dataType"); if (ex != null) throw ex; _dataType = dataType; } #endregion Constructors #region Public Properties //-------------------------------------------------------------------- // // Public Properties // //------------------------------------------------------------------- ////// DataType for this DataTemplate. If the template is intended /// for object data, this is the Type of the data. If the /// template is intended for XML data, this is the tag name /// of the data (i.e. a string). /// [DefaultValue(null)] public object DataType { get { return _dataType; } set { Exception ex = TemplateKey.ValidateDataType(value, "value"); if (ex != null) throw ex; CheckSealed(); _dataType = value; } } ////// Collection of Triggers /// [DesignerSerializationVisibility(DesignerSerializationVisibility.Content)] [DependsOn("VisualTree")] public TriggerCollection Triggers { get { if (_triggers == null) { _triggers = new TriggerCollection(); // If the template has been sealed prior to this the newly // created TriggerCollection also needs to be sealed if (IsSealed) { _triggers.Seal(); } } return _triggers; } } ////// The key that will be used if the DataTemplate is added to a /// ResourceDictionary in Xaml without a specified Key (x:Key). /// public object DataTemplateKey { get { return (DataType != null) ? new DataTemplateKey(DataType) : null; } } #endregion PublicProperties #region Internal Properties //-------------------------------------------------------------------- // // Internal Properties // //-------------------------------------------------------------------- // // TargetType for DataTemplate. This is override is // so FrameworkTemplate can see this property. // internal override Type TargetTypeInternal { get { return DefaultTargetType; } } // Subclasses must provide a way for the parser to directly set the // target type. For DataTemplate, this is not allowed. internal override void SetTargetTypeInternal(Type targetType) { throw new InvalidOperationException(SR.Get(SRID.TemplateNotTargetType)); } // // DataType for DataTemplate. This is override is // so FrameworkTemplate can see this property. // internal override object DataTypeInternal { get { return DataType; } } // // Collection of Triggers for a DataTemplate. This is // override is so FrameworkTemplate can see this property. // internal override TriggerCollection TriggersInternal { get { return Triggers; } } // Target type of DataTrigger is ContentPresenter static internal Type DefaultTargetType { get { return typeof(ContentPresenter); } } #endregion Internal Properties #region Protected Methods //------------------------------------------------------------------- // // Protected Methods // //-------------------------------------------------------------------- ////// Validate against the following rules /// 1. Must have a non-null feTemplatedParent /// 2. A DataTemplate must be applied to a ContentPresenter /// protected override void ValidateTemplatedParent(FrameworkElement templatedParent) { // Must have a non-null feTemplatedParent if (templatedParent == null) { throw new ArgumentNullException("templatedParent"); } // A DataTemplate must be applied to a ContentPresenter if (!(templatedParent is ContentPresenter)) { throw new ArgumentException(SR.Get(SRID.TemplateTargetTypeMismatch, "ContentPresenter", templatedParent.GetType().Name)); } } #endregion Protected Methods #region Data private object _dataType; private TriggerCollection _triggers; #endregion Data } } // 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: DataTemplate describes how to display a single data item. // // Specs: http://avalon/coreui/Specs%20%20Property%20Engine/Styling%20Revisited.doc // //--------------------------------------------------------------------------- using System.ComponentModel; using System.Windows.Controls; using System.Windows.Markup; namespace System.Windows { ////// DataTemplate describes how to display a single data item. /// [DictionaryKeyProperty("DataTemplateKey")] public class DataTemplate : FrameworkTemplate { #region Constructors //------------------------------------------------------------------- // // Constructors // //------------------------------------------------------------------- ////// DataTemplate Constructor /// public DataTemplate() { } ////// DataTemplate Constructor /// public DataTemplate(object dataType) { Exception ex = TemplateKey.ValidateDataType(dataType, "dataType"); if (ex != null) throw ex; _dataType = dataType; } #endregion Constructors #region Public Properties //-------------------------------------------------------------------- // // Public Properties // //------------------------------------------------------------------- ////// DataType for this DataTemplate. If the template is intended /// for object data, this is the Type of the data. If the /// template is intended for XML data, this is the tag name /// of the data (i.e. a string). /// [DefaultValue(null)] public object DataType { get { return _dataType; } set { Exception ex = TemplateKey.ValidateDataType(value, "value"); if (ex != null) throw ex; CheckSealed(); _dataType = value; } } ////// Collection of Triggers /// [DesignerSerializationVisibility(DesignerSerializationVisibility.Content)] [DependsOn("VisualTree")] public TriggerCollection Triggers { get { if (_triggers == null) { _triggers = new TriggerCollection(); // If the template has been sealed prior to this the newly // created TriggerCollection also needs to be sealed if (IsSealed) { _triggers.Seal(); } } return _triggers; } } ////// The key that will be used if the DataTemplate is added to a /// ResourceDictionary in Xaml without a specified Key (x:Key). /// public object DataTemplateKey { get { return (DataType != null) ? new DataTemplateKey(DataType) : null; } } #endregion PublicProperties #region Internal Properties //-------------------------------------------------------------------- // // Internal Properties // //-------------------------------------------------------------------- // // TargetType for DataTemplate. This is override is // so FrameworkTemplate can see this property. // internal override Type TargetTypeInternal { get { return DefaultTargetType; } } // Subclasses must provide a way for the parser to directly set the // target type. For DataTemplate, this is not allowed. internal override void SetTargetTypeInternal(Type targetType) { throw new InvalidOperationException(SR.Get(SRID.TemplateNotTargetType)); } // // DataType for DataTemplate. This is override is // so FrameworkTemplate can see this property. // internal override object DataTypeInternal { get { return DataType; } } // // Collection of Triggers for a DataTemplate. This is // override is so FrameworkTemplate can see this property. // internal override TriggerCollection TriggersInternal { get { return Triggers; } } // Target type of DataTrigger is ContentPresenter static internal Type DefaultTargetType { get { return typeof(ContentPresenter); } } #endregion Internal Properties #region Protected Methods //------------------------------------------------------------------- // // Protected Methods // //-------------------------------------------------------------------- ////// Validate against the following rules /// 1. Must have a non-null feTemplatedParent /// 2. A DataTemplate must be applied to a ContentPresenter /// protected override void ValidateTemplatedParent(FrameworkElement templatedParent) { // Must have a non-null feTemplatedParent if (templatedParent == null) { throw new ArgumentNullException("templatedParent"); } // A DataTemplate must be applied to a ContentPresenter if (!(templatedParent is ContentPresenter)) { throw new ArgumentException(SR.Get(SRID.TemplateTargetTypeMismatch, "ContentPresenter", templatedParent.GetType().Name)); } } #endregion Protected Methods #region Data private object _dataType; private TriggerCollection _triggers; #endregion Data } } // 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
- RegistryKey.cs
- TypeInfo.cs
- OdbcFactory.cs
- mactripleDES.cs
- CompilerParameters.cs
- WebPartDisplayModeEventArgs.cs
- ExpanderAutomationPeer.cs
- XmlSerializableServices.cs
- SecurityKeyIdentifier.cs
- Tokenizer.cs
- HttpStaticObjectsCollectionWrapper.cs
- SemaphoreFullException.cs
- Point3DCollectionValueSerializer.cs
- OrderedDictionaryStateHelper.cs
- HttpListenerException.cs
- ProfileInfo.cs
- ResourceAttributes.cs
- RedBlackList.cs
- PenLineCapValidation.cs
- XmlSchemas.cs
- SystemInformation.cs
- WebPartConnectionsDisconnectVerb.cs
- FontUnitConverter.cs
- SqlTransaction.cs
- StringInfo.cs
- PermissionAttributes.cs
- GeometryDrawing.cs
- TextEffectResolver.cs
- ToolStripMenuItem.cs
- MonitorWrapper.cs
- ETagAttribute.cs
- Attachment.cs
- IsolatedStoragePermission.cs
- ClientTargetCollection.cs
- DescendantBaseQuery.cs
- WebScriptMetadataMessageEncoderFactory.cs
- SchemaTypeEmitter.cs
- Matrix.cs
- TextBox.cs
- SelectionWordBreaker.cs
- SafeFileMapViewHandle.cs
- ETagAttribute.cs
- Input.cs
- cookiecontainer.cs
- PopOutPanel.cs
- HandleCollector.cs
- BindingContext.cs
- XmlExceptionHelper.cs
- MultiSelector.cs
- TemplatedMailWebEventProvider.cs
- BaseComponentEditor.cs
- PackWebRequestFactory.cs
- FileVersionInfo.cs
- OrderedEnumerableRowCollection.cs
- CommonObjectSecurity.cs
- X509SubjectKeyIdentifierClause.cs
- RawStylusActions.cs
- SequentialOutput.cs
- EdmScalarPropertyAttribute.cs
- SelectedCellsChangedEventArgs.cs
- BamlResourceContent.cs
- SafeBuffer.cs
- Helper.cs
- WindowClosedEventArgs.cs
- XmlAnyElementAttribute.cs
- AttachedAnnotationChangedEventArgs.cs
- CapacityStreamGeometryContext.cs
- CompositeTypefaceMetrics.cs
- IncrementalReadDecoders.cs
- HttpCachePolicyElement.cs
- ChtmlLinkAdapter.cs
- RandomNumberGenerator.cs
- SafeHandles.cs
- ClientRequest.cs
- Page.cs
- ObjectDataProvider.cs
- ChildTable.cs
- ListViewInsertEventArgs.cs
- TCPClient.cs
- xmlfixedPageInfo.cs
- CriticalExceptions.cs
- IPCCacheManager.cs
- ComponentEditorPage.cs
- SimpleApplicationHost.cs
- ReadOnlyCollection.cs
- ItemContainerProviderWrapper.cs
- HitTestResult.cs
- UnsafeNativeMethods.cs
- WindowsAltTab.cs
- XmlEventCache.cs
- GetWinFXPath.cs
- Util.cs
- MdiWindowListItemConverter.cs
- Validator.cs
- Annotation.cs
- HostedImpersonationContext.cs
- ListViewHitTestInfo.cs
- ObjectKeyFrameCollection.cs
- SafeHandle.cs
- _HeaderInfo.cs