Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/printing/print_web_view_helper.h" | 5 #include "chrome/renderer/printing/print_web_view_helper.h" |
| 6 | 6 |
| 7 #include "base/file_descriptor_posix.h" | 7 #include "base/file_descriptor_posix.h" |
| 8 #include "base/logging.h" | 8 #include "base/logging.h" |
| 9 #include "base/memory/scoped_ptr.h" | 9 #include "base/memory/scoped_ptr.h" |
| 10 #include "base/metrics/histogram.h" | 10 #include "base/metrics/histogram.h" |
| (...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 50 draft_metafile->FinishDocument(); | 50 draft_metafile->FinishDocument(); |
| 51 } else if (print_preview_context_.IsModifiable() && | 51 } else if (print_preview_context_.IsModifiable() && |
| 52 print_preview_context_.generate_draft_pages()) { | 52 print_preview_context_.generate_draft_pages()) { |
| 53 DCHECK(!draft_metafile.get()); | 53 DCHECK(!draft_metafile.get()); |
| 54 draft_metafile.reset( | 54 draft_metafile.reset( |
| 55 print_preview_context_.metafile()->GetMetafileForCurrentPage()); | 55 print_preview_context_.metafile()->GetMetafileForCurrentPage()); |
| 56 } | 56 } |
| 57 return PreviewPageRendered(page_number, draft_metafile.get()); | 57 return PreviewPageRendered(page_number, draft_metafile.get()); |
| 58 } | 58 } |
| 59 | 59 |
| 60 bool PrintWebViewHelper::PrintPages(WebFrame* frame, const WebNode& node) { | 60 bool PrintWebViewHelper::PrintPagesNative(WebKit::WebFrame* frame, |
| 61 const WebKit::WebNode& node, | |
| 62 int page_count, | |
| 63 const gfx::Size& canvas_size) { | |
| 61 NativeMetafile metafile; | 64 NativeMetafile metafile; |
| 62 if (!metafile.Init()) | 65 if (!metafile.Init()) |
| 63 return false; | 66 return false; |
| 64 | 67 |
| 65 const PrintMsg_PrintPages_Params& params = *print_pages_params_; | 68 const PrintMsg_PrintPages_Params& params = *print_pages_params_; |
| 66 std::vector<int> printed_pages; | 69 std::vector<int> printed_pages; |
| 67 if (!RenderPages(params, frame, node, &printed_pages, &metafile)) { | 70 if (!RenderPages(params, frame, &printed_pages, page_count, canvas_size, |
| 71 &metafile)) { | |
| 68 return false; | 72 return false; |
| 69 } | 73 } |
| 70 | 74 |
| 71 metafile.FinishDocument(); | 75 metafile.FinishDocument(); |
| 72 | 76 |
| 73 // Get the size of the resulting metafile. | 77 // Get the size of the resulting metafile. |
| 74 uint32 buf_size = metafile.GetDataSize(); | 78 uint32 buf_size = metafile.GetDataSize(); |
| 75 DCHECK_GT(buf_size, 0u); | 79 DCHECK_GT(buf_size, 0u); |
| 76 | 80 |
| 77 #if defined(OS_CHROMEOS) | 81 #if defined(OS_CHROMEOS) |
| (...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 116 Send(new PrintHostMsg_DidPrintPage(routing_id(), printed_page_params)); | 120 Send(new PrintHostMsg_DidPrintPage(routing_id(), printed_page_params)); |
| 117 // Send the rest of the pages with an invalid metafile handle. | 121 // Send the rest of the pages with an invalid metafile handle. |
| 118 printed_page_params.metafile_data_handle.fd = -1; | 122 printed_page_params.metafile_data_handle.fd = -1; |
| 119 } | 123 } |
| 120 return true; | 124 return true; |
| 121 #endif // defined(OS_CHROMEOS) | 125 #endif // defined(OS_CHROMEOS) |
| 122 } | 126 } |
| 123 | 127 |
| 124 bool PrintWebViewHelper::RenderPages(const PrintMsg_PrintPages_Params& params, | 128 bool PrintWebViewHelper::RenderPages(const PrintMsg_PrintPages_Params& params, |
| 125 WebKit::WebFrame* frame, | 129 WebKit::WebFrame* frame, |
| 126 const WebKit::WebNode& node, | |
| 127 std::vector<int>* printed_pages, | 130 std::vector<int>* printed_pages, |
| 131 int page_count, | |
|
Lei Zhang
2013/01/23 08:31:38
With |page_count| coming from outside, RenderPages
Vitaly Buka (NO REVIEWS)
2013/01/23 09:32:31
I can remove RenderPage.
I see that loop in Print
| |
| 132 const gfx::Size& canvas_size, | |
| 128 Metafile* metafile) { | 133 Metafile* metafile) { |
| 129 PrepareFrameAndViewForPrint prepare(params.params, frame, node); | |
| 130 PrintMsg_Print_Params print_params = params.params; | |
| 131 UpdateFrameAndViewFromCssPageLayout(frame, node, &prepare, print_params, | |
| 132 ignore_css_margins_); | |
| 133 | |
| 134 int page_count = prepare.GetExpectedPageCount(); | |
| 135 if (!page_count) | |
| 136 return false; | |
| 137 | |
| 138 #if !defined(OS_CHROMEOS) | |
| 139 // TODO(vitalybuka): should be page_count or valid pages from params.pages. | |
| 140 // See http://crbug.com/161576 | |
| 141 Send(new PrintHostMsg_DidGetPrintedPagesCount(routing_id(), | |
| 142 print_params.document_cookie, | |
| 143 page_count)); | |
| 144 #endif | |
| 145 | |
| 146 if (params.pages.empty()) { | 134 if (params.pages.empty()) { |
| 147 for (int i = 0; i < page_count; ++i) { | 135 for (int i = 0; i < page_count; ++i) { |
| 148 printed_pages->push_back(i); | 136 printed_pages->push_back(i); |
| 149 } | 137 } |
| 150 } else { | 138 } else { |
| 151 // TODO(vitalybuka): redesign to make more code cross platform. | 139 // TODO(vitalybuka): redesign to make more code cross platform. |
| 152 for (size_t i = 0; i < params.pages.size(); ++i) { | 140 for (size_t i = 0; i < params.pages.size(); ++i) { |
| 153 if (params.pages[i] >= 0 && params.pages[i] < page_count) { | 141 if (params.pages[i] >= 0 && params.pages[i] < page_count) { |
| 154 printed_pages->push_back(params.pages[i]); | 142 printed_pages->push_back(params.pages[i]); |
| 155 } | 143 } |
| 156 } | 144 } |
| 157 } | 145 } |
| 158 | 146 |
| 159 if (printed_pages->empty()) | 147 if (printed_pages->empty()) |
| 160 return false; | 148 return false; |
| 161 | 149 |
| 162 PrintMsg_PrintPage_Params page_params; | 150 PrintMsg_PrintPage_Params page_params; |
| 163 page_params.params = print_params; | 151 page_params.params = params.params; |
| 164 const gfx::Size& canvas_size = prepare.GetPrintCanvasSize(); | |
| 165 for (size_t i = 0; i < printed_pages->size(); ++i) { | 152 for (size_t i = 0; i < printed_pages->size(); ++i) { |
| 166 page_params.page_number = (*printed_pages)[i]; | 153 page_params.page_number = (*printed_pages)[i]; |
| 167 PrintPageInternal(page_params, canvas_size, frame, metafile); | 154 PrintPageInternal(page_params, canvas_size, frame, metafile); |
| 168 } | 155 } |
| 169 | 156 |
| 170 return true; | 157 return true; |
| 171 } | 158 } |
| 172 | 159 |
| 173 void PrintWebViewHelper::PrintPageInternal( | 160 void PrintWebViewHelper::PrintPageInternal( |
| 174 const PrintMsg_PrintPage_Params& params, | 161 const PrintMsg_PrintPage_Params& params, |
| (...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 210 } | 197 } |
| 211 RenderPageContent(frame, params.page_number, canvas_area, content_area, | 198 RenderPageContent(frame, params.page_number, canvas_area, content_area, |
| 212 scale_factor, canvas.get()); | 199 scale_factor, canvas.get()); |
| 213 | 200 |
| 214 // Done printing. Close the device context to retrieve the compiled metafile. | 201 // Done printing. Close the device context to retrieve the compiled metafile. |
| 215 if (!metafile->FinishPage()) | 202 if (!metafile->FinishPage()) |
| 216 NOTREACHED() << "metafile failed"; | 203 NOTREACHED() << "metafile failed"; |
| 217 } | 204 } |
| 218 | 205 |
| 219 } // namespace printing | 206 } // namespace printing |
| OLD | NEW |