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 / Controls / AdornedElementPlaceholder.cs / 1 / AdornedElementPlaceholder.cs
//---------------------------------------------------------------------------- // //// Copyright (C) 2005 by Microsoft Corporation. All rights reserved. // // // // Description: // AdornedElementPlaceholder is an element used in a Binding.ErrorTemplate. // Its purpose is to mimic the height and width of the AdornedElement so that // other elements in Template can be arranged around or within it. // // See specs at http://avalon/connecteddata/Specs/Validation.mht // // History: // 02/01/2005 mharper: created. // //--------------------------------------------------------------------------- using System; using System.Collections; using System.Collections.Specialized; using System.ComponentModel; using System.Diagnostics; using System.Windows.Media; using System.Windows; using System.Windows.Data; using System.Windows.Documents; using System.Windows.Markup; using MS.Internal.Controls; using MS.Utility; namespace System.Windows.Controls { ////// The base class for all controls. /// [ContentProperty("Child")] public class AdornedElementPlaceholder : FrameworkElement, IAddChild { #region Constructors ////// Default Control constructor /// ////// Automatic determination of current Dispatcher. Use alternative constructor /// that accepts a Dispatcher for best performance. /// public AdornedElementPlaceholder() : base() { } #endregion Constructors ////// This method is called to Add the object as a child. This method is used primarily /// by the parser; a more direct way of adding a child is to use the /// /// The object to add as a child; it must be a UIElement. /// void IAddChild.AddChild (Object value) { // keeping consistent with other elements: adding null is a no-op. if (value == null) return; if (!(value is UIElement)) throw new ArgumentException (SR.Get(SRID.UnexpectedParameterType, value.GetType(), typeof(UIElement)), "value"); if (this.Child != null) throw new ArgumentException(SR.Get(SRID.CanOnlyHaveOneChild, this.GetType(), value.GetType())); this.Child = (UIElement)value; } ////// property. /// /// This method is called by the parser when text appears under the tag in markup. /// Calling this method has no effect if text is just whitespace. If text is not /// just whitespace, throw an exception. /// /// /// Text to add as a child. /// void IAddChild.AddText (string text) { XamlSerializerUtil.ThrowIfNonWhiteSpaceInAddText(text, this); } ////// Element for which the AdornedElementPlaceholder is reserving space. /// public UIElement AdornedElement { get { TemplatedAdorner adorner = TemplatedAdorner; return adorner == null ? null : TemplatedAdorner.AdornedElement; } } ////// The single child of an [DefaultValue(null)] public virtual UIElement Child { get { return _child; } set { UIElement old = _child; if (old != value) { RemoveVisualChild(old); //need to remove old element from logical tree RemoveLogicalChild(old); _child = value; AddVisualChild(_child); AddLogicalChild(value); InvalidateMeasure(); } } } ////// /// Gets the Visual children count. /// protected override int VisualChildrenCount { get { return (_child == null) ? 0 : 1; } } ////// Gets the Visual child at the specified index. /// protected override Visual GetVisualChild(int index) { if (_child == null || index != 0) { throw new ArgumentOutOfRangeException("index", index, SR.Get(SRID.Visual_ArgumentOutOfRange)); } return _child; } ////// Returns enumerator to logical children. /// protected internal override IEnumerator LogicalChildren { get { // Could optimize this code by returning EmptyEnumerator.Instance if _child == null. return new SingleChildEnumerator(_child); } } ////// This virtual method in called when IsInitialized is set to true and it raises an Initialized event /// protected override void OnInitialized(EventArgs e) { if (TemplatedParent == null) throw new InvalidOperationException(SR.Get(SRID.AdornedElementPlaceholderMustBeInTemplate)); base.OnInitialized(e); } ////// AdornedElementPlaceholder measure behavior is to measure /// only the first visual child. Note that the return value /// of Measure on this child is ignored as the purpose of this /// class is to match the size of the element for which this /// is a placeholder. /// /// The measurement constraints. ///The desired size of the control. protected override Size MeasureOverride(Size constraint) { if (TemplatedParent == null) throw new InvalidOperationException(SR.Get(SRID.AdornedElementPlaceholderMustBeInTemplate)); if (AdornedElement == null) return new Size(0,0); Size desiredSize = AdornedElement.RenderSize; UIElement child = Child; if (child != null) child.Measure(desiredSize); return desiredSize; } ////// Default AdornedElementPlaceholder arrangement is to only arrange /// the first visual child. No transforms will be applied. /// /// The computed size. protected override Size ArrangeOverride(Size arrangeBounds) { UIElement child = Child; if (child != null) child.Arrange(new Rect(arrangeBounds)); return arrangeBounds; } private TemplatedAdorner TemplatedAdorner { get { if (_templatedAdorner == null) { // find the TemplatedAdorner FrameworkElement templateParent = this.TemplatedParent as FrameworkElement; if (templateParent != null) { _templatedAdorner = VisualTreeHelper.GetParent(templateParent) as TemplatedAdorner; if (_templatedAdorner != null && _templatedAdorner.ReferenceElement == null) { _templatedAdorner.ReferenceElement = this; } } } return _templatedAdorner; } } private UIElement _child; private TemplatedAdorner _templatedAdorner; } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. //---------------------------------------------------------------------------- // //// Copyright (C) 2005 by Microsoft Corporation. All rights reserved. // // // // Description: // AdornedElementPlaceholder is an element used in a Binding.ErrorTemplate. // Its purpose is to mimic the height and width of the AdornedElement so that // other elements in Template can be arranged around or within it. // // See specs at http://avalon/connecteddata/Specs/Validation.mht // // History: // 02/01/2005 mharper: created. // //--------------------------------------------------------------------------- using System; using System.Collections; using System.Collections.Specialized; using System.ComponentModel; using System.Diagnostics; using System.Windows.Media; using System.Windows; using System.Windows.Data; using System.Windows.Documents; using System.Windows.Markup; using MS.Internal.Controls; using MS.Utility; namespace System.Windows.Controls { ////// The base class for all controls. /// [ContentProperty("Child")] public class AdornedElementPlaceholder : FrameworkElement, IAddChild { #region Constructors ////// Default Control constructor /// ////// Automatic determination of current Dispatcher. Use alternative constructor /// that accepts a Dispatcher for best performance. /// public AdornedElementPlaceholder() : base() { } #endregion Constructors ////// This method is called to Add the object as a child. This method is used primarily /// by the parser; a more direct way of adding a child is to use the /// /// The object to add as a child; it must be a UIElement. /// void IAddChild.AddChild (Object value) { // keeping consistent with other elements: adding null is a no-op. if (value == null) return; if (!(value is UIElement)) throw new ArgumentException (SR.Get(SRID.UnexpectedParameterType, value.GetType(), typeof(UIElement)), "value"); if (this.Child != null) throw new ArgumentException(SR.Get(SRID.CanOnlyHaveOneChild, this.GetType(), value.GetType())); this.Child = (UIElement)value; } ////// property. /// /// This method is called by the parser when text appears under the tag in markup. /// Calling this method has no effect if text is just whitespace. If text is not /// just whitespace, throw an exception. /// /// /// Text to add as a child. /// void IAddChild.AddText (string text) { XamlSerializerUtil.ThrowIfNonWhiteSpaceInAddText(text, this); } ////// Element for which the AdornedElementPlaceholder is reserving space. /// public UIElement AdornedElement { get { TemplatedAdorner adorner = TemplatedAdorner; return adorner == null ? null : TemplatedAdorner.AdornedElement; } } ////// The single child of an [DefaultValue(null)] public virtual UIElement Child { get { return _child; } set { UIElement old = _child; if (old != value) { RemoveVisualChild(old); //need to remove old element from logical tree RemoveLogicalChild(old); _child = value; AddVisualChild(_child); AddLogicalChild(value); InvalidateMeasure(); } } } ////// /// Gets the Visual children count. /// protected override int VisualChildrenCount { get { return (_child == null) ? 0 : 1; } } ////// Gets the Visual child at the specified index. /// protected override Visual GetVisualChild(int index) { if (_child == null || index != 0) { throw new ArgumentOutOfRangeException("index", index, SR.Get(SRID.Visual_ArgumentOutOfRange)); } return _child; } ////// Returns enumerator to logical children. /// protected internal override IEnumerator LogicalChildren { get { // Could optimize this code by returning EmptyEnumerator.Instance if _child == null. return new SingleChildEnumerator(_child); } } ////// This virtual method in called when IsInitialized is set to true and it raises an Initialized event /// protected override void OnInitialized(EventArgs e) { if (TemplatedParent == null) throw new InvalidOperationException(SR.Get(SRID.AdornedElementPlaceholderMustBeInTemplate)); base.OnInitialized(e); } ////// AdornedElementPlaceholder measure behavior is to measure /// only the first visual child. Note that the return value /// of Measure on this child is ignored as the purpose of this /// class is to match the size of the element for which this /// is a placeholder. /// /// The measurement constraints. ///The desired size of the control. protected override Size MeasureOverride(Size constraint) { if (TemplatedParent == null) throw new InvalidOperationException(SR.Get(SRID.AdornedElementPlaceholderMustBeInTemplate)); if (AdornedElement == null) return new Size(0,0); Size desiredSize = AdornedElement.RenderSize; UIElement child = Child; if (child != null) child.Measure(desiredSize); return desiredSize; } ////// Default AdornedElementPlaceholder arrangement is to only arrange /// the first visual child. No transforms will be applied. /// /// The computed size. protected override Size ArrangeOverride(Size arrangeBounds) { UIElement child = Child; if (child != null) child.Arrange(new Rect(arrangeBounds)); return arrangeBounds; } private TemplatedAdorner TemplatedAdorner { get { if (_templatedAdorner == null) { // find the TemplatedAdorner FrameworkElement templateParent = this.TemplatedParent as FrameworkElement; if (templateParent != null) { _templatedAdorner = VisualTreeHelper.GetParent(templateParent) as TemplatedAdorner; if (_templatedAdorner != null && _templatedAdorner.ReferenceElement == null) { _templatedAdorner.ReferenceElement = this; } } } return _templatedAdorner; } } private UIElement _child; private TemplatedAdorner _templatedAdorner; } } // 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
- BoundField.cs
- TraceHandler.cs
- SiteMapDataSourceView.cs
- Fonts.cs
- ComEventsSink.cs
- MethodToken.cs
- CapabilitiesPattern.cs
- BaseEntityWrapper.cs
- SafeNativeMethodsMilCoreApi.cs
- DesignBindingValueUIHandler.cs
- HtmlShimManager.cs
- FileDialogCustomPlace.cs
- CodeBinaryOperatorExpression.cs
- x509utils.cs
- Nodes.cs
- GB18030Encoding.cs
- Number.cs
- Timer.cs
- ScrollChangedEventArgs.cs
- ErrorFormatter.cs
- MultiAsyncResult.cs
- CodeNamespace.cs
- CompatibleIComparer.cs
- Vector3DKeyFrameCollection.cs
- TextServicesCompartmentEventSink.cs
- DigitShape.cs
- WindowsButton.cs
- TreeNodeBindingCollection.cs
- IInstanceContextProvider.cs
- WorkflowServiceHost.cs
- XsdDateTime.cs
- Authorization.cs
- DPCustomTypeDescriptor.cs
- RegistryKey.cs
- PartialArray.cs
- HtmlInputButton.cs
- GatewayDefinition.cs
- ResourceExpressionBuilder.cs
- SeekStoryboard.cs
- ListViewItem.cs
- DataServiceQueryOfT.cs
- NullableBoolConverter.cs
- ItemsPresenter.cs
- userdatakeys.cs
- TextEditorThreadLocalStore.cs
- NavigateEvent.cs
- TextProperties.cs
- CallbackWrapper.cs
- Compiler.cs
- Stroke.cs
- FixedTextContainer.cs
- ArraySegment.cs
- RegexWorker.cs
- MonthChangedEventArgs.cs
- SignatureGenerator.cs
- Pair.cs
- ActiveDocumentEvent.cs
- ChangesetResponse.cs
- Parameter.cs
- OdbcCommandBuilder.cs
- BrowserCapabilitiesFactoryBase.cs
- TransformCollection.cs
- ExtenderProvidedPropertyAttribute.cs
- HttpResponseBase.cs
- InputReportEventArgs.cs
- LinqMaximalSubtreeNominator.cs
- DetailsViewDeletedEventArgs.cs
- bidPrivateBase.cs
- AttributeCollection.cs
- ProcessingInstructionAction.cs
- XDRSchema.cs
- DeadLetterQueue.cs
- ConnectionPoint.cs
- DataContractJsonSerializerOperationBehavior.cs
- DocumentSequenceHighlightLayer.cs
- TypedDataSetSchemaImporterExtensionFx35.cs
- sitestring.cs
- ArrayWithOffset.cs
- ElementHostAutomationPeer.cs
- Descriptor.cs
- XpsFilter.cs
- FlowLayoutSettings.cs
- XPathChildIterator.cs
- DataGridClipboardHelper.cs
- SqlDataSourceSelectingEventArgs.cs
- HttpProfileGroupBase.cs
- TextTreeObjectNode.cs
- EventPropertyMap.cs
- CacheMode.cs
- NativeMethods.cs
- PaginationProgressEventArgs.cs
- ConfigurationPropertyCollection.cs
- ResourceType.cs
- TrailingSpaceComparer.cs
- TimersDescriptionAttribute.cs
- ProjectionAnalyzer.cs
- DataGridViewColumnConverter.cs
- PackageRelationshipCollection.cs
- PaperSource.cs
- TextShapeableCharacters.cs