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

Side by Side Diff: chrome/renderer/print_web_view_helper_mac.mm

Issue 7747033: Merge 97702, 97820, 97976 (Closed) Base URL: svn://chrome-svn/chrome/branches/835/src/
Patch Set: Created 9 years, 3 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/renderer/print_web_view_helper.h" 5 #include "chrome/renderer/print_web_view_helper.h"
6 6
7 #import <AppKit/AppKit.h> 7 #import <AppKit/AppKit.h>
8 8
9 #include "base/logging.h" 9 #include "base/logging.h"
10 #include "base/mac/scoped_nsautorelease_pool.h" 10 #include "base/mac/scoped_nsautorelease_pool.h"
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after
52 52
53 // Ask the browser to create the shared memory for us. 53 // Ask the browser to create the shared memory for us.
54 if (!CopyMetafileDataToSharedMem(&metafile, 54 if (!CopyMetafileDataToSharedMem(&metafile,
55 &(page_params.metafile_data_handle))) { 55 &(page_params.metafile_data_handle))) {
56 page_params.data_size = 0; 56 page_params.data_size = 0;
57 } 57 }
58 58
59 Send(new PrintHostMsg_DidPrintPage(routing_id(), page_params)); 59 Send(new PrintHostMsg_DidPrintPage(routing_id(), page_params));
60 } 60 }
61 61
62 void PrintWebViewHelper::RenderPreviewPage(int page_number) { 62 bool PrintWebViewHelper::RenderPreviewPage(int page_number) {
63 float scale_factor = print_preview_context_.frame()->getPrintPageShrink(0); 63 float scale_factor = print_preview_context_.frame()->getPrintPageShrink(0);
64 PrintMsg_Print_Params printParams = print_preview_context_.print_params(); 64 PrintMsg_Print_Params printParams = print_preview_context_.print_params();
65 gfx::Rect content_area(printParams.margin_left, printParams.margin_top, 65 gfx::Rect content_area(printParams.margin_left, printParams.margin_top,
66 printParams.printable_size.width(), 66 printParams.printable_size.width(),
67 printParams.printable_size.height()); 67 printParams.printable_size.height());
68 68
69 printing::Metafile* initial_render_metafile = 69 printing::Metafile* initial_render_metafile =
70 print_preview_context_.metafile(); 70 print_preview_context_.metafile();
71 scoped_ptr<printing::PreviewMetafile> draft_metafile; 71 scoped_ptr<printing::PreviewMetafile> draft_metafile;
72 #if !defined(USE_SKIA) 72 #if !defined(USE_SKIA)
73 if (print_preview_context_.IsModifiable()) { 73 if (print_preview_context_.IsModifiable()) {
74 draft_metafile.reset(new printing::PreviewMetafile); 74 draft_metafile.reset(new printing::PreviewMetafile);
75 if (!draft_metafile->Init()) { 75 if (!draft_metafile->Init()) {
76 DidFinishPrinting(FAIL_PREVIEW); 76 return false;
77 return;
78 } 77 }
79 initial_render_metafile = draft_metafile.get(); 78 initial_render_metafile = draft_metafile.get();
80 } 79 }
81 #endif 80 #endif
82 81
83 base::TimeTicks begin_time = base::TimeTicks::Now(); 82 base::TimeTicks begin_time = base::TimeTicks::Now();
84 RenderPage(printParams.page_size, content_area, scale_factor, page_number, 83 RenderPage(printParams.page_size, content_area, scale_factor, page_number,
85 print_preview_context_.frame(), initial_render_metafile); 84 print_preview_context_.frame(), initial_render_metafile);
86 print_preview_context_.RenderedPreviewPage( 85 print_preview_context_.RenderedPreviewPage(
87 base::TimeTicks::Now() - begin_time); 86 base::TimeTicks::Now() - begin_time);
(...skipping 23 matching lines...) Expand all
111 complete_metafile->context(), 110 complete_metafile->context(),
112 draft_metafile->GetPageBounds(1).ToCGRect(), 111 draft_metafile->GetPageBounds(1).ToCGRect(),
113 false /* shrink_to_fit */, 112 false /* shrink_to_fit */,
114 false /* stretch_to_fit */, 113 false /* stretch_to_fit */,
115 true /* center_horizontally */, 114 true /* center_horizontally */,
116 true /* center_vertically */); 115 true /* center_vertically */);
117 complete_metafile->FinishPage(); 116 complete_metafile->FinishPage();
118 #endif 117 #endif
119 } 118 }
120 119
121 PreviewPageRendered(page_number, draft_metafile.get()); 120 return PreviewPageRendered(page_number, draft_metafile.get());
122 } 121 }
123 122
124 void PrintWebViewHelper::RenderPage( 123 void PrintWebViewHelper::RenderPage(
125 const gfx::Size& page_size, const gfx::Rect& content_area, 124 const gfx::Size& page_size, const gfx::Rect& content_area,
126 const float& scale_factor, int page_number, WebFrame* frame, 125 const float& scale_factor, int page_number, WebFrame* frame,
127 printing::Metafile* metafile) { 126 printing::Metafile* metafile) {
128 127
129 { 128 {
130 #if defined(USE_SKIA) 129 #if defined(USE_SKIA)
131 SkDevice* device = metafile->StartPageForVectorCanvas( 130 SkDevice* device = metafile->StartPageForVectorCanvas(
(...skipping 14 matching lines...) Expand all
146 base::mac::ScopedNSAutoreleasePool pool; 145 base::mac::ScopedNSAutoreleasePool pool;
147 CGContextRef cgContext = metafile->context(); 146 CGContextRef cgContext = metafile->context();
148 CGContextRef canvasPtr = cgContext; 147 CGContextRef canvasPtr = cgContext;
149 #endif 148 #endif
150 frame->printPage(page_number, canvasPtr); 149 frame->printPage(page_number, canvasPtr);
151 } 150 }
152 151
153 // Done printing. Close the device context to retrieve the compiled metafile. 152 // Done printing. Close the device context to retrieve the compiled metafile.
154 metafile->FinishPage(); 153 metafile->FinishPage();
155 } 154 }
OLDNEW
« no previous file with comments | « chrome/renderer/print_web_view_helper_linux.cc ('k') | chrome/renderer/print_web_view_helper_win.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698