Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / whidbey / NetFXspW7 / ndp / fx / src / CommonUI / System / Drawing / BufferedGraphics.cs / 1 / BufferedGraphics.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Drawing { using System; using System.ComponentModel; using System.Collections; using System.Drawing; using System.Drawing.Drawing2D; using System.Drawing.Text; using System.Diagnostics; using System.Runtime.InteropServices; using System.Threading; using System.Security; using System.Security.Permissions; using System.Diagnostics.CodeAnalysis; ////// /// The BufferedGraphics class can be thought of as a "Token" or "Reference" to the /// buffer that a BufferedGraphicsContext creates. While a BufferedGraphics is /// outstanding, the memory associated with the buffer is locked. The general design /// is such that under normal conditions a single BufferedGraphics will be in use at /// one time for a given BufferedGraphicsContext. /// [SuppressMessage("Microsoft.Usage", "CA2216:DisposableTypesShouldDeclareFinalizer")] public sealed class BufferedGraphics : IDisposable { private Graphics bufferedGraphicsSurface; private Graphics targetGraphics; private BufferedGraphicsContext context; private IntPtr targetDC; private Point targetLoc; private Size virtualSize; private bool disposeContext; private static int rop = 0xcc0020; // RasterOp.SOURCE.GetRop(); ////// /// Internal constructor, this class is created by the BufferedGraphicsContext. /// internal BufferedGraphics(Graphics bufferedGraphicsSurface, BufferedGraphicsContext context, Graphics targetGraphics, IntPtr targetDC, Point targetLoc, Size virtualSize) { this.context = context; this.bufferedGraphicsSurface = bufferedGraphicsSurface; this.targetDC = targetDC; this.targetGraphics = targetGraphics; this.targetLoc = targetLoc; this.virtualSize = virtualSize; } ~BufferedGraphics() { Dispose(false); } ////// /// Disposes the object and releases the lock on the memory. /// public void Dispose() { Dispose(true); } private void Dispose(bool disposing) { if (disposing) { if (context != null) { context.ReleaseBuffer(this); if (DisposeContext) { context.Dispose(); context = null; } } if (bufferedGraphicsSurface != null) { bufferedGraphicsSurface.Dispose(); bufferedGraphicsSurface = null; } } } ////// /// Internal property - determines if we need to dispose of the Context when this is disposed /// internal bool DisposeContext { get { return disposeContext; } set { disposeContext = value; } } ////// /// Allows access to the Graphics wrapper for the buffer. /// public Graphics Graphics { get { Debug.Assert(bufferedGraphicsSurface != null, "The BufferedGraphicsSurface is null!"); return bufferedGraphicsSurface; } } ////// /// Renders the buffer to the original graphics used to allocate the buffer. /// public void Render() { if (targetGraphics != null) { Render(targetGraphics); } else { RenderInternal(new HandleRef(Graphics, targetDC), this); } } ////// /// Renders the buffer to the specified target graphics. /// public void Render(Graphics target) { if (target != null) { IntPtr targetDC = target.GetHdc(); try { RenderInternal(new HandleRef(target, targetDC), this); } finally { target.ReleaseHdcInternal(targetDC); } } } ////// /// Renders the buffer to the specified target HDC. /// public void Render(IntPtr targetDC) { IntSecurity.UnmanagedCode.Demand(); RenderInternal(new HandleRef(null, targetDC), this); } ////// /// Internal method that renders the specified buffer into the target. /// private void RenderInternal(HandleRef refTargetDC, BufferedGraphics buffer) { IntPtr sourceDC = buffer.Graphics.GetHdc(); try { SafeNativeMethods.BitBlt(refTargetDC, targetLoc.X, targetLoc.Y, virtualSize.Width, virtualSize.Height, new HandleRef(buffer.Graphics, sourceDC), 0, 0, rop); } finally { buffer.Graphics.ReleaseHdcInternal(sourceDC); } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Drawing { using System; using System.ComponentModel; using System.Collections; using System.Drawing; using System.Drawing.Drawing2D; using System.Drawing.Text; using System.Diagnostics; using System.Runtime.InteropServices; using System.Threading; using System.Security; using System.Security.Permissions; using System.Diagnostics.CodeAnalysis; ////// /// The BufferedGraphics class can be thought of as a "Token" or "Reference" to the /// buffer that a BufferedGraphicsContext creates. While a BufferedGraphics is /// outstanding, the memory associated with the buffer is locked. The general design /// is such that under normal conditions a single BufferedGraphics will be in use at /// one time for a given BufferedGraphicsContext. /// [SuppressMessage("Microsoft.Usage", "CA2216:DisposableTypesShouldDeclareFinalizer")] public sealed class BufferedGraphics : IDisposable { private Graphics bufferedGraphicsSurface; private Graphics targetGraphics; private BufferedGraphicsContext context; private IntPtr targetDC; private Point targetLoc; private Size virtualSize; private bool disposeContext; private static int rop = 0xcc0020; // RasterOp.SOURCE.GetRop(); ////// /// Internal constructor, this class is created by the BufferedGraphicsContext. /// internal BufferedGraphics(Graphics bufferedGraphicsSurface, BufferedGraphicsContext context, Graphics targetGraphics, IntPtr targetDC, Point targetLoc, Size virtualSize) { this.context = context; this.bufferedGraphicsSurface = bufferedGraphicsSurface; this.targetDC = targetDC; this.targetGraphics = targetGraphics; this.targetLoc = targetLoc; this.virtualSize = virtualSize; } ~BufferedGraphics() { Dispose(false); } ////// /// Disposes the object and releases the lock on the memory. /// public void Dispose() { Dispose(true); } private void Dispose(bool disposing) { if (disposing) { if (context != null) { context.ReleaseBuffer(this); if (DisposeContext) { context.Dispose(); context = null; } } if (bufferedGraphicsSurface != null) { bufferedGraphicsSurface.Dispose(); bufferedGraphicsSurface = null; } } } ////// /// Internal property - determines if we need to dispose of the Context when this is disposed /// internal bool DisposeContext { get { return disposeContext; } set { disposeContext = value; } } ////// /// Allows access to the Graphics wrapper for the buffer. /// public Graphics Graphics { get { Debug.Assert(bufferedGraphicsSurface != null, "The BufferedGraphicsSurface is null!"); return bufferedGraphicsSurface; } } ////// /// Renders the buffer to the original graphics used to allocate the buffer. /// public void Render() { if (targetGraphics != null) { Render(targetGraphics); } else { RenderInternal(new HandleRef(Graphics, targetDC), this); } } ////// /// Renders the buffer to the specified target graphics. /// public void Render(Graphics target) { if (target != null) { IntPtr targetDC = target.GetHdc(); try { RenderInternal(new HandleRef(target, targetDC), this); } finally { target.ReleaseHdcInternal(targetDC); } } } ////// /// Renders the buffer to the specified target HDC. /// public void Render(IntPtr targetDC) { IntSecurity.UnmanagedCode.Demand(); RenderInternal(new HandleRef(null, targetDC), this); } ////// /// Internal method that renders the specified buffer into the target. /// private void RenderInternal(HandleRef refTargetDC, BufferedGraphics buffer) { IntPtr sourceDC = buffer.Graphics.GetHdc(); try { SafeNativeMethods.BitBlt(refTargetDC, targetLoc.X, targetLoc.Y, virtualSize.Width, virtualSize.Height, new HandleRef(buffer.Graphics, sourceDC), 0, 0, rop); } finally { buffer.Graphics.ReleaseHdcInternal(sourceDC); } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu
![Network programming in C#, Network Programming in VB.NET, Network Programming in .NET](/images/book.jpg)
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- IChannel.cs
- CodeFieldReferenceExpression.cs
- DesignerVerbCollection.cs
- DataGridViewToolTip.cs
- NavigationService.cs
- Header.cs
- UnsafeNativeMethods.cs
- ToolStripSeparatorRenderEventArgs.cs
- PixelShader.cs
- BreakSafeBase.cs
- DataSourceGroupCollection.cs
- ReflectTypeDescriptionProvider.cs
- XXXInfos.cs
- SiteMapNodeItem.cs
- TracedNativeMethods.cs
- PropertyItemInternal.cs
- DecimalConverter.cs
- QuotedStringFormatReader.cs
- InvokeCompletedEventArgs.cs
- StylusTip.cs
- Baml2006Reader.cs
- OperandQuery.cs
- CompilerCollection.cs
- BaseContextMenu.cs
- DiagnosticsConfigurationHandler.cs
- ObjectTag.cs
- WinEventWrap.cs
- ObjectDataSourceMethodEventArgs.cs
- EditorBrowsableAttribute.cs
- PersonalizationStateQuery.cs
- TextDataBindingHandler.cs
- DrawTreeNodeEventArgs.cs
- StructuredTypeEmitter.cs
- DayRenderEvent.cs
- SubqueryRules.cs
- _FtpDataStream.cs
- PointCollection.cs
- OdbcConnectionFactory.cs
- DecoderNLS.cs
- BitmapFrameEncode.cs
- ClientSettingsStore.cs
- XmlAtomicValue.cs
- LayoutTableCell.cs
- SegmentInfo.cs
- _AutoWebProxyScriptEngine.cs
- Header.cs
- SupportingTokenAuthenticatorSpecification.cs
- FlowDocument.cs
- ResourceDefaultValueAttribute.cs
- TextDecorations.cs
- SmiEventSink_Default.cs
- BufferedStream.cs
- CallContext.cs
- JulianCalendar.cs
- ClientSettingsStore.cs
- DataGridViewRowHeaderCell.cs
- XComponentModel.cs
- DetailsViewCommandEventArgs.cs
- LogManagementAsyncResult.cs
- Knowncolors.cs
- PenCursorManager.cs
- TreeViewImageIndexConverter.cs
- PolyBezierSegment.cs
- DesignerForm.cs
- PageStatePersister.cs
- ByteStreamGeometryContext.cs
- ArrangedElement.cs
- DecoderNLS.cs
- WorkflowMarkupSerializationProvider.cs
- COM2EnumConverter.cs
- SqlDelegatedTransaction.cs
- RayMeshGeometry3DHitTestResult.cs
- ConditionBrowserDialog.cs
- Compilation.cs
- VerticalAlignConverter.cs
- DuplicateWaitObjectException.cs
- DayRenderEvent.cs
- ToolStripTextBox.cs
- DataGridViewCellValueEventArgs.cs
- InsufficientMemoryException.cs
- WindowsRegion.cs
- EntityWithChangeTrackerStrategy.cs
- DuplicateWaitObjectException.cs
- UserNameSecurityToken.cs
- SingleTagSectionHandler.cs
- NetNamedPipeSecurity.cs
- CommandHelpers.cs
- RegionIterator.cs
- XmlHierarchicalEnumerable.cs
- MarshalDirectiveException.cs
- PropertyDescriptorComparer.cs
- CodeSnippetStatement.cs
- Margins.cs
- TempEnvironment.cs
- Logging.cs
- Range.cs
- StringKeyFrameCollection.cs
- InstanceNormalEvent.cs
- HotSpot.cs
- EntityDataSourceWrapper.cs