Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / ndp / fx / src / Misc / GDI / WindowsRegion.cs / 1 / WindowsRegion.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- #if WINFORMS_NAMESPACE namespace System.Windows.Forms.Internal #elif DRAWING_NAMESPACE namespace System.Drawing.Internal #else namespace System.Experimental.Gdi #endif { using System; using System.Internal; using System.Runtime.InteropServices; using System.ComponentModel; using System.Diagnostics; using System.Diagnostics.CodeAnalysis; using System.Drawing; using System.Globalization; ////// #if WINFORMS_PUBLIC_GRAPHICS_LIBRARY public #else internal #endif sealed partial class WindowsRegion : MarshalByRefObject, ICloneable, IDisposable { [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Reliability", "CA2006:UseSafeHandleToEncapsulateNativeResources")] private IntPtr nativeHandle; // The hRegion, this class always takes ownership of the hRegion. private bool ownHandle; #if GDI_FINALIZATION_WATCH private string AllocationSite = DbgUtil.StackTrace; #endif ////// Encapsulates a GDI Region object. /// ////// private WindowsRegion() { } ////// public WindowsRegion(Rectangle rect) { CreateRegion(rect); } ////// public WindowsRegion(int x, int y, int width, int height) { CreateRegion(new Rectangle(x,y,width, height)); } // Consider implementing a constructor that calls ExtCreateRegion(XFORM lpXform, DWORD nCount, RGNDATA lpRgnData) if needed. ////// Creates a WindowsRegion from a region handle, if 'takeOwnership' is true, the handle is added to the HandleCollector /// and is removed & destroyed on dispose. /// public static WindowsRegion FromHregion(IntPtr hRegion, bool takeOwnership) { WindowsRegion wr = new WindowsRegion(); // Note: Passing IntPtr.Zero for hRegion is ok. GDI+ infinite regions will have hRegion == null. // GDI's SelectClipRgn interprets null region handle as resetting the clip region (all region will be available for painting). if( hRegion != IntPtr.Zero ) { wr.nativeHandle = hRegion; if (takeOwnership) { wr.ownHandle = true; System.Internal.HandleCollector.Add(hRegion, IntSafeNativeMethods.CommonHandles.GDI); } } return wr; } ////// Creates a WindowsRegion from a System.Drawing.Region. /// public static WindowsRegion FromRegion( Region region, Graphics g ){ if (region.IsInfinite(g)){ // An infinite region would cover the entire device region which is the same as // not having a clipping region. Observe that this is not the same as having an // empty region, which when clipping to it has the effect of excluding the entire // device region. // To remove the clip region from a dc the SelectClipRgn() function needs to be // called with a null region ptr - that's why we use the empty constructor here. // GDI+ will return IntPtr.Zero for Region.GetHrgn(Graphics) when the region is // Infinite. return new WindowsRegion(); } return WindowsRegion.FromHregion(region.GetHrgn(g), true); } ////// public object Clone() { // WARNING: WindowsRegion currently supports rectangulare regions only, if the WindowsRegion was created // from an HRegion and it is not rectangular this method won't work as expected. // Note: This method is currently not used and is here just to implement ICloneable. return this.IsInfinite ? new WindowsRegion() : new WindowsRegion(this.ToRectangle()); } ////// Combines region1 & region2 into this region. The regions cannot be null. /// The three regions need not be distinct. For example, the sourceRgn1 can equal this region. /// public IntNativeMethods.RegionFlags CombineRegion(WindowsRegion region1, WindowsRegion region2, RegionCombineMode mode) { return IntUnsafeNativeMethods.CombineRgn(new HandleRef(this, this.HRegion), new HandleRef(region1, region1.HRegion), new HandleRef(region2, region2.HRegion), mode); } ////// private void CreateRegion(Rectangle rect) { Debug.Assert(nativeHandle == IntPtr.Zero, "nativeHandle should be null, we're leaking handle"); this.nativeHandle = IntSafeNativeMethods.CreateRectRgn(rect.X, rect.Y, rect.X+rect.Width, rect.Y+rect.Height); ownHandle = true; } ////// public void Dispose() { Dispose(true); } ////// public void Dispose(bool disposing) { if (this.nativeHandle != IntPtr.Zero) { DbgUtil.AssertFinalization(this, disposing); if( this.ownHandle ) { IntUnsafeNativeMethods.DeleteObject(new HandleRef(this, this.nativeHandle)); } this.nativeHandle = IntPtr.Zero; if (disposing) { GC.SuppressFinalize(this); } } } ////// ~WindowsRegion() { Dispose(false); } ////// The native region handle. /// public IntPtr HRegion { get { return this.nativeHandle; } } ////// public bool IsInfinite { get { return this.nativeHandle == IntPtr.Zero; } } ////// A rectangle representing the window region set with the SetWindowRgn function. /// public Rectangle ToRectangle() { if( this.IsInfinite ) { return new Rectangle( -Int32.MaxValue, -Int32.MaxValue, Int32.MaxValue, Int32.MaxValue ); } IntNativeMethods.RECT rect = new IntNativeMethods.RECT(); IntUnsafeNativeMethods.GetRgnBox(new HandleRef(this, this.nativeHandle), ref rect); return new Rectangle(new Point(rect.left, rect.top), rect.Size); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- #if WINFORMS_NAMESPACE namespace System.Windows.Forms.Internal #elif DRAWING_NAMESPACE namespace System.Drawing.Internal #else namespace System.Experimental.Gdi #endif { using System; using System.Internal; using System.Runtime.InteropServices; using System.ComponentModel; using System.Diagnostics; using System.Diagnostics.CodeAnalysis; using System.Drawing; using System.Globalization; ////// #if WINFORMS_PUBLIC_GRAPHICS_LIBRARY public #else internal #endif sealed partial class WindowsRegion : MarshalByRefObject, ICloneable, IDisposable { [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Reliability", "CA2006:UseSafeHandleToEncapsulateNativeResources")] private IntPtr nativeHandle; // The hRegion, this class always takes ownership of the hRegion. private bool ownHandle; #if GDI_FINALIZATION_WATCH private string AllocationSite = DbgUtil.StackTrace; #endif ////// Encapsulates a GDI Region object. /// ////// private WindowsRegion() { } ////// public WindowsRegion(Rectangle rect) { CreateRegion(rect); } ////// public WindowsRegion(int x, int y, int width, int height) { CreateRegion(new Rectangle(x,y,width, height)); } // Consider implementing a constructor that calls ExtCreateRegion(XFORM lpXform, DWORD nCount, RGNDATA lpRgnData) if needed. ////// Creates a WindowsRegion from a region handle, if 'takeOwnership' is true, the handle is added to the HandleCollector /// and is removed & destroyed on dispose. /// public static WindowsRegion FromHregion(IntPtr hRegion, bool takeOwnership) { WindowsRegion wr = new WindowsRegion(); // Note: Passing IntPtr.Zero for hRegion is ok. GDI+ infinite regions will have hRegion == null. // GDI's SelectClipRgn interprets null region handle as resetting the clip region (all region will be available for painting). if( hRegion != IntPtr.Zero ) { wr.nativeHandle = hRegion; if (takeOwnership) { wr.ownHandle = true; System.Internal.HandleCollector.Add(hRegion, IntSafeNativeMethods.CommonHandles.GDI); } } return wr; } ////// Creates a WindowsRegion from a System.Drawing.Region. /// public static WindowsRegion FromRegion( Region region, Graphics g ){ if (region.IsInfinite(g)){ // An infinite region would cover the entire device region which is the same as // not having a clipping region. Observe that this is not the same as having an // empty region, which when clipping to it has the effect of excluding the entire // device region. // To remove the clip region from a dc the SelectClipRgn() function needs to be // called with a null region ptr - that's why we use the empty constructor here. // GDI+ will return IntPtr.Zero for Region.GetHrgn(Graphics) when the region is // Infinite. return new WindowsRegion(); } return WindowsRegion.FromHregion(region.GetHrgn(g), true); } ////// public object Clone() { // WARNING: WindowsRegion currently supports rectangulare regions only, if the WindowsRegion was created // from an HRegion and it is not rectangular this method won't work as expected. // Note: This method is currently not used and is here just to implement ICloneable. return this.IsInfinite ? new WindowsRegion() : new WindowsRegion(this.ToRectangle()); } ////// Combines region1 & region2 into this region. The regions cannot be null. /// The three regions need not be distinct. For example, the sourceRgn1 can equal this region. /// public IntNativeMethods.RegionFlags CombineRegion(WindowsRegion region1, WindowsRegion region2, RegionCombineMode mode) { return IntUnsafeNativeMethods.CombineRgn(new HandleRef(this, this.HRegion), new HandleRef(region1, region1.HRegion), new HandleRef(region2, region2.HRegion), mode); } ////// private void CreateRegion(Rectangle rect) { Debug.Assert(nativeHandle == IntPtr.Zero, "nativeHandle should be null, we're leaking handle"); this.nativeHandle = IntSafeNativeMethods.CreateRectRgn(rect.X, rect.Y, rect.X+rect.Width, rect.Y+rect.Height); ownHandle = true; } ////// public void Dispose() { Dispose(true); } ////// public void Dispose(bool disposing) { if (this.nativeHandle != IntPtr.Zero) { DbgUtil.AssertFinalization(this, disposing); if( this.ownHandle ) { IntUnsafeNativeMethods.DeleteObject(new HandleRef(this, this.nativeHandle)); } this.nativeHandle = IntPtr.Zero; if (disposing) { GC.SuppressFinalize(this); } } } ////// ~WindowsRegion() { Dispose(false); } ////// The native region handle. /// public IntPtr HRegion { get { return this.nativeHandle; } } ////// public bool IsInfinite { get { return this.nativeHandle == IntPtr.Zero; } } ////// A rectangle representing the window region set with the SetWindowRgn function. /// public Rectangle ToRectangle() { if( this.IsInfinite ) { return new Rectangle( -Int32.MaxValue, -Int32.MaxValue, Int32.MaxValue, Int32.MaxValue ); } IntNativeMethods.RECT rect = new IntNativeMethods.RECT(); IntUnsafeNativeMethods.GetRgnBox(new HandleRef(this, this.nativeHandle), ref rect); return new Rectangle(new Point(rect.left, rect.top), rect.Size); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- TcpClientSocketManager.cs
- ButtonChrome.cs
- Compensate.cs
- SmiEventSink.cs
- InputElement.cs
- AlignmentXValidation.cs
- JournalEntryStack.cs
- VScrollProperties.cs
- StorageEntitySetMapping.cs
- SettingsContext.cs
- SourceFilter.cs
- XmlReaderDelegator.cs
- InkCanvasFeedbackAdorner.cs
- RawStylusInputReport.cs
- GridViewCancelEditEventArgs.cs
- Utils.cs
- DataGridPageChangedEventArgs.cs
- ValidatorUtils.cs
- WebPartConnectionsCloseVerb.cs
- SecurityElementBase.cs
- DLinqAssociationProvider.cs
- ProcessModelInfo.cs
- RubberbandSelector.cs
- Comparer.cs
- XXXInfos.cs
- FormViewModeEventArgs.cs
- TableAutomationPeer.cs
- IPCCacheManager.cs
- Axis.cs
- X509RawDataKeyIdentifierClause.cs
- TimeSpanFormat.cs
- RadioButtonAutomationPeer.cs
- SecurityPolicySection.cs
- TileBrush.cs
- LinkArea.cs
- RenameRuleObjectDialog.Designer.cs
- ImageAnimator.cs
- WindowVisualStateTracker.cs
- ping.cs
- Label.cs
- NoClickablePointException.cs
- XamlClipboardData.cs
- CharAnimationBase.cs
- EncryptedKey.cs
- hresults.cs
- DataErrorValidationRule.cs
- SchemaCollectionCompiler.cs
- ArrowControl.xaml.cs
- ListControlConvertEventArgs.cs
- _StreamFramer.cs
- XhtmlCssHandler.cs
- SuppressIldasmAttribute.cs
- DataServiceException.cs
- ViewKeyConstraint.cs
- GridViewRowCollection.cs
- SectionUpdates.cs
- DataRelation.cs
- QueuePathEditor.cs
- QilName.cs
- ModifierKeysConverter.cs
- MetaDataInfo.cs
- LocalServiceSecuritySettingsElement.cs
- ModuleConfigurationInfo.cs
- compensatingcollection.cs
- WebPartsPersonalization.cs
- TransactionManager.cs
- Point4D.cs
- CheckedListBox.cs
- ComponentCommands.cs
- DefaultCommandConverter.cs
- TypeElement.cs
- ConditionCollection.cs
- StrokeRenderer.cs
- SspiSafeHandles.cs
- DataGridItemEventArgs.cs
- ContractNamespaceAttribute.cs
- UpdateException.cs
- UidManager.cs
- TreeNodeSelectionProcessor.cs
- BitmapEffect.cs
- MissingMethodException.cs
- BaseValidator.cs
- KnownTypes.cs
- WindowsStatusBar.cs
- ConstrainedDataObject.cs
- Model3D.cs
- ConfigurationHandlersInstallComponent.cs
- SetterBaseCollection.cs
- PartialTrustValidationBehavior.cs
- FamilyMapCollection.cs
- CatalogPartCollection.cs
- XmlnsPrefixAttribute.cs
- StrokeNode.cs
- CacheMemory.cs
- DBCommand.cs
- AssemblyAssociatedContentFileAttribute.cs
- Blend.cs
- parserscommon.cs
- TypeSource.cs
- EventLogPermissionAttribute.cs