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

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

Issue 7639023: Revert 96567 - Reland 96406 - Print preview page selection should not require a rerendering of dr... (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: Created 9 years, 4 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 48 matching lines...) Expand 10 before | Expand all | Expand 10 after
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 void 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 scoped_ptr<printing::Metafile> draft_metafile;
70 printing::Metafile* initial_render_metafile = 69 printing::Metafile* initial_render_metafile =
71 print_preview_context_.metafile(); 70 print_preview_context_.metafile();
72 71 scoped_ptr<printing::PreviewMetafile> draft_metafile;
73 #if defined(USE_SKIA) 72 #if !defined(USE_SKIA)
74 bool need_draft_metafile = print_preview_context_.IsModifiable() && 73 if (print_preview_context_.IsModifiable()) {
75 is_print_ready_metafile_sent_; 74 draft_metafile.reset(new printing::PreviewMetafile);
76 #else
77 bool need_draft_metafile = print_preview_context_.IsModifiable() &&
78 print_preview_context_.generate_draft_pages();
79 // NOTE: If the rendering page need to be in draft metafile and print ready
80 // metafile, we should always render to the draft metafile first and then
81 // copy that into the print ready metafile because CG does not allow us to do
82 // it in the other order.
83 #endif
84
85 if (need_draft_metafile) {
86 draft_metafile.reset(new printing::PreviewMetafile());
87 if (!draft_metafile->Init()) { 75 if (!draft_metafile->Init()) {
88 DidFinishPrinting(FAIL_PREVIEW); 76 DidFinishPrinting(FAIL_PREVIEW);
89 return; 77 return;
90 } 78 }
91 initial_render_metafile = draft_metafile.get(); 79 initial_render_metafile = draft_metafile.get();
92 } 80 }
81 #endif
93 82
94 base::TimeTicks begin_time = base::TimeTicks::Now(); 83 base::TimeTicks begin_time = base::TimeTicks::Now();
95 RenderPage(printParams.page_size, content_area, scale_factor, page_number, 84 RenderPage(printParams.page_size, content_area, scale_factor, page_number,
96 print_preview_context_.frame(), initial_render_metafile); 85 print_preview_context_.frame(), initial_render_metafile);
97 print_preview_context_.RenderedPreviewPage( 86 print_preview_context_.RenderedPreviewPage(
98 base::TimeTicks::Now() - begin_time); 87 base::TimeTicks::Now() - begin_time);
99 88
100 if (draft_metafile.get()) { 89 if (print_preview_context_.IsModifiable()) {
90 #if defined(USE_SKIA)
91 DCHECK(!draft_metafile.get());
92 draft_metafile.reset(
93 print_preview_context_.metafile()->GetMetafileForCurrentPage());
94 #else
101 draft_metafile->FinishDocument(); 95 draft_metafile->FinishDocument();
102 #if !defined(USE_SKIA) 96
103 if (!is_print_ready_metafile_sent_) { 97 // With CG, we rendered into a new metafile so we could get it as a draft
104 // With CG, we rendered into a new metafile so we could get it as a draft 98 // document. Now we need to add it to complete document. But the document
105 // document. Now we need to add it to print ready document. But the 99 // has already been scaled and adjusted for margins, so do a 1:1 drawing.
106 // document has already been scaled and adjusted for margins, so do a 1:1 100 printing::Metafile* complete_metafile = print_preview_context_.metafile();
107 // drawing. 101 bool success = complete_metafile->StartPage(
108 printing::Metafile* print_ready_metafile = 102 printParams.page_size, gfx::Rect(printParams.page_size), 1.0);
109 print_preview_context_.metafile(); 103 DCHECK(success);
110 bool success = print_ready_metafile->StartPage( 104 // StartPage unconditionally flips the content over, flip it back since it
111 printParams.page_size, gfx::Rect(printParams.page_size), 1.0); 105 // was already flipped in |draft_metafile|.
112 DCHECK(success); 106 CGContextTranslateCTM(complete_metafile->context(), 0,
113 // StartPage unconditionally flips the content over, flip it back since it 107 printParams.page_size.height());
114 // was already flipped in |draft_metafile|. 108 CGContextScaleCTM(complete_metafile->context(), 1.0, -1.0);
115 CGContextTranslateCTM(print_ready_metafile->context(), 0, 109
116 printParams.page_size.height()); 110 draft_metafile->RenderPage(1,
117 CGContextScaleCTM(print_ready_metafile->context(), 1.0, -1.0); 111 complete_metafile->context(),
118 draft_metafile->RenderPage(1, 112 draft_metafile->GetPageBounds(1).ToCGRect(),
119 print_ready_metafile->context(), 113 false /* shrink_to_fit */,
120 draft_metafile->GetPageBounds(1).ToCGRect(), 114 false /* stretch_to_fit */,
121 false /* shrink_to_fit */, 115 true /* center_horizontally */,
122 false /* stretch_to_fit */, 116 true /* center_vertically */);
123 true /* center_horizontally */, 117 complete_metafile->FinishPage();
124 true /* center_vertically */);
125 print_ready_metafile->FinishPage();
126 }
127 #endif
128 } else {
129 #if defined(USE_SKIA)
130 if (print_preview_context_.IsModifiable() &&
131 print_preview_context_.generate_draft_pages()) {
132 DCHECK(!draft_metafile.get());
133 draft_metafile.reset(
134 print_preview_context_.metafile()->GetMetafileForCurrentPage());
135 }
136 #endif 118 #endif
137 } 119 }
120
138 PreviewPageRendered(page_number, draft_metafile.get()); 121 PreviewPageRendered(page_number, draft_metafile.get());
139 } 122 }
140 123
141 void PrintWebViewHelper::RenderPage( 124 void PrintWebViewHelper::RenderPage(
142 const gfx::Size& page_size, const gfx::Rect& content_area, 125 const gfx::Size& page_size, const gfx::Rect& content_area,
143 const float& scale_factor, int page_number, WebFrame* frame, 126 const float& scale_factor, int page_number, WebFrame* frame,
144 printing::Metafile* metafile) { 127 printing::Metafile* metafile) {
145 128
146 { 129 {
147 #if defined(USE_SKIA) 130 #if defined(USE_SKIA)
148 SkDevice* device = metafile->StartPageForVectorCanvas( 131 SkDevice* device = metafile->StartPageForVectorCanvas(
149 page_size, content_area, scale_factor); 132 page_size, content_area, scale_factor);
150 if (!device) 133 if (!device)
151 return; 134 return;
152 135
153 SkRefPtr<skia::VectorCanvas> canvas = new skia::VectorCanvas(device); 136 SkRefPtr<skia::VectorCanvas> canvas = new skia::VectorCanvas(device);
154 canvas->unref(); // SkRefPtr and new both took a reference. 137 canvas->unref(); // SkRefPtr and new both took a reference.
155 WebKit::WebCanvas* canvasPtr = canvas.get(); 138 WebKit::WebCanvas* canvasPtr = canvas.get();
156 printing::MetafileSkiaWrapper::SetMetafileOnCanvas(canvasPtr, metafile); 139 printing::MetafileSkiaWrapper::SetMetafileOnCanvas(canvasPtr, metafile);
157 printing::MetafileSkiaWrapper::SetDraftMode(canvasPtr,
158 is_print_ready_metafile_sent_);
159 #else 140 #else
160 bool success = metafile->StartPage(page_size, content_area, scale_factor); 141 bool success = metafile->StartPage(page_size, content_area, scale_factor);
161 DCHECK(success); 142 DCHECK(success);
162 // printPage can create autoreleased references to |context|. PDF contexts 143 // printPage can create autoreleased references to |context|. PDF contexts
163 // don't write all their data until they are destroyed, so we need to make 144 // don't write all their data until they are destroyed, so we need to make
164 // certain that there are no lingering references. 145 // certain that there are no lingering references.
165 base::mac::ScopedNSAutoreleasePool pool; 146 base::mac::ScopedNSAutoreleasePool pool;
166 CGContextRef cgContext = metafile->context(); 147 CGContextRef cgContext = metafile->context();
167 CGContextRef canvasPtr = cgContext; 148 CGContextRef canvasPtr = cgContext;
168 #endif 149 #endif
169 frame->printPage(page_number, canvasPtr); 150 frame->printPage(page_number, canvasPtr);
170 } 151 }
171 152
172 // Done printing. Close the device context to retrieve the compiled metafile. 153 // Done printing. Close the device context to retrieve the compiled metafile.
173 metafile->FinishPage(); 154 metafile->FinishPage();
174 } 155 }
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