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

Unified Diff: chrome/renderer/print_web_view_helper_linux.cc

Issue 2807029: Move GetPageSizeAndMarginsInPoints from linux code to generic code. (Closed)
Patch Set: s/params/default_params/ Created 10 years, 6 months 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
« no previous file with comments | « chrome/renderer/print_web_view_helper.cc ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/renderer/print_web_view_helper_linux.cc
diff --git a/chrome/renderer/print_web_view_helper_linux.cc b/chrome/renderer/print_web_view_helper_linux.cc
index b909b07861e08c5489cfdf198fc2a34c7b4cd9db..a02709bdf5e080988a726c2e1907aafc3d1371e1 100644
--- a/chrome/renderer/print_web_view_helper_linux.cc
+++ b/chrome/renderer/print_web_view_helper_linux.cc
@@ -13,79 +13,35 @@
#include "third_party/WebKit/WebKit/chromium/public/WebFrame.h"
#include "third_party/WebKit/WebKit/chromium/public/WebSize.h"
-using printing::ConvertPixelsToPoint;
-using printing::ConvertPixelsToPointDouble;
using printing::NativeMetafile;
using WebKit::WebFrame;
using WebKit::WebSize;
-// If frame is NULL, this function returns the default value.
-static void GetPageSizeAndMarginsInPoints(WebFrame* frame,
- int page_index,
- double* content_width_in_points,
- double* content_height_in_points,
- double* margin_top_in_points,
- double* margin_right_in_points,
- double* margin_bottom_in_points,
- double* margin_left_in_points) {
+static void FillDefaultPrintParams(ViewMsg_Print_Params* params) {
// TODO(myhuang): Get printing parameters via IPC
// using the print_web_view_helper.cc version of Print.
// For testing purpose, we hard-coded printing parameters here.
// The paper size is US Letter (8.5 in. by 11 in.).
- WebSize page_size_in_pixels(8.5 * printing::kPixelsPerInch,
- 11.0 * printing::kPixelsPerInch);
-
- int margin_top_in_pixels = static_cast<int>(
+ double page_width_in_pixel = 8.5 * printing::kPixelsPerInch;
+ double page_height_in_pixel = 11.0 * printing::kPixelsPerInch;
+ params->page_size = gfx::Size(
+ static_cast<int>(page_width_in_pixel),
+ static_cast<int>(page_height_in_pixel));
+ params->printable_size = gfx::Size(
+ static_cast<int>(
+ page_width_in_pixel -
+ (NativeMetafile::kLeftMarginInInch +
+ NativeMetafile::kRightMarginInInch) * printing::kPixelsPerInch),
+ static_cast<int>(
+ page_height_in_pixel -
+ (NativeMetafile::kTopMarginInInch +
+ NativeMetafile::kBottomMarginInInch) * printing::kPixelsPerInch));
+ params->margin_top = static_cast<int>(
NativeMetafile::kTopMarginInInch * printing::kPixelsPerInch);
- int margin_right_in_pixels = static_cast<int>(
- NativeMetafile::kRightMarginInInch * printing::kPixelsPerInch);
- int margin_bottom_in_pixels = static_cast<int>(
- NativeMetafile::kBottomMarginInInch * printing::kPixelsPerInch);
- int margin_left_in_pixels = static_cast<int>(
+ params->margin_left = static_cast<int>(
NativeMetafile::kLeftMarginInInch * printing::kPixelsPerInch);
-
- if (frame) {
- frame->pageSizeAndMarginsInPixels(page_index,
- page_size_in_pixels,
- margin_top_in_pixels,
- margin_right_in_pixels,
- margin_bottom_in_pixels,
- margin_left_in_pixels);
- }
-
- *content_width_in_points = ConvertPixelsToPoint(page_size_in_pixels.width
- - margin_left_in_pixels
- - margin_right_in_pixels);
- *content_height_in_points = ConvertPixelsToPoint(page_size_in_pixels.height
- - margin_top_in_pixels
- - margin_bottom_in_pixels);
-
- // Invalid page size and/or margins. We just use the default setting.
- if (*content_width_in_points < 1.0 || *content_height_in_points < 1.0) {
- GetPageSizeAndMarginsInPoints(NULL,
- page_index,
- content_width_in_points,
- content_height_in_points,
- margin_top_in_points,
- margin_right_in_points,
- margin_bottom_in_points,
- margin_left_in_points);
- return;
- }
-
- if (margin_top_in_points)
- *margin_top_in_points =
- ConvertPixelsToPointDouble(margin_top_in_pixels);
- if (margin_right_in_points)
- *margin_right_in_points =
- ConvertPixelsToPointDouble(margin_right_in_pixels);
- if (margin_bottom_in_points)
- *margin_bottom_in_points =
- ConvertPixelsToPointDouble(margin_bottom_in_pixels);
- if (margin_left_in_points)
- *margin_left_in_points =
- ConvertPixelsToPointDouble(margin_left_in_pixels);
+ params->dpi = printing::kPixelsPerInch;
}
void PrintWebViewHelper::Print(WebFrame* frame, bool script_initiated) {
@@ -93,13 +49,14 @@ void PrintWebViewHelper::Print(WebFrame* frame, bool script_initiated) {
if (IsPrinting())
return;
+ ViewMsg_Print_Params default_settings;
+ FillDefaultPrintParams(&default_settings);
+
double content_width, content_height;
- GetPageSizeAndMarginsInPoints(frame, 0, &content_width, &content_height,
+ GetPageSizeAndMarginsInPoints(frame, 0, default_settings,
+ &content_width, &content_height,
NULL, NULL, NULL, NULL);
- ViewMsg_Print_Params default_settings;
- default_settings.printable_size = gfx::Size(
- static_cast<int>(content_width), static_cast<int>(content_height));
default_settings.dpi = printing::kPointsPerInch;
default_settings.min_shrink = 1.25;
default_settings.max_shrink = 2.0;
@@ -107,6 +64,9 @@ void PrintWebViewHelper::Print(WebFrame* frame, bool script_initiated) {
default_settings.document_cookie = 0;
default_settings.selection_only = false;
+ default_settings.printable_size = gfx::Size(
+ static_cast<int>(content_width), static_cast<int>(content_height));
+
ViewMsg_PrintPages_Params print_settings;
print_settings.params = default_settings;
@@ -171,6 +131,9 @@ void PrintWebViewHelper::PrintPage(const ViewMsg_PrintPage_Params& params,
const gfx::Size& canvas_size,
WebFrame* frame,
printing::NativeMetafile* metafile) {
+ ViewMsg_Print_Params default_params;
+ FillDefaultPrintParams(&default_params);
+
double content_width_in_points;
double content_height_in_points;
double margin_top_in_points;
@@ -179,6 +142,7 @@ void PrintWebViewHelper::PrintPage(const ViewMsg_PrintPage_Params& params,
double margin_left_in_points;
GetPageSizeAndMarginsInPoints(frame,
params.page_number,
+ default_params,
&content_width_in_points,
&content_height_in_points,
&margin_top_in_points,
« no previous file with comments | « chrome/renderer/print_web_view_helper.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698