Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / Orcas / QFE / wpf / src / Framework / System / Windows / SizeChangedEventArgs.cs / 1 / 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
- CatalogZone.cs
- ActivityDesignerHelper.cs
- DesignerToolboxInfo.cs
- GridViewColumn.cs
- Polygon.cs
- DataGridBeginningEditEventArgs.cs
- IFormattable.cs
- HtmlInputHidden.cs
- SecurityTokenParametersEnumerable.cs
- ProxyWebPart.cs
- RootProfilePropertySettingsCollection.cs
- MediaPlayer.cs
- DispatcherProcessingDisabled.cs
- DoubleConverter.cs
- RtfToXamlReader.cs
- HtmlUtf8RawTextWriter.cs
- ListParagraph.cs
- Context.cs
- DbConnectionPoolCounters.cs
- Int32Collection.cs
- ArgumentException.cs
- _HeaderInfoTable.cs
- SessionParameter.cs
- InProcStateClientManager.cs
- ProfileInfo.cs
- HttpModulesSection.cs
- FaultCallbackWrapper.cs
- validationstate.cs
- WebBrowser.cs
- Span.cs
- HttpHandlersSection.cs
- BuildProvider.cs
- FixedDSBuilder.cs
- ScaleTransform3D.cs
- MsmqHostedTransportManager.cs
- GridViewColumn.cs
- LOSFormatter.cs
- AssemblyBuilder.cs
- StylusPointDescription.cs
- AssemblyInfo.cs
- BufferedStream.cs
- CodeCastExpression.cs
- brushes.cs
- InputMethodStateChangeEventArgs.cs
- DrawingAttributeSerializer.cs
- CommonDialog.cs
- SiteMapDataSource.cs
- Int16Converter.cs
- CriticalFinalizerObject.cs
- SByteConverter.cs
- ExpandedWrapper.cs
- NamedObject.cs
- FormViewRow.cs
- PrintPreviewDialog.cs
- UriTemplateDispatchFormatter.cs
- Faults.cs
- OpenTypeCommon.cs
- ProcessManager.cs
- WindowsClaimSet.cs
- EntityModelSchemaGenerator.cs
- IgnoreFlushAndCloseStream.cs
- SqlRetyper.cs
- ObjectSecurity.cs
- Int32.cs
- BasicHttpMessageSecurity.cs
- MemberNameValidator.cs
- Panel.cs
- BrowserTree.cs
- TextWriter.cs
- XmlHierarchicalEnumerable.cs
- XmlSchemaRedefine.cs
- SchemaTypeEmitter.cs
- EditorPartChrome.cs
- PolyBezierSegment.cs
- XmlDocumentFieldSchema.cs
- SqlNodeTypeOperators.cs
- NameSpaceExtractor.cs
- EventSinkHelperWriter.cs
- sqlmetadatafactory.cs
- DataIdProcessor.cs
- SessionStateContainer.cs
- VisualStyleRenderer.cs
- LinqDataSource.cs
- XmlSchemaCompilationSettings.cs
- ConfigXmlAttribute.cs
- COM2ExtendedUITypeEditor.cs
- SessionState.cs
- DefinitionUpdate.cs
- VideoDrawing.cs
- followingquery.cs
- DetailsViewRowCollection.cs
- Point4DValueSerializer.cs
- SecurityKeyIdentifier.cs
- TableLayoutPanelCellPosition.cs
- ParsedAttributeCollection.cs
- UpdatableWrapper.cs
- ConnectionInterfaceCollection.cs
- Crc32.cs
- ScriptingScriptResourceHandlerSection.cs
- SymDocumentType.cs