Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / CommonUI / System / Drawing / Printing / PreviewPrintController.cs / 1305376 / PreviewPrintController.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Drawing.Printing { using Microsoft.Win32; using System; using System.Collections; using System.ComponentModel; using System.Diagnostics; using System.Drawing; using System.Drawing.Internal; using System.Drawing.Drawing2D; using System.Drawing.Imaging; using System.Drawing.Text; using System.Runtime.InteropServices; using System.Runtime.Versioning; using CodeAccessPermission = System.Security.CodeAccessPermission; ////// /// A PrintController which "prints" to a series of images. /// public class PreviewPrintController : PrintController { private IList list = new ArrayList(); // list of PreviewPageInfo private System.Drawing.Graphics graphics; private DeviceContext dc; private bool antiAlias; private void CheckSecurity() { IntSecurity.SafePrinting.Demand(); } ////// /// public override bool IsPreview { get { return true; } } ////// This is new public property which notifies if this controller is used for PrintPreview. /// ////// /// [ResourceExposure(ResourceScope.Process)] [ResourceConsumption(ResourceScope.Process)] public override void OnStartPrint(PrintDocument document, PrintEventArgs e) { Debug.Assert(dc == null && graphics == null, "PrintController methods called in the wrong order?"); // For security purposes, don't assume our public methods methods are called in any particular order CheckSecurity(); base.OnStartPrint(document, e); try { if (!document.PrinterSettings.IsValid) throw new InvalidPrinterException(document.PrinterSettings); IntSecurity.AllPrintingAndUnmanagedCode.Assert(); // We need a DC as a reference; we don't actually draw on it. // We make sure to reuse the same one to improve performance. dc = document.PrinterSettings.CreateInformationContext(modeHandle); } finally { CodeAccessPermission.RevertAssert(); } } ////// Implements StartPrint for generating print preview information. /// ////// /// [ResourceExposure(ResourceScope.Process)] [ResourceConsumption(ResourceScope.Machine | ResourceScope.Process, ResourceScope.Machine)] public override Graphics OnStartPage(PrintDocument document, PrintPageEventArgs e) { Debug.Assert(dc != null && graphics == null, "PrintController methods called in the wrong order?"); // For security purposes, don't assume our public methods methods are called in any particular order CheckSecurity(); base.OnStartPage(document, e); try { IntSecurity.AllPrintingAndUnmanagedCode.Assert(); e.PageSettings.CopyToHdevmode(modeHandle); Size size = e.PageBounds.Size; // Metafile framing rectangles apparently use hundredths of mm as their unit of measurement, // instead of the GDI+ standard hundredth of an inch. Size metafileSize = PrinterUnitConvert.Convert(size, PrinterUnit.Display, PrinterUnit.HundredthsOfAMillimeter); // Create a Metafile which accepts only GDI+ commands since we are the ones creating // and using this ... // Framework creates a dual-mode EMF for each page in the preview. // When these images are displayed in preview, // they are added to the dual-mode EMF. However, // GDI+ breaks during this process if the image // is sufficiently large and has more than 254 colors. // This code path can easily be avoided by requesting // an EmfPlusOnly EMF.. Metafile metafile = new Metafile(dc.Hdc, new Rectangle(0,0, metafileSize.Width, metafileSize.Height), MetafileFrameUnit.GdiCompatible, EmfType.EmfPlusOnly); PreviewPageInfo info = new PreviewPageInfo(metafile, size); list.Add(info); PrintPreviewGraphics printGraphics = new PrintPreviewGraphics(document, e); graphics = Graphics.FromImage(metafile); if (graphics != null && document.OriginAtMargins) { // Adjust the origin of the graphics object to be at the // user-specified margin location // int dpiX = UnsafeNativeMethods.GetDeviceCaps(new HandleRef(dc, dc.Hdc), SafeNativeMethods.LOGPIXELSX); int dpiY = UnsafeNativeMethods.GetDeviceCaps(new HandleRef(dc, dc.Hdc), SafeNativeMethods.LOGPIXELSY); int hardMarginX_DU = UnsafeNativeMethods.GetDeviceCaps(new HandleRef(dc, dc.Hdc), SafeNativeMethods.PHYSICALOFFSETX); int hardMarginY_DU = UnsafeNativeMethods.GetDeviceCaps(new HandleRef(dc, dc.Hdc), SafeNativeMethods.PHYSICALOFFSETY); float hardMarginX = hardMarginX_DU * 100 / dpiX; float hardMarginY = hardMarginY_DU * 100 / dpiY; graphics.TranslateTransform(-hardMarginX, -hardMarginY); graphics.TranslateTransform(document.DefaultPageSettings.Margins.Left, document.DefaultPageSettings.Margins.Top); } graphics.PrintingHelper = printGraphics; if (antiAlias) { graphics.TextRenderingHint = TextRenderingHint.AntiAlias; graphics.SmoothingMode = SmoothingMode.AntiAlias; } } finally { CodeAccessPermission.RevertAssert(); } return graphics; } ////// Implements StartEnd for generating print preview information. /// ////// /// public override void OnEndPage(PrintDocument document, PrintPageEventArgs e) { Debug.Assert(dc != null && graphics != null, "PrintController methods called in the wrong order?"); // For security purposes, don't assume our public methods methods are called in any particular order CheckSecurity(); graphics.Dispose(); graphics = null; base.OnEndPage(document, e); } ////// Implements EndPage for generating print preview information. /// ////// /// public override void OnEndPrint(PrintDocument document, PrintEventArgs e) { Debug.Assert(dc != null && graphics == null, "PrintController methods called in the wrong order?"); // For security purposes, don't assume our public methods are called in any particular order CheckSecurity(); dc.Dispose(); dc = null; base.OnEndPrint(document, e); } ////// Implements EndPrint for generating print preview information. /// ////// /// public PreviewPageInfo[] GetPreviewPageInfo() { // For security purposes, don't assume our public methods methods are called in any particular order CheckSecurity(); PreviewPageInfo[] temp = new PreviewPageInfo[list.Count]; list.CopyTo(temp, 0); return temp; } ////// The "printout". /// ///public virtual bool UseAntiAlias { get { return antiAlias; } set { antiAlias = value; } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ // // Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Drawing.Printing { using Microsoft.Win32; using System; using System.Collections; using System.ComponentModel; using System.Diagnostics; using System.Drawing; using System.Drawing.Internal; using System.Drawing.Drawing2D; using System.Drawing.Imaging; using System.Drawing.Text; using System.Runtime.InteropServices; using System.Runtime.Versioning; using CodeAccessPermission = System.Security.CodeAccessPermission; ////// /// A PrintController which "prints" to a series of images. /// public class PreviewPrintController : PrintController { private IList list = new ArrayList(); // list of PreviewPageInfo private System.Drawing.Graphics graphics; private DeviceContext dc; private bool antiAlias; private void CheckSecurity() { IntSecurity.SafePrinting.Demand(); } ////// /// public override bool IsPreview { get { return true; } } ////// This is new public property which notifies if this controller is used for PrintPreview. /// ////// /// [ResourceExposure(ResourceScope.Process)] [ResourceConsumption(ResourceScope.Process)] public override void OnStartPrint(PrintDocument document, PrintEventArgs e) { Debug.Assert(dc == null && graphics == null, "PrintController methods called in the wrong order?"); // For security purposes, don't assume our public methods methods are called in any particular order CheckSecurity(); base.OnStartPrint(document, e); try { if (!document.PrinterSettings.IsValid) throw new InvalidPrinterException(document.PrinterSettings); IntSecurity.AllPrintingAndUnmanagedCode.Assert(); // We need a DC as a reference; we don't actually draw on it. // We make sure to reuse the same one to improve performance. dc = document.PrinterSettings.CreateInformationContext(modeHandle); } finally { CodeAccessPermission.RevertAssert(); } } ////// Implements StartPrint for generating print preview information. /// ////// /// [ResourceExposure(ResourceScope.Process)] [ResourceConsumption(ResourceScope.Machine | ResourceScope.Process, ResourceScope.Machine)] public override Graphics OnStartPage(PrintDocument document, PrintPageEventArgs e) { Debug.Assert(dc != null && graphics == null, "PrintController methods called in the wrong order?"); // For security purposes, don't assume our public methods methods are called in any particular order CheckSecurity(); base.OnStartPage(document, e); try { IntSecurity.AllPrintingAndUnmanagedCode.Assert(); e.PageSettings.CopyToHdevmode(modeHandle); Size size = e.PageBounds.Size; // Metafile framing rectangles apparently use hundredths of mm as their unit of measurement, // instead of the GDI+ standard hundredth of an inch. Size metafileSize = PrinterUnitConvert.Convert(size, PrinterUnit.Display, PrinterUnit.HundredthsOfAMillimeter); // Create a Metafile which accepts only GDI+ commands since we are the ones creating // and using this ... // Framework creates a dual-mode EMF for each page in the preview. // When these images are displayed in preview, // they are added to the dual-mode EMF. However, // GDI+ breaks during this process if the image // is sufficiently large and has more than 254 colors. // This code path can easily be avoided by requesting // an EmfPlusOnly EMF.. Metafile metafile = new Metafile(dc.Hdc, new Rectangle(0,0, metafileSize.Width, metafileSize.Height), MetafileFrameUnit.GdiCompatible, EmfType.EmfPlusOnly); PreviewPageInfo info = new PreviewPageInfo(metafile, size); list.Add(info); PrintPreviewGraphics printGraphics = new PrintPreviewGraphics(document, e); graphics = Graphics.FromImage(metafile); if (graphics != null && document.OriginAtMargins) { // Adjust the origin of the graphics object to be at the // user-specified margin location // int dpiX = UnsafeNativeMethods.GetDeviceCaps(new HandleRef(dc, dc.Hdc), SafeNativeMethods.LOGPIXELSX); int dpiY = UnsafeNativeMethods.GetDeviceCaps(new HandleRef(dc, dc.Hdc), SafeNativeMethods.LOGPIXELSY); int hardMarginX_DU = UnsafeNativeMethods.GetDeviceCaps(new HandleRef(dc, dc.Hdc), SafeNativeMethods.PHYSICALOFFSETX); int hardMarginY_DU = UnsafeNativeMethods.GetDeviceCaps(new HandleRef(dc, dc.Hdc), SafeNativeMethods.PHYSICALOFFSETY); float hardMarginX = hardMarginX_DU * 100 / dpiX; float hardMarginY = hardMarginY_DU * 100 / dpiY; graphics.TranslateTransform(-hardMarginX, -hardMarginY); graphics.TranslateTransform(document.DefaultPageSettings.Margins.Left, document.DefaultPageSettings.Margins.Top); } graphics.PrintingHelper = printGraphics; if (antiAlias) { graphics.TextRenderingHint = TextRenderingHint.AntiAlias; graphics.SmoothingMode = SmoothingMode.AntiAlias; } } finally { CodeAccessPermission.RevertAssert(); } return graphics; } ////// Implements StartEnd for generating print preview information. /// ////// /// public override void OnEndPage(PrintDocument document, PrintPageEventArgs e) { Debug.Assert(dc != null && graphics != null, "PrintController methods called in the wrong order?"); // For security purposes, don't assume our public methods methods are called in any particular order CheckSecurity(); graphics.Dispose(); graphics = null; base.OnEndPage(document, e); } ////// Implements EndPage for generating print preview information. /// ////// /// public override void OnEndPrint(PrintDocument document, PrintEventArgs e) { Debug.Assert(dc != null && graphics == null, "PrintController methods called in the wrong order?"); // For security purposes, don't assume our public methods are called in any particular order CheckSecurity(); dc.Dispose(); dc = null; base.OnEndPrint(document, e); } ////// Implements EndPrint for generating print preview information. /// ////// /// public PreviewPageInfo[] GetPreviewPageInfo() { // For security purposes, don't assume our public methods methods are called in any particular order CheckSecurity(); PreviewPageInfo[] temp = new PreviewPageInfo[list.Count]; list.CopyTo(temp, 0); return temp; } ////// The "printout". /// ///public virtual bool UseAntiAlias { get { return antiAlias; } set { antiAlias = value; } } } } // 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
- WindowsToolbarItemAsMenuItem.cs
- ElementHostAutomationPeer.cs
- DrawingAttributesDefaultValueFactory.cs
- DataColumnMappingCollection.cs
- HttpAsyncResult.cs
- _LocalDataStoreMgr.cs
- PropertyDescriptorGridEntry.cs
- DataGridTableStyleMappingNameEditor.cs
- Menu.cs
- RTTrackingProfile.cs
- CompressEmulationStream.cs
- TypedTableBaseExtensions.cs
- SubMenuStyle.cs
- ColorContext.cs
- DynamicRenderer.cs
- SignatureToken.cs
- MetadataProperty.cs
- ServiceModelInstallComponent.cs
- DirectoryRedirect.cs
- MultilineStringConverter.cs
- ConstraintEnumerator.cs
- BitmapEffectGroup.cs
- BamlRecordHelper.cs
- AdjustableArrowCap.cs
- DataProtection.cs
- DependencyObjectType.cs
- DateTimeStorage.cs
- CompiledScopeCriteria.cs
- BufferedGraphics.cs
- StreamInfo.cs
- XamlToRtfWriter.cs
- TemplateEditingVerb.cs
- ExtentCqlBlock.cs
- Emitter.cs
- TreeNodeBindingCollection.cs
- GeneralTransform2DTo3DTo2D.cs
- DecimalConstantAttribute.cs
- TableCellCollection.cs
- ListViewGroup.cs
- XmlDataDocument.cs
- MailHeaderInfo.cs
- Menu.cs
- SizeConverter.cs
- TextBox.cs
- ObjectView.cs
- DbInsertCommandTree.cs
- QuaternionRotation3D.cs
- Rules.cs
- SmiGettersStream.cs
- BrushMappingModeValidation.cs
- CommandEventArgs.cs
- GenericPrincipal.cs
- TextRunTypographyProperties.cs
- RtType.cs
- ButtonColumn.cs
- PointConverter.cs
- DescendentsWalker.cs
- MessageQueueCriteria.cs
- LongTypeConverter.cs
- DataGridView.cs
- ProcessModelInfo.cs
- FixUpCollection.cs
- ConnectionPoint.cs
- DesignerLabelAdapter.cs
- EmptyQuery.cs
- PreservationFileReader.cs
- XmlName.cs
- ProfileBuildProvider.cs
- TextEditorCharacters.cs
- GridViewSelectEventArgs.cs
- DoubleLinkList.cs
- CurrencyWrapper.cs
- OwnerDrawPropertyBag.cs
- SqlDataReaderSmi.cs
- RotateTransform3D.cs
- ZipFileInfoCollection.cs
- NativeBuffer.cs
- CredentialSelector.cs
- DrawTreeNodeEventArgs.cs
- SymbolMethod.cs
- PersistNameAttribute.cs
- VersionedStreamOwner.cs
- UpdateTranslator.cs
- PropertyDescriptorCollection.cs
- HttpListenerResponse.cs
- TagElement.cs
- Decoder.cs
- ChannelBinding.cs
- Mappings.cs
- CodeExporter.cs
- PrimaryKeyTypeConverter.cs
- CodeTypeMember.cs
- TdsParserSessionPool.cs
- XamlVector3DCollectionSerializer.cs
- DataGridViewRowEventArgs.cs
- InfiniteIntConverter.cs
- SessionStateItemCollection.cs
- RepeatBehaviorConverter.cs
- FileDataSourceCache.cs
- EmptyEnumerator.cs