Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(10709)

Unified Diff: chrome/renderer/print_web_view_helper_mac.mm

Issue 8585017: PrintPreview: Honor the print media page size and margin values. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fix conflicts Created 9 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/renderer/print_web_view_helper_mac.mm
diff --git a/chrome/renderer/print_web_view_helper_mac.mm b/chrome/renderer/print_web_view_helper_mac.mm
index 5962a1a9dfe3d6ddbbc1d9f6354d7147f25dcb41..b5a2c379f2ba5d1f36deabe596a0eb2743db497b 100644
--- a/chrome/renderer/print_web_view_helper_mac.mm
+++ b/chrome/renderer/print_web_view_helper_mac.mm
@@ -32,13 +32,29 @@ void PrintWebViewHelper::PrintPageInternal(
if (!metafile.Init())
return;
- float scale_factor = frame->getPrintPageShrink(params.page_number);
+ double scale_factor = frame->getPrintPageShrink(params.page_number);
int page_number = params.page_number;
// Render page for printing.
+ printing::PageSizeMargins page_layout_in_points;
+ gfx::Size page_size(params.params.content_size);
gfx::Rect content_area(params.params.content_size);
- RenderPage(params.params.content_size, content_area, scale_factor,
- page_number, frame, false, &metafile);
+
+#if defined(USE_SKIA)
vandebo (ex-Chrome) 2011/12/14 19:05:38 Probably should note the bug number that will trac
kmadhusu 2011/12/19 09:52:19 I have made code changes to honor the css settings
+ GetPageSizeAndMarginsInPoints(print_preview_context_.frame(), page_number,
+ print_pages_params_->params,
+ ignore_css_margins_, fit_to_page_,
+ &scale_factor, &page_layout_in_points);
+ UpdatePageSizeAndContentAreaFromPageLayout(page_layout_in_points, &page_size,
+ &content_area);
+#else
+ GetPageSizeAndMarginsInPoints(print_preview_context_.frame(), page_number,
+ print_pages_params_->params, false, false, NULL,
+ &page_layout_in_points);
+#endif
+
+ RenderPage(page_size, content_area, scale_factor, page_number, frame, false,
+ &metafile, page_layout_in_points);
metafile.FinishDocument();
PrintHostMsg_DidPrintPage_Params page_params;
@@ -46,11 +62,8 @@ void PrintWebViewHelper::PrintPageInternal(
page_params.page_number = page_number;
page_params.document_cookie = params.params.document_cookie;
page_params.actual_shrink = scale_factor;
- page_params.page_size = params.params.page_size;
- page_params.content_area = gfx::Rect(params.params.margin_left,
- params.params.margin_top,
- params.params.content_size.width(),
- params.params.content_size.height());
+ page_params.page_size = page_size;
+ page_params.content_area = content_area;
// Ask the browser to create the shared memory for us.
if (!CopyMetafileDataToSharedMem(&metafile,
@@ -62,12 +75,27 @@ void PrintWebViewHelper::PrintPageInternal(
}
bool PrintWebViewHelper::RenderPreviewPage(int page_number) {
- float scale_factor = print_preview_context_.frame()->getPrintPageShrink(0);
+ double scale_factor = print_preview_context_.frame()->getPrintPageShrink(0);
PrintMsg_Print_Params printParams = print_preview_context_.print_params();
+ printing::PageSizeMargins page_layout_in_points;
+ gfx::Size page_size(printParams.page_size);
gfx::Rect content_area(printParams.margin_left, printParams.margin_top,
printParams.content_size.width(),
printParams.content_size.height());
+#if defined(USE_SKIA)
+ GetPageSizeAndMarginsInPoints(print_preview_context_.frame(), page_number,
+ print_pages_params_->params,
+ ignore_css_margins_, fit_to_page_,
+ &scale_factor, &page_layout_in_points);
+ UpdatePageSizeAndContentAreaFromPageLayout(page_layout_in_points, &page_size,
+ &content_area);
+#else
+ GetPageSizeAndMarginsInPoints(print_preview_context_.frame(), page_number,
+ print_pages_params_->params, false, false, NULL,
+ &page_layout_in_points);
+#endif
+
scoped_ptr<printing::Metafile> draft_metafile;
printing::Metafile* initial_render_metafile =
print_preview_context_.metafile();
@@ -96,8 +124,9 @@ bool PrintWebViewHelper::RenderPreviewPage(int page_number) {
}
base::TimeTicks begin_time = base::TimeTicks::Now();
- RenderPage(printParams.page_size, content_area, scale_factor, page_number,
- print_preview_context_.frame(), true, initial_render_metafile);
+ RenderPage(page_size, content_area, scale_factor, page_number,
+ print_preview_context_.frame(), true, initial_render_metafile,
+ page_layout_in_points);
print_preview_context_.RenderedPreviewPage(
base::TimeTicks::Now() - begin_time);
@@ -111,13 +140,13 @@ bool PrintWebViewHelper::RenderPreviewPage(int page_number) {
// drawing.
printing::Metafile* print_ready_metafile =
print_preview_context_.metafile();
- bool success = print_ready_metafile->StartPage(
- printParams.page_size, gfx::Rect(printParams.page_size), 1.0);
+ bool success = print_ready_metafile->StartPage(page_size,
+ gfx::Rect(page_size), 1.0);
DCHECK(success);
// StartPage unconditionally flips the content over, flip it back since it
// was already flipped in |draft_metafile|.
CGContextTranslateCTM(print_ready_metafile->context(), 0,
- printParams.page_size.height());
+ page_size.height());
CGContextScaleCTM(print_ready_metafile->context(), 1.0, -1.0);
draft_metafile->RenderPage(1,
print_ready_metafile->context(),
@@ -144,8 +173,9 @@ bool PrintWebViewHelper::RenderPreviewPage(int page_number) {
void PrintWebViewHelper::RenderPage(
const gfx::Size& page_size, const gfx::Rect& content_area,
- const float& scale_factor, int page_number, WebFrame* frame,
- bool is_preview, printing::Metafile* metafile) {
+ const double& scale_factor, int page_number, WebFrame* frame,
+ bool is_preview, printing::Metafile* metafile,
+ printing::PageSizeMargins page_layout_in_points) {
{
#if defined(USE_SKIA)
@@ -171,11 +201,6 @@ void PrintWebViewHelper::RenderPage(
CGContextRef canvas_ptr = cgContext;
#endif
- printing::PageSizeMargins page_layout_in_points;
- GetPageSizeAndMarginsInPoints(frame, page_number,
- print_pages_params_->params,
- &page_layout_in_points);
-
#if !defined(USE_SKIA)
// For CoreGraphics, print in the margins before printing in the content
// area so that we don't spill over. Webkit draws a white background in the

Powered by Google App Engine
This is Rietveld 408576698