Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / whidbey / NetFXspW7 / ndp / fx / src / WinForms / Managed / System / WinForms / ArrangedElement.cs / 1 / ArrangedElement.cs
namespace System.Windows.Forms { using System.Drawing; using System.Windows.Forms.Layout; using System.Collections.Specialized; using System.Collections; using System.ComponentModel; using System.Diagnostics; internal abstract class ArrangedElement : Component, IArrangedElement { ////// ///private Rectangle bounds = Rectangle.Empty; private IArrangedElement parent = null; private BitVector32 state = new BitVector32(); private PropertyStore propertyStore = new PropertyStore(); // Contains all properties that are not always set. private int suspendCount = 0; private static readonly int stateVisible = BitVector32.CreateMask(); private static readonly int stateDisposing = BitVector32.CreateMask(stateVisible); private static readonly int stateLocked = BitVector32.CreateMask(stateDisposing); private static readonly int PropControlsCollection = PropertyStore.CreateKey(); private Control spacer = new Control(); internal ArrangedElement() { this.Padding = DefaultPadding; this.Margin = DefaultMargin; state[stateVisible] = true; } public Rectangle Bounds { get { return bounds; } } ArrangedElementCollection IArrangedElement.Children { get { return GetChildren(); } } IArrangedElement IArrangedElement.Container { get { return GetContainer(); } } protected virtual Padding DefaultMargin { get { return Padding.Empty; } } protected virtual Padding DefaultPadding { get { return Padding.Empty; } } public virtual Rectangle DisplayRectangle { get { Rectangle displayRectangle = this.Bounds; return displayRectangle; } } public abstract LayoutEngine LayoutEngine { get; } public Padding Margin { get { return CommonProperties.GetMargin(this); } set { Debug.Assert((value.Right >= 0 && value.Left >= 0 && value.Top >= 0 && value.Bottom >=0), "who's setting margin negative?"); value = LayoutUtils.ClampNegativePaddingToZero(value); if (Margin != value ) { CommonProperties.SetMargin(this, value); } } } public virtual Padding Padding { get { return CommonProperties.GetPadding(this, DefaultPadding); } set { Debug.Assert((value.Right >= 0 && value.Left >= 0 && value.Top >= 0 && value.Bottom >=0), "who's setting padding negative?"); value = LayoutUtils.ClampNegativePaddingToZero(value); if (Padding != value) { CommonProperties.SetPadding(this, value); } } } public virtual IArrangedElement Parent { get { return parent; } set { parent = value as IArrangedElement; } } public virtual bool ParticipatesInLayout { get { return Visible; } } PropertyStore IArrangedElement.Properties { get { return this.Properties; } } private PropertyStore Properties { get { return propertyStore; } } public virtual bool Visible { get { return state[stateVisible]; } set { if ( state[stateVisible] != value) { state[stateVisible] = value; if (Parent != null){ LayoutTransaction.DoLayout(this.Parent, this, PropertyNames.Visible); } } } } protected abstract IArrangedElement GetContainer(); protected abstract ArrangedElementCollection GetChildren(); public virtual Size GetPreferredSize(Size constrainingSize) { Size preferredSize = LayoutEngine.GetPreferredSize(this, constrainingSize - Padding.Size) + Padding.Size; return preferredSize; } public virtual void PerformLayout(IArrangedElement container, string propertyName) { if (suspendCount <= 0) { OnLayout(new LayoutEventArgs(container, propertyName)); } } protected virtual void OnLayout(LayoutEventArgs e) { bool parentNeedsLayout = LayoutEngine.Layout(this, e); } protected virtual void OnBoundsChanged(Rectangle oldBounds, Rectangle newBounds) { ((IArrangedElement)this).PerformLayout((IArrangedElement)this, PropertyNames.Size); } public void SetBounds(Rectangle bounds, BoundsSpecified specified) { // in this case the parent is telling us to refresh our bounds - dont // call PerformLayout SetBoundsCore(bounds, specified); } protected virtual void SetBoundsCore(Rectangle bounds, BoundsSpecified specified) { if (bounds != this.bounds) { Rectangle oldBounds = this.bounds; this.bounds = bounds; OnBoundsChanged(oldBounds, bounds); } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. namespace System.Windows.Forms { using System.Drawing; using System.Windows.Forms.Layout; using System.Collections.Specialized; using System.Collections; using System.ComponentModel; using System.Diagnostics; internal abstract class ArrangedElement : Component, IArrangedElement { /// /// ///private Rectangle bounds = Rectangle.Empty; private IArrangedElement parent = null; private BitVector32 state = new BitVector32(); private PropertyStore propertyStore = new PropertyStore(); // Contains all properties that are not always set. private int suspendCount = 0; private static readonly int stateVisible = BitVector32.CreateMask(); private static readonly int stateDisposing = BitVector32.CreateMask(stateVisible); private static readonly int stateLocked = BitVector32.CreateMask(stateDisposing); private static readonly int PropControlsCollection = PropertyStore.CreateKey(); private Control spacer = new Control(); internal ArrangedElement() { this.Padding = DefaultPadding; this.Margin = DefaultMargin; state[stateVisible] = true; } public Rectangle Bounds { get { return bounds; } } ArrangedElementCollection IArrangedElement.Children { get { return GetChildren(); } } IArrangedElement IArrangedElement.Container { get { return GetContainer(); } } protected virtual Padding DefaultMargin { get { return Padding.Empty; } } protected virtual Padding DefaultPadding { get { return Padding.Empty; } } public virtual Rectangle DisplayRectangle { get { Rectangle displayRectangle = this.Bounds; return displayRectangle; } } public abstract LayoutEngine LayoutEngine { get; } public Padding Margin { get { return CommonProperties.GetMargin(this); } set { Debug.Assert((value.Right >= 0 && value.Left >= 0 && value.Top >= 0 && value.Bottom >=0), "who's setting margin negative?"); value = LayoutUtils.ClampNegativePaddingToZero(value); if (Margin != value ) { CommonProperties.SetMargin(this, value); } } } public virtual Padding Padding { get { return CommonProperties.GetPadding(this, DefaultPadding); } set { Debug.Assert((value.Right >= 0 && value.Left >= 0 && value.Top >= 0 && value.Bottom >=0), "who's setting padding negative?"); value = LayoutUtils.ClampNegativePaddingToZero(value); if (Padding != value) { CommonProperties.SetPadding(this, value); } } } public virtual IArrangedElement Parent { get { return parent; } set { parent = value as IArrangedElement; } } public virtual bool ParticipatesInLayout { get { return Visible; } } PropertyStore IArrangedElement.Properties { get { return this.Properties; } } private PropertyStore Properties { get { return propertyStore; } } public virtual bool Visible { get { return state[stateVisible]; } set { if ( state[stateVisible] != value) { state[stateVisible] = value; if (Parent != null){ LayoutTransaction.DoLayout(this.Parent, this, PropertyNames.Visible); } } } } protected abstract IArrangedElement GetContainer(); protected abstract ArrangedElementCollection GetChildren(); public virtual Size GetPreferredSize(Size constrainingSize) { Size preferredSize = LayoutEngine.GetPreferredSize(this, constrainingSize - Padding.Size) + Padding.Size; return preferredSize; } public virtual void PerformLayout(IArrangedElement container, string propertyName) { if (suspendCount <= 0) { OnLayout(new LayoutEventArgs(container, propertyName)); } } protected virtual void OnLayout(LayoutEventArgs e) { bool parentNeedsLayout = LayoutEngine.Layout(this, e); } protected virtual void OnBoundsChanged(Rectangle oldBounds, Rectangle newBounds) { ((IArrangedElement)this).PerformLayout((IArrangedElement)this, PropertyNames.Size); } public void SetBounds(Rectangle bounds, BoundsSpecified specified) { // in this case the parent is telling us to refresh our bounds - dont // call PerformLayout SetBoundsCore(bounds, specified); } protected virtual void SetBoundsCore(Rectangle bounds, BoundsSpecified specified) { if (bounds != this.bounds) { Rectangle oldBounds = this.bounds; this.bounds = bounds; OnBoundsChanged(oldBounds, bounds); } } } } // 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
- Rotation3DAnimationBase.cs
- RoleProviderPrincipal.cs
- LoginDesignerUtil.cs
- ActiveXContainer.cs
- TextTreeUndoUnit.cs
- TrustManagerMoreInformation.cs
- PropertyFilter.cs
- OneOfConst.cs
- NetNamedPipeSecurity.cs
- Style.cs
- _HeaderInfoTable.cs
- HttpsTransportBindingElement.cs
- PropertyOverridesTypeEditor.cs
- SupportsEventValidationAttribute.cs
- SymbolResolver.cs
- ExpressionBuilder.cs
- ListViewHitTestInfo.cs
- XmlElementList.cs
- VisualTreeFlattener.cs
- GetReadStreamResult.cs
- SqlCacheDependencyDatabase.cs
- XmlSerializableServices.cs
- IdleTimeoutMonitor.cs
- DataGridViewCellStyle.cs
- LayoutExceptionEventArgs.cs
- ListItemParagraph.cs
- DrawingContextWalker.cs
- FixedHyperLink.cs
- validation.cs
- TraceHandlerErrorFormatter.cs
- AnimationStorage.cs
- SHA384Cng.cs
- _NetworkingPerfCounters.cs
- PhysicalAddress.cs
- RequestContext.cs
- ProcessInfo.cs
- ImpersonationContext.cs
- TypeNameConverter.cs
- NumberFormatInfo.cs
- ShimAsPublicXamlType.cs
- TreeViewBindingsEditor.cs
- SelectionWordBreaker.cs
- CommentEmitter.cs
- PowerEase.cs
- PreviewPrintController.cs
- XPathNavigatorKeyComparer.cs
- ZipIOLocalFileDataDescriptor.cs
- XmlEncoding.cs
- MsmqTransportSecurity.cs
- StylusCollection.cs
- CustomErrorsSection.cs
- ToolZone.cs
- HttpRequest.cs
- ClusterSafeNativeMethods.cs
- DesignerActionMethodItem.cs
- GridItemCollection.cs
- CaseStatement.cs
- MimeWriter.cs
- ToolStripOverflowButton.cs
- XmlObjectSerializerReadContext.cs
- UTF8Encoding.cs
- XmlSerializerFaultFormatter.cs
- DescendantQuery.cs
- BamlBinaryReader.cs
- CallbackWrapper.cs
- RefType.cs
- _SSPIWrapper.cs
- ReadOnlyDataSourceView.cs
- GB18030Encoding.cs
- ParameterBuilder.cs
- SchemeSettingElement.cs
- EndOfStreamException.cs
- DataGridViewCellConverter.cs
- SubqueryTrackingVisitor.cs
- WindowsAuthenticationModule.cs
- Freezable.cs
- SQLInt16.cs
- X509Certificate2Collection.cs
- DictionaryBase.cs
- TableCellCollection.cs
- HeaderFilter.cs
- XAMLParseException.cs
- Positioning.cs
- XPathMessageFilterElementCollection.cs
- DataGridViewCellParsingEventArgs.cs
- Base64Stream.cs
- SingleObjectCollection.cs
- FixedTextView.cs
- HierarchicalDataSourceControl.cs
- DataColumnCollection.cs
- FunctionOverloadResolver.cs
- DataControlCommands.cs
- CollectionMarkupSerializer.cs
- ConstrainedGroup.cs
- DefaultAssemblyResolver.cs
- Formatter.cs
- WorkflowTraceTransfer.cs
- QilInvokeLateBound.cs
- HttpRuntimeSection.cs
- Debugger.cs