Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / wpf / src / Framework / System / Windows / SizeChangedEventArgs.cs / 1305600 / SizeChangedEventArgs.cs
using System; namespace System.Windows { ////// The SizeChangedEventArgs class is used by SizeChangedEventHandler. /// This handler is used for ComputedWidthChanged and ComputedHeightChanged events /// on UIElement. /// public class SizeChangedEventArgs : RoutedEventArgs { ////// Initializes a new instance of the SizeChangedEventArgs class. /// /// /// The UIElement which has its size changed by layout engine/>. /// /// /// The SizeChangeInfo that is used by. /// internal SizeChangedEventArgs(UIElement element, SizeChangedInfo info) { if (info == null) { throw new ArgumentNullException("info"); } if (element == null) { throw new ArgumentNullException("element"); } _element = element; _previousSize = info.PreviousSize; if(info.WidthChanged) _bits |= _widthChangedBit; if(info.HeightChanged) _bits |= _heightChangedBit; } /// /// Read-only access to the previous Size /// public Size PreviousSize { get { return _previousSize; } } ////// Read-only access to the new Size /// public Size NewSize { get { return _element.RenderSize; } } ////// Read-only access to the flag indicating that Width component of the size changed. /// Note that due to double math /// effects, the it may be (previousSize.Width != newSize.Width) and widthChanged = true. /// This may happen in layout when sizes of objects are fluctuating because of a precision "jitter" of /// the input parameters, but the overall scene is considered to be "the same" so no visible changes /// will be detected. Typically, the handler of SizeChangedEvent should check this bit to avoid /// invalidation of layout if the dimension didn't change. /// public bool WidthChanged { get { return ((_bits & _widthChangedBit) != 0); } } ////// Read-only access to the flag indicating that Height component of the size changed. /// Note that due to double math /// effects, the it may be (previousSize.Height != newSize.Height) and heightChanged = true. /// This may happen in layout when sizes of objects are fluctuating because of a precision "jitter" of /// the input parameters, but the overall scene is considered to be "the same" so no visible changes /// will be detected. Typically, the handler of SizeChangedEvent should check this bit to avoid /// invalidation of layout if the dimension didn't change. /// public bool HeightChanged { get { return ((_bits & _heightChangedBit) != 0); } } private Size _previousSize; private UIElement _element; private byte _bits; private static byte _widthChangedBit = 0x1; private static byte _heightChangedBit = 0x2; ////// The mechanism used to call the type-specific handler on the /// target. /// /// /// The generic handler to call in a type-specific way. /// /// /// The target to call the handler on. /// ///protected override void InvokeEventHandler(Delegate genericHandler, object genericTarget) { SizeChangedEventHandler handler = (SizeChangedEventHandler) genericHandler; handler(genericTarget, this); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. using System; namespace System.Windows { /// /// The SizeChangedEventArgs class is used by SizeChangedEventHandler. /// This handler is used for ComputedWidthChanged and ComputedHeightChanged events /// on UIElement. /// public class SizeChangedEventArgs : RoutedEventArgs { ////// Initializes a new instance of the SizeChangedEventArgs class. /// /// /// The UIElement which has its size changed by layout engine/>. /// /// /// The SizeChangeInfo that is used by. /// internal SizeChangedEventArgs(UIElement element, SizeChangedInfo info) { if (info == null) { throw new ArgumentNullException("info"); } if (element == null) { throw new ArgumentNullException("element"); } _element = element; _previousSize = info.PreviousSize; if(info.WidthChanged) _bits |= _widthChangedBit; if(info.HeightChanged) _bits |= _heightChangedBit; } /// /// Read-only access to the previous Size /// public Size PreviousSize { get { return _previousSize; } } ////// Read-only access to the new Size /// public Size NewSize { get { return _element.RenderSize; } } ////// Read-only access to the flag indicating that Width component of the size changed. /// Note that due to double math /// effects, the it may be (previousSize.Width != newSize.Width) and widthChanged = true. /// This may happen in layout when sizes of objects are fluctuating because of a precision "jitter" of /// the input parameters, but the overall scene is considered to be "the same" so no visible changes /// will be detected. Typically, the handler of SizeChangedEvent should check this bit to avoid /// invalidation of layout if the dimension didn't change. /// public bool WidthChanged { get { return ((_bits & _widthChangedBit) != 0); } } ////// Read-only access to the flag indicating that Height component of the size changed. /// Note that due to double math /// effects, the it may be (previousSize.Height != newSize.Height) and heightChanged = true. /// This may happen in layout when sizes of objects are fluctuating because of a precision "jitter" of /// the input parameters, but the overall scene is considered to be "the same" so no visible changes /// will be detected. Typically, the handler of SizeChangedEvent should check this bit to avoid /// invalidation of layout if the dimension didn't change. /// public bool HeightChanged { get { return ((_bits & _heightChangedBit) != 0); } } private Size _previousSize; private UIElement _element; private byte _bits; private static byte _widthChangedBit = 0x1; private static byte _heightChangedBit = 0x2; ////// The mechanism used to call the type-specific handler on the /// target. /// /// /// The generic handler to call in a type-specific way. /// /// /// The target to call the handler on. /// ///protected override void InvokeEventHandler(Delegate genericHandler, object genericTarget) { SizeChangedEventHandler handler = (SizeChangedEventHandler) genericHandler; handler(genericTarget, this); } } } // 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
- EdgeProfileValidation.cs
- ToolStripDropDownItemDesigner.cs
- ImportedNamespaceContextItem.cs
- Table.cs
- PixelFormats.cs
- DocumentXmlWriter.cs
- GACIdentityPermission.cs
- CustomLineCap.cs
- SqlConnectionString.cs
- DashStyles.cs
- Membership.cs
- ClaimTypes.cs
- XmlSchemaAnnotation.cs
- KeyGestureValueSerializer.cs
- ContextDataSourceContextData.cs
- Object.cs
- PanelDesigner.cs
- HtmlImage.cs
- WindowsFormsDesignerOptionService.cs
- SQLDateTimeStorage.cs
- TypeTypeConverter.cs
- ListParagraph.cs
- SessionStateContainer.cs
- ClientEndpointLoader.cs
- XmlSerializerSection.cs
- ToolStripItemTextRenderEventArgs.cs
- CustomAttributeFormatException.cs
- DesigntimeLicenseContextSerializer.cs
- StylusTouchDevice.cs
- Mappings.cs
- EdmSchemaAttribute.cs
- RichTextBoxAutomationPeer.cs
- QueryExpr.cs
- EventListenerClientSide.cs
- ArithmeticException.cs
- Stackframe.cs
- SafeNativeMethods.cs
- XmlIterators.cs
- XmlDesignerDataSourceView.cs
- SafeProcessHandle.cs
- UInt32Storage.cs
- ReachPrintTicketSerializer.cs
- AppLevelCompilationSectionCache.cs
- GreenMethods.cs
- recordstate.cs
- UnknownBitmapEncoder.cs
- WebBrowserNavigatedEventHandler.cs
- SqlBuilder.cs
- VersionedStream.cs
- SynchronizedInputAdaptor.cs
- PrimitiveDataContract.cs
- TreeChangeInfo.cs
- base64Transforms.cs
- SqlDataSourceWizardForm.cs
- ManifestResourceInfo.cs
- Int64.cs
- XmlSchemaValidationException.cs
- RangeValidator.cs
- DeferredSelectedIndexReference.cs
- ColumnBinding.cs
- UnconditionalPolicy.cs
- UserMapPath.cs
- NameValuePermission.cs
- SmiTypedGetterSetter.cs
- XamlInt32CollectionSerializer.cs
- Compilation.cs
- DocumentSequenceHighlightLayer.cs
- InfoCardRSAOAEPKeyExchangeDeformatter.cs
- ColumnHeader.cs
- ConsumerConnectionPointCollection.cs
- ClientUtils.cs
- CompositeFontFamily.cs
- CodeBinaryOperatorExpression.cs
- StylusPointDescription.cs
- CacheDependency.cs
- DataBinder.cs
- DataGridViewCheckBoxColumn.cs
- TextServicesProperty.cs
- BlobPersonalizationState.cs
- HtmlTableRowCollection.cs
- CodeGotoStatement.cs
- Scheduler.cs
- TextWriter.cs
- PersonalizationProviderHelper.cs
- DataGridViewRowPrePaintEventArgs.cs
- ResponseStream.cs
- XmlCountingReader.cs
- SpnEndpointIdentityExtension.cs
- HtmlHead.cs
- DataGridViewControlCollection.cs
- CapiNative.cs
- ProofTokenCryptoHandle.cs
- ListDictionary.cs
- XmlFormatWriterGenerator.cs
- XmlBuffer.cs
- DataGridItem.cs
- FeatureSupport.cs
- TypeBuilderInstantiation.cs
- ToolboxItemCollection.cs
- DbProviderServices.cs