Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / Orcas / QFE / wpf / src / Core / CSharp / System / Windows / Media / Renderer.cs / 1 / Renderer.cs
//------------------------------------------------------------------------------ // //// Copyright (C) Microsoft Corporation. All rights reserved. // // // Description: // Though called "Renderer", this is used only for the 'rendering // to a BitmapImage' case, and not when rendering to an HwndTarget. // //----------------------------------------------------------------------------- using System; using System.Windows; using System.Collections.Generic; using System.Windows.Threading; using System.Diagnostics; using MS.Internal; using System.Windows.Media; using System.Windows.Media.Composition; using MS.Win32; using System.Security; using System.Security.Permissions; namespace System.Windows.Media { static internal class Renderer { ////// Critical - unmanaged pointer arguments, access critical resources, calls unmanaged code /// [SecurityCritical] static public void Render( IntPtr pRenderTarget, DUCE.Channel channel, Visual visual, int width, int height, double dpiX, double dpiY) { Render(pRenderTarget, channel, visual, width, height, dpiX, dpiY, Matrix.Identity, Rect.Empty, false); } ////// If fRenderForBitmapEffect is true, the method calls special methods on visual /// to render it specifically for an effect to be applied to it. It excludes /// properties such as transform, clip, offset and guidelines. /// ////// Critical - unmanaged pointer arguments, access critical resources, calls unmanaged code /// [SecurityCritical] static internal void Render( IntPtr pRenderTarget, DUCE.Channel channel, Visual visual, int width, int height, double dpiX, double dpiY, Matrix worldTransform, Rect windowClip, bool fRenderForBitmapEffect ) { DUCE.Resource target = new DUCE.Resource(); DUCE.Resource root = new DUCE.Resource(); DUCE.ResourceHandle targetHandle = DUCE.ResourceHandle.Null; DUCE.ResourceHandle rootHandle = DUCE.ResourceHandle.Null; Matrix deviceTransform = new Matrix( dpiX * (1.0 / 96.0), 0, 0, dpiY * (1.0 / 96.0), 0, 0); deviceTransform = worldTransform * deviceTransform; MatrixTransform mtDeviceTransform = new MatrixTransform(deviceTransform); DUCE.ResourceHandle deviceTransformHandle = ((DUCE.IResource)mtDeviceTransform).AddRefOnChannel(channel); try { // ----------------------------------------------------------- // Create the composition target and root visual resources. target.CreateOrAddRefOnChannel(channel, DUCE.ResourceType.TYPE_GENERICRENDERTARGET); targetHandle = target.Handle; DUCE.CompositionTarget.PrintInitialize( targetHandle, pRenderTarget, width, height, channel); root.CreateOrAddRefOnChannel(channel, DUCE.ResourceType.TYPE_VISUAL); rootHandle = root.Handle; DUCE.CompositionNode.SetTransform( rootHandle, deviceTransformHandle, channel); DUCE.CompositionTarget.SetRoot( targetHandle, rootHandle, channel); channel.Commit(); // ----------------------------------------------------------- // Render the freshly created target. RenderContext renderContext = new RenderContext(); renderContext.Initialize(channel, rootHandle); visual.Precompute(); if (fRenderForBitmapEffect) { visual.RenderForBitmapEffect(renderContext, 0); } else { visual.Render(renderContext, 0); } // Mark the visible realizations. RealizationContext realizationContext = new RealizationContext(); realizationContext.WindowClip = (windowClip.IsEmpty) ? new Rect(0, 0, width, height) : windowClip; DUCE.ChannelSet channelSet = new DUCE.ChannelSet(); channelSet.Channel = channel; realizationContext.BeginFrame(false /* full walk */, true /* walk for BitmapRenderTarget */); realizationContext.ChannelSet = channelSet; realizationContext.TransformStack.Push(ref deviceTransform, /* combine */ false); if (fRenderForBitmapEffect) { visual.MarkVisibleRealizationsForBitmapEffect(realizationContext); } else { visual.MarkVisibleRealizations(realizationContext); } realizationContext.TransformStack.Pop(); // Execute the realization updates. realizationContext.ExecuteRealizationsUpdateSchedule(); // ------------------------------------------------------------ // Flush the channel and present the composition target. channel.Commit(); channel.Present(); MediaContext mediaContext = MediaContext.CurrentMediaContext; mediaContext.NotifySyncChannelMessage(channel); // // Note: RealizationContext.EndFrame does not need to be called // here because we don't cache the realization context. // } finally { // ----------------------------------------------------------- // Clean up and release the root visual. if (!rootHandle.IsNull) { DUCE.CompositionNode.RemoveAllChildren( rootHandle, channel); if (fRenderForBitmapEffect) { visual.ReleaseOnChannelForBitmapEffect(channel); } else { ((DUCE.IResource)visual).ReleaseOnChannel(channel); } root.ReleaseOnChannel(channel); } // ------------------------------------------------------------ // Release the world transform. if (!deviceTransformHandle.IsNull) { ((DUCE.IResource)mtDeviceTransform).ReleaseOnChannel(channel); } // ------------------------------------------------------------ // Clean up and release the composition target. if (!targetHandle.IsNull) { DUCE.CompositionTarget.SetRoot( targetHandle, DUCE.ResourceHandle.Null, channel); target.ReleaseOnChannel(channel); } // // Since we initiate ReleaseOnChannel from the root, that // should not enqueue any delayed release. // Debug.Assert(channel.IsRemoveAndReleaseQueueEmpty()); // ----------------------------------------------------------- // Flush the channel and present the composition target. channel.Commit(); channel.Present(); MediaContext mediaContext = MediaContext.CurrentMediaContext; mediaContext.NotifySyncChannelMessage(channel); } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. //------------------------------------------------------------------------------ // //// Copyright (C) Microsoft Corporation. All rights reserved. // // // Description: // Though called "Renderer", this is used only for the 'rendering // to a BitmapImage' case, and not when rendering to an HwndTarget. // //----------------------------------------------------------------------------- using System; using System.Windows; using System.Collections.Generic; using System.Windows.Threading; using System.Diagnostics; using MS.Internal; using System.Windows.Media; using System.Windows.Media.Composition; using MS.Win32; using System.Security; using System.Security.Permissions; namespace System.Windows.Media { static internal class Renderer { ////// Critical - unmanaged pointer arguments, access critical resources, calls unmanaged code /// [SecurityCritical] static public void Render( IntPtr pRenderTarget, DUCE.Channel channel, Visual visual, int width, int height, double dpiX, double dpiY) { Render(pRenderTarget, channel, visual, width, height, dpiX, dpiY, Matrix.Identity, Rect.Empty, false); } ////// If fRenderForBitmapEffect is true, the method calls special methods on visual /// to render it specifically for an effect to be applied to it. It excludes /// properties such as transform, clip, offset and guidelines. /// ////// Critical - unmanaged pointer arguments, access critical resources, calls unmanaged code /// [SecurityCritical] static internal void Render( IntPtr pRenderTarget, DUCE.Channel channel, Visual visual, int width, int height, double dpiX, double dpiY, Matrix worldTransform, Rect windowClip, bool fRenderForBitmapEffect ) { DUCE.Resource target = new DUCE.Resource(); DUCE.Resource root = new DUCE.Resource(); DUCE.ResourceHandle targetHandle = DUCE.ResourceHandle.Null; DUCE.ResourceHandle rootHandle = DUCE.ResourceHandle.Null; Matrix deviceTransform = new Matrix( dpiX * (1.0 / 96.0), 0, 0, dpiY * (1.0 / 96.0), 0, 0); deviceTransform = worldTransform * deviceTransform; MatrixTransform mtDeviceTransform = new MatrixTransform(deviceTransform); DUCE.ResourceHandle deviceTransformHandle = ((DUCE.IResource)mtDeviceTransform).AddRefOnChannel(channel); try { // ----------------------------------------------------------- // Create the composition target and root visual resources. target.CreateOrAddRefOnChannel(channel, DUCE.ResourceType.TYPE_GENERICRENDERTARGET); targetHandle = target.Handle; DUCE.CompositionTarget.PrintInitialize( targetHandle, pRenderTarget, width, height, channel); root.CreateOrAddRefOnChannel(channel, DUCE.ResourceType.TYPE_VISUAL); rootHandle = root.Handle; DUCE.CompositionNode.SetTransform( rootHandle, deviceTransformHandle, channel); DUCE.CompositionTarget.SetRoot( targetHandle, rootHandle, channel); channel.Commit(); // ----------------------------------------------------------- // Render the freshly created target. RenderContext renderContext = new RenderContext(); renderContext.Initialize(channel, rootHandle); visual.Precompute(); if (fRenderForBitmapEffect) { visual.RenderForBitmapEffect(renderContext, 0); } else { visual.Render(renderContext, 0); } // Mark the visible realizations. RealizationContext realizationContext = new RealizationContext(); realizationContext.WindowClip = (windowClip.IsEmpty) ? new Rect(0, 0, width, height) : windowClip; DUCE.ChannelSet channelSet = new DUCE.ChannelSet(); channelSet.Channel = channel; realizationContext.BeginFrame(false /* full walk */, true /* walk for BitmapRenderTarget */); realizationContext.ChannelSet = channelSet; realizationContext.TransformStack.Push(ref deviceTransform, /* combine */ false); if (fRenderForBitmapEffect) { visual.MarkVisibleRealizationsForBitmapEffect(realizationContext); } else { visual.MarkVisibleRealizations(realizationContext); } realizationContext.TransformStack.Pop(); // Execute the realization updates. realizationContext.ExecuteRealizationsUpdateSchedule(); // ------------------------------------------------------------ // Flush the channel and present the composition target. channel.Commit(); channel.Present(); MediaContext mediaContext = MediaContext.CurrentMediaContext; mediaContext.NotifySyncChannelMessage(channel); // // Note: RealizationContext.EndFrame does not need to be called // here because we don't cache the realization context. // } finally { // ----------------------------------------------------------- // Clean up and release the root visual. if (!rootHandle.IsNull) { DUCE.CompositionNode.RemoveAllChildren( rootHandle, channel); if (fRenderForBitmapEffect) { visual.ReleaseOnChannelForBitmapEffect(channel); } else { ((DUCE.IResource)visual).ReleaseOnChannel(channel); } root.ReleaseOnChannel(channel); } // ------------------------------------------------------------ // Release the world transform. if (!deviceTransformHandle.IsNull) { ((DUCE.IResource)mtDeviceTransform).ReleaseOnChannel(channel); } // ------------------------------------------------------------ // Clean up and release the composition target. if (!targetHandle.IsNull) { DUCE.CompositionTarget.SetRoot( targetHandle, DUCE.ResourceHandle.Null, channel); target.ReleaseOnChannel(channel); } // // Since we initiate ReleaseOnChannel from the root, that // should not enqueue any delayed release. // Debug.Assert(channel.IsRemoveAndReleaseQueueEmpty()); // ----------------------------------------------------------- // Flush the channel and present the composition target. channel.Commit(); channel.Present(); MediaContext mediaContext = MediaContext.CurrentMediaContext; mediaContext.NotifySyncChannelMessage(channel); } } } } // 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
- JulianCalendar.cs
- CursorConverter.cs
- ResizeBehavior.cs
- PageAction.cs
- FrameworkRichTextComposition.cs
- Axis.cs
- DocumentGridPage.cs
- SqlFactory.cs
- SecurityChannelListener.cs
- PenContext.cs
- ExpressionBuilder.cs
- XmlAggregates.cs
- AspNetHostingPermission.cs
- ScriptControlManager.cs
- JpegBitmapEncoder.cs
- ContentDisposition.cs
- SymmetricAlgorithm.cs
- XmlWriterTraceListener.cs
- PartialToken.cs
- TimeoutException.cs
- TrackingMemoryStreamFactory.cs
- StylusTouchDevice.cs
- HwndTarget.cs
- DefaultPropertyAttribute.cs
- ExpressionBindingCollection.cs
- XmlDataSourceNodeDescriptor.cs
- CompatibleComparer.cs
- Style.cs
- XmlSchema.cs
- MdImport.cs
- SocketAddress.cs
- CommandExpr.cs
- DocumentGridPage.cs
- HttpCachePolicyElement.cs
- Pens.cs
- PostBackOptions.cs
- ActivationServices.cs
- RichTextBox.cs
- DataGridItemAttachedStorage.cs
- DoubleAnimationBase.cs
- KeyValuePairs.cs
- SecurityRuntime.cs
- ReadOnlyTernaryTree.cs
- UpdateTranslator.cs
- SqlDataSource.cs
- CodeAttributeArgumentCollection.cs
- DomainUpDown.cs
- TransformDescriptor.cs
- BaseUriHelper.cs
- RtfControlWordInfo.cs
- Walker.cs
- PassportAuthentication.cs
- DataSourceHelper.cs
- Symbol.cs
- RealizationDrawingContextWalker.cs
- WorkflowViewElement.cs
- RootProfilePropertySettingsCollection.cs
- ObjectConverter.cs
- CatalogZoneBase.cs
- SerializerProvider.cs
- IntegerCollectionEditor.cs
- EmptyStringExpandableObjectConverter.cs
- TextFormatter.cs
- ZeroOpNode.cs
- Model3DGroup.cs
- Command.cs
- Transform.cs
- CommandHelpers.cs
- WebPartEditorApplyVerb.cs
- DuplexChannelFactory.cs
- ExtendedProperty.cs
- DataGridViewRowsRemovedEventArgs.cs
- entitydatasourceentitysetnameconverter.cs
- TimeSpanSecondsOrInfiniteConverter.cs
- QueryOutputWriter.cs
- FileEnumerator.cs
- SafeCryptHandles.cs
- SqlInternalConnectionTds.cs
- LocationSectionRecord.cs
- MethodExpr.cs
- Mutex.cs
- StorageEntityContainerMapping.cs
- storepermissionattribute.cs
- ConfigurationStrings.cs
- XmlDictionaryString.cs
- AsymmetricAlgorithm.cs
- ToolboxBitmapAttribute.cs
- SchemaCollectionPreprocessor.cs
- DnsEndPoint.cs
- ColorConvertedBitmap.cs
- DeflateEmulationStream.cs
- JournalEntryListConverter.cs
- XmlDocument.cs
- ViewStateModeByIdAttribute.cs
- DoubleLinkList.cs
- mansign.cs
- ConsumerConnectionPoint.cs
- PathFigure.cs
- ClientFormsIdentity.cs
- DynamicResourceExtensionConverter.cs