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...) 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...) 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...) 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 |