Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 #include "base/logging.h" | 7 #include "base/logging.h" |
| 8 #include "base/memory/scoped_ptr.h" | 8 #include "base/memory/scoped_ptr.h" |
| 9 #include "base/metrics/histogram.h" | 9 #include "base/metrics/histogram.h" |
| 10 #include "base/process_util.h" | 10 #include "base/process_util.h" |
| (...skipping 108 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 119 } | 119 } |
| 120 | 120 |
| 121 Send(new PrintHostMsg_DidPrintPage(routing_id(), page_params)); | 121 Send(new PrintHostMsg_DidPrintPage(routing_id(), page_params)); |
| 122 } | 122 } |
| 123 | 123 |
| 124 void PrintWebViewHelper::RenderPreviewPage(int page_number) { | 124 void PrintWebViewHelper::RenderPreviewPage(int page_number) { |
| 125 PrintMsg_Print_Params print_params = print_preview_context_.print_params(); | 125 PrintMsg_Print_Params print_params = print_preview_context_.print_params(); |
| 126 // Calculate the dpi adjustment. | 126 // Calculate the dpi adjustment. |
| 127 float scale_factor = static_cast<float>(print_params.desired_dpi / | 127 float scale_factor = static_cast<float>(print_params.desired_dpi / |
| 128 print_params.dpi); | 128 print_params.dpi); |
| 129 scoped_ptr<Metafile> draft_metafile; | |
| 130 printing::Metafile* initial_render_metafile = | |
| 131 print_preview_context_.metafile(); | |
| 132 | |
| 133 if (print_preview_context_.IsModifiable() && is_complete_metafile_sent_) { | |
| 134 draft_metafile.reset(new printing::PreviewMetafile); | |
| 135 initial_render_metafile = draft_metafile.get(); | |
| 136 } | |
| 129 | 137 |
| 130 base::TimeTicks begin_time = base::TimeTicks::Now(); | 138 base::TimeTicks begin_time = base::TimeTicks::Now(); |
| 131 printing::Metafile* render_page_result = | 139 printing::Metafile* render_page_result = |
| 132 RenderPage(print_params, &scale_factor, page_number, true, | 140 RenderPage(print_params, &scale_factor, page_number, true, |
| 133 print_preview_context_.frame(), | 141 print_preview_context_.frame(), initial_render_metafile); |
| 134 print_preview_context_.metafile()); | 142 |
| 135 // In the preview flow, RenderPage will never return a new metafile. | 143 if (!draft_metafile.get()) { |
| 136 DCHECK_EQ(render_page_result, print_preview_context_.metafile()); | 144 // In the preview flow, RenderPage will never return a new metafile. |
| 145 DCHECK_EQ(render_page_result, print_preview_context_.metafile()); | |
|
vandebo (ex-Chrome)
2011/08/10 17:21:40
Change the second DCHECK arg to initial_render_met
kmadhusu
2011/08/10 19:01:13
Done.
| |
| 146 } | |
| 137 | 147 |
| 138 print_preview_context_.RenderedPreviewPage( | 148 print_preview_context_.RenderedPreviewPage( |
| 139 base::TimeTicks::Now() - begin_time); | 149 base::TimeTicks::Now() - begin_time); |
| 140 | 150 |
| 141 scoped_ptr<printing::Metafile> page_metafile; | 151 if (draft_metafile.get()) { |
| 142 if (print_preview_context_.IsModifiable()) { | 152 draft_metafile->FinishDocument(); |
| 143 page_metafile.reset( | 153 } else if (print_preview_context_.IsModifiable() && |
| 154 print_preview_context_.generate_draft_pages()){ | |
| 155 DCHECK(!draft_metafile.get()); | |
| 156 draft_metafile.reset( | |
| 144 print_preview_context_.metafile()->GetMetafileForCurrentPage()); | 157 print_preview_context_.metafile()->GetMetafileForCurrentPage()); |
| 145 } | 158 } |
| 146 PreviewPageRendered(page_number, page_metafile.get()); | 159 PreviewPageRendered(page_number, draft_metafile.get()); |
| 147 } | 160 } |
| 148 | 161 |
| 149 Metafile* PrintWebViewHelper::RenderPage( | 162 Metafile* PrintWebViewHelper::RenderPage( |
| 150 const PrintMsg_Print_Params& params, float* scale_factor, int page_number, | 163 const PrintMsg_Print_Params& params, float* scale_factor, int page_number, |
| 151 bool is_preview, WebFrame* frame, Metafile* metafile) { | 164 bool is_preview, WebFrame* frame, Metafile* metafile) { |
| 152 PageSizeMargins page_layout_in_points; | 165 PageSizeMargins page_layout_in_points; |
| 153 GetPageSizeAndMarginsInPoints(frame, page_number, params, | 166 GetPageSizeAndMarginsInPoints(frame, page_number, params, |
| 154 &page_layout_in_points); | 167 &page_layout_in_points); |
| 155 | 168 |
| 156 int width; | 169 int width; |
| (...skipping 19 matching lines...) Expand all Loading... | |
| 176 static_cast<int>(page_layout_in_points.margin_top), | 189 static_cast<int>(page_layout_in_points.margin_top), |
| 177 static_cast<int>(page_layout_in_points.content_width), | 190 static_cast<int>(page_layout_in_points.content_width), |
| 178 static_cast<int>(page_layout_in_points.content_height)); | 191 static_cast<int>(page_layout_in_points.content_height)); |
| 179 SkDevice* device = metafile->StartPageForVectorCanvas( | 192 SkDevice* device = metafile->StartPageForVectorCanvas( |
| 180 page_size, content_area, frame->getPrintPageShrink(page_number)); | 193 page_size, content_area, frame->getPrintPageShrink(page_number)); |
| 181 DCHECK(device); | 194 DCHECK(device); |
| 182 // The printPage method may take a reference to the canvas we pass down, so it | 195 // The printPage method may take a reference to the canvas we pass down, so it |
| 183 // can't be a stack object. | 196 // can't be a stack object. |
| 184 SkRefPtr<skia::VectorCanvas> canvas = new skia::VectorCanvas(device); | 197 SkRefPtr<skia::VectorCanvas> canvas = new skia::VectorCanvas(device); |
| 185 canvas->unref(); // SkRefPtr and new both took a reference. | 198 canvas->unref(); // SkRefPtr and new both took a reference. |
| 186 if (is_preview) | 199 if (is_preview) { |
| 187 printing::MetafileSkiaWrapper::SetMetafileOnCanvas(canvas.get(), metafile); | 200 printing::MetafileSkiaWrapper::SetMetafileOnCanvas(canvas.get(), metafile); |
| 201 printing::MetafileSkiaWrapper::SetDraftMode(canvas.get(), | |
| 202 is_complete_metafile_sent_); | |
| 203 } | |
| 188 | 204 |
| 189 float webkit_scale_factor = frame->printPage(page_number, canvas.get()); | 205 float webkit_scale_factor = frame->printPage(page_number, canvas.get()); |
| 190 if (*scale_factor <= 0 || webkit_scale_factor <= 0) { | 206 if (*scale_factor <= 0 || webkit_scale_factor <= 0) { |
| 191 NOTREACHED() << "Printing page " << page_number << " failed."; | 207 NOTREACHED() << "Printing page " << page_number << " failed."; |
| 192 } else { | 208 } else { |
| 193 // Update the dpi adjustment with the "page |scale_factor|" calculated in | 209 // Update the dpi adjustment with the "page |scale_factor|" calculated in |
| 194 // webkit. | 210 // webkit. |
| 195 *scale_factor /= webkit_scale_factor; | 211 *scale_factor /= webkit_scale_factor; |
| 196 } | 212 } |
| 197 | 213 |
| (...skipping 80 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 278 shared_buf.Unmap(); | 294 shared_buf.Unmap(); |
| 279 return false; | 295 return false; |
| 280 } | 296 } |
| 281 shared_buf.GiveToProcess(base::GetCurrentProcessHandle(), shared_mem_handle); | 297 shared_buf.GiveToProcess(base::GetCurrentProcessHandle(), shared_mem_handle); |
| 282 shared_buf.Unmap(); | 298 shared_buf.Unmap(); |
| 283 | 299 |
| 284 Send(new PrintHostMsg_DuplicateSection(routing_id(), *shared_mem_handle, | 300 Send(new PrintHostMsg_DuplicateSection(routing_id(), *shared_mem_handle, |
| 285 shared_mem_handle)); | 301 shared_mem_handle)); |
| 286 return true; | 302 return true; |
| 287 } | 303 } |
| OLD | NEW |