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
- PersonalizationDictionary.cs
- _LoggingObject.cs
- LinqDataView.cs
- ObjectToIdCache.cs
- Menu.cs
- LineGeometry.cs
- RequestStatusBarUpdateEventArgs.cs
- WebServiceErrorEvent.cs
- LocalClientSecuritySettingsElement.cs
- IIS7UserPrincipal.cs
- BezierSegment.cs
- HashMembershipCondition.cs
- HealthMonitoringSectionHelper.cs
- RuleEngine.cs
- Hex.cs
- WhitespaceRuleLookup.cs
- ProcessHostServerConfig.cs
- AutoGeneratedFieldProperties.cs
- SafeNativeMethods.cs
- TableProvider.cs
- PrimaryKeyTypeConverter.cs
- DoWorkEventArgs.cs
- ButtonColumn.cs
- SendMailErrorEventArgs.cs
- XmlDataProvider.cs
- ContextMenuStrip.cs
- ArrayEditor.cs
- NameGenerator.cs
- SecurityCookieModeValidator.cs
- WebException.cs
- DataGridViewCellStyleContentChangedEventArgs.cs
- StreamReader.cs
- DrawingGroup.cs
- StatusBarAutomationPeer.cs
- RuntimeResourceSet.cs
- DiscreteKeyFrames.cs
- FontStyleConverter.cs
- Setter.cs
- WebPartPersonalization.cs
- BoolExpressionVisitors.cs
- StreamingContext.cs
- BaseDataList.cs
- _ConnectOverlappedAsyncResult.cs
- UnsafeNativeMethods.cs
- ResourceDisplayNameAttribute.cs
- CodeConditionStatement.cs
- PointLightBase.cs
- ListView.cs
- Utils.cs
- RequestCacheManager.cs
- SocketInformation.cs
- ExtensionSimplifierMarkupObject.cs
- ParseHttpDate.cs
- XmlMtomWriter.cs
- OdbcDataAdapter.cs
- DataRelationPropertyDescriptor.cs
- LicenseProviderAttribute.cs
- WindowInteractionStateTracker.cs
- GridViewAutomationPeer.cs
- validation.cs
- PageSettings.cs
- HttpAsyncResult.cs
- DataGridViewRowContextMenuStripNeededEventArgs.cs
- HScrollBar.cs
- ToolBarButtonClickEvent.cs
- AnnotationHighlightLayer.cs
- FixedLineResult.cs
- StateDesignerConnector.cs
- Int32AnimationUsingKeyFrames.cs
- IChannel.cs
- DataViewListener.cs
- ArithmeticException.cs
- AutomationPeer.cs
- TextMarkerSource.cs
- StartUpEventArgs.cs
- XsdDuration.cs
- SessionViewState.cs
- HelpFileFileNameEditor.cs
- NumberSubstitution.cs
- ListViewInsertionMark.cs
- PostBackTrigger.cs
- SchemaDeclBase.cs
- Normalizer.cs
- PropertyGridCommands.cs
- DelimitedListTraceListener.cs
- SemanticKeyElement.cs
- ISAPIApplicationHost.cs
- ComponentDispatcherThread.cs
- CustomExpression.cs
- HtmlElementErrorEventArgs.cs
- SafeNativeMethods.cs
- XmlMtomReader.cs
- XmlWriterTraceListener.cs
- COM2IDispatchConverter.cs
- LayoutExceptionEventArgs.cs
- CodeConditionStatement.cs
- ErrorRuntimeConfig.cs
- DiscardableAttribute.cs
- coordinatorscratchpad.cs
- XmlSchemaAttribute.cs