Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / wpf / src / Core / CSharp / System / Windows / Media / DrawingContext.cs / 1305600 / DrawingContext.cs
//------------------------------------------------------------------------------ // Microsoft Avalon // Copyright (c) Microsoft Corporation, 2003 // // File: DrawingContext.cs // // History: // [....]: 04/19/2003 // Created it based on the RetainedDrawingContext used in the AvPhat branch. // [....]: 07/02/2003 // Turned this class into an abstract base class for RetainedDrawingContext // and PaintingDrawingContext. // //----------------------------------------------------------------------------- using System; using System.Security.Permissions; using System.Windows; using System.Windows.Threading; using System.Windows.Media.Animation; using System.Windows.Media; using System.Diagnostics; using MS.Internal; using System.Runtime.InteropServices; using MS.Utility; namespace System.Windows.Media { ////// Drawing context. /// public abstract partial class DrawingContext : DispatcherObject, IDisposable { #region Constructors ////// Default constructor for DrawingContext - this uses the current Dispatcher. /// internal DrawingContext() { // Nothing to do here } #endregion Constructors #region Public Methods ////// Draw Text at the location specified. /// /// The FormattedText to draw. /// The location at which to draw the text. ////// This call is illegal if this object has already been closed or disposed. /// public void DrawText(FormattedText formattedText, Point origin) { EventTrace.EasyTraceEvent(EventTrace.Keyword.KeywordGeneral, EventTrace.Level.Verbose, EventTrace.Event.WClientStringBegin, "DrawingContext.DrawText Start"); VerifyApiNonstructuralChange(); #if DEBUG MediaTrace.DrawingContextOp.Trace("DrawText(const)"); #endif if (formattedText == null) { return; } formattedText.Draw(this, origin); EventTrace.EasyTraceEvent(EventTrace.Keyword.KeywordGeneral, EventTrace.Level.Verbose, EventTrace.Event.WClientStringEnd, "DrawingContext.DrawText End"); } ////// Closes the DrawingContext and flushes the content. /// Afterwards the DrawingContext can not be used anymore. /// This call does not require all Push calls to have been Popped. /// ////// This call is illegal if this object has already been closed or disposed. /// public abstract void Close(); ////// This is the same as the Close call: /// Closes the DrawingContext and flushes the content. /// Afterwards the DrawingContext can not be used anymore. /// This call does not require all Push calls to have been Popped. /// ////// This call is illegal if this object has already been closed or disposed. /// void IDisposable.Dispose() { // Call a virtual method for derived Dispose implementations // // Attempting to override a explicit interface member implementation causes // the most-derived implementation to always be called, and the base // implementation becomes uncallable. But FxCop requires the base Dispose // method is always be called. To avoid this situation, we use the *Core // pattern for derived classes, instead of attempting to override // IDisposable.Dispose. VerifyAccess(); DisposeCore(); GC.SuppressFinalize(this); } #endregion Public Methods #region Protected Methods ////// Dispose functionality implemented by subclasses /// ////// This call is illegal if this object has already been closed or disposed. /// protected abstract void DisposeCore(); ////// This verifies that the API can be called for read only access. /// protected virtual void VerifyApiNonstructuralChange() { this.VerifyAccess(); } #endregion Protected Methods } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. //------------------------------------------------------------------------------ // Microsoft Avalon // Copyright (c) Microsoft Corporation, 2003 // // File: DrawingContext.cs // // History: // [....]: 04/19/2003 // Created it based on the RetainedDrawingContext used in the AvPhat branch. // [....]: 07/02/2003 // Turned this class into an abstract base class for RetainedDrawingContext // and PaintingDrawingContext. // //----------------------------------------------------------------------------- using System; using System.Security.Permissions; using System.Windows; using System.Windows.Threading; using System.Windows.Media.Animation; using System.Windows.Media; using System.Diagnostics; using MS.Internal; using System.Runtime.InteropServices; using MS.Utility; namespace System.Windows.Media { ////// Drawing context. /// public abstract partial class DrawingContext : DispatcherObject, IDisposable { #region Constructors ////// Default constructor for DrawingContext - this uses the current Dispatcher. /// internal DrawingContext() { // Nothing to do here } #endregion Constructors #region Public Methods ////// Draw Text at the location specified. /// /// The FormattedText to draw. /// The location at which to draw the text. ////// This call is illegal if this object has already been closed or disposed. /// public void DrawText(FormattedText formattedText, Point origin) { EventTrace.EasyTraceEvent(EventTrace.Keyword.KeywordGeneral, EventTrace.Level.Verbose, EventTrace.Event.WClientStringBegin, "DrawingContext.DrawText Start"); VerifyApiNonstructuralChange(); #if DEBUG MediaTrace.DrawingContextOp.Trace("DrawText(const)"); #endif if (formattedText == null) { return; } formattedText.Draw(this, origin); EventTrace.EasyTraceEvent(EventTrace.Keyword.KeywordGeneral, EventTrace.Level.Verbose, EventTrace.Event.WClientStringEnd, "DrawingContext.DrawText End"); } ////// Closes the DrawingContext and flushes the content. /// Afterwards the DrawingContext can not be used anymore. /// This call does not require all Push calls to have been Popped. /// ////// This call is illegal if this object has already been closed or disposed. /// public abstract void Close(); ////// This is the same as the Close call: /// Closes the DrawingContext and flushes the content. /// Afterwards the DrawingContext can not be used anymore. /// This call does not require all Push calls to have been Popped. /// ////// This call is illegal if this object has already been closed or disposed. /// void IDisposable.Dispose() { // Call a virtual method for derived Dispose implementations // // Attempting to override a explicit interface member implementation causes // the most-derived implementation to always be called, and the base // implementation becomes uncallable. But FxCop requires the base Dispose // method is always be called. To avoid this situation, we use the *Core // pattern for derived classes, instead of attempting to override // IDisposable.Dispose. VerifyAccess(); DisposeCore(); GC.SuppressFinalize(this); } #endregion Public Methods #region Protected Methods ////// Dispose functionality implemented by subclasses /// ////// This call is illegal if this object has already been closed or disposed. /// protected abstract void DisposeCore(); ////// This verifies that the API can be called for read only access. /// protected virtual void VerifyApiNonstructuralChange() { this.VerifyAccess(); } #endregion Protected Methods } } // 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
- XmlSchemaAttributeGroupRef.cs
- TreeNodeSelectionProcessor.cs
- ReadonlyMessageFilter.cs
- DecoderBestFitFallback.cs
- NamedPipeDuplicateContext.cs
- CmsInterop.cs
- Privilege.cs
- DataSourceXmlSubItemAttribute.cs
- DrawingCollection.cs
- Collection.cs
- LayoutUtils.cs
- mactripleDES.cs
- PropertyGridCommands.cs
- InProcStateClientManager.cs
- ConfigurationManagerHelperFactory.cs
- SpotLight.cs
- FrameDimension.cs
- PersonalizationStateQuery.cs
- AutomationElement.cs
- ImageInfo.cs
- ButtonStandardAdapter.cs
- TransformProviderWrapper.cs
- DataErrorValidationRule.cs
- TrustLevelCollection.cs
- ReturnEventArgs.cs
- AutomationInteropProvider.cs
- _RequestCacheProtocol.cs
- Canvas.cs
- sortedlist.cs
- UserControlFileEditor.cs
- SystemParameters.cs
- XmlBinaryWriterSession.cs
- StyleHelper.cs
- FullTextBreakpoint.cs
- DataGridViewButtonCell.cs
- TraceProvider.cs
- DataMisalignedException.cs
- CombinedGeometry.cs
- WebException.cs
- WorkItem.cs
- TypeDependencyAttribute.cs
- SiteMapNodeItem.cs
- XMLDiffLoader.cs
- ValidatorCollection.cs
- SecurityCriticalDataForSet.cs
- CatalogZoneAutoFormat.cs
- Point4DValueSerializer.cs
- UnsafeMethods.cs
- EventLogPermissionEntryCollection.cs
- OleDbStruct.cs
- PropertyKey.cs
- DataGridView.cs
- ServerValidateEventArgs.cs
- PointHitTestResult.cs
- selecteditemcollection.cs
- Semaphore.cs
- MessageDecoder.cs
- DataGridCellClipboardEventArgs.cs
- KeyEventArgs.cs
- ArrayMergeHelper.cs
- UnsafeNetInfoNativeMethods.cs
- DbConnectionFactory.cs
- SqlParameter.cs
- DataGridViewCellPaintingEventArgs.cs
- Renderer.cs
- FrugalMap.cs
- XmlComplianceUtil.cs
- ReadOnlyNameValueCollection.cs
- RTLAwareMessageBox.cs
- LinqDataSourceView.cs
- BooleanProjectedSlot.cs
- CompilerState.cs
- PackagingUtilities.cs
- AssemblyCollection.cs
- Header.cs
- Accessible.cs
- ArgumentDirectionHelper.cs
- SecurityElement.cs
- TextEmbeddedObject.cs
- BindingContext.cs
- Overlapped.cs
- NotificationContext.cs
- SerializerWriterEventHandlers.cs
- DataSourceCache.cs
- GenerateScriptTypeAttribute.cs
- ListCollectionView.cs
- SerializationStore.cs
- DBParameter.cs
- PageRanges.cs
- WebBrowserPermission.cs
- HwndSource.cs
- MexHttpBindingCollectionElement.cs
- DelimitedListTraceListener.cs
- DesignerSerializationOptionsAttribute.cs
- NonParentingControl.cs
- TextServicesProperty.cs
- WebPartRestoreVerb.cs
- DetailsViewInsertEventArgs.cs
- recordstatefactory.cs
- CodeIndexerExpression.cs