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

Side by Side Diff: chrome/renderer/printing/print_web_view_helper_linux.cc

Issue 516833002: Removed NativeMetafile and PreviewMetafile typedef as it's always PdfMetafileSkia. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@no_pdf
Patch Set: Thu Aug 28 02:43:23 PDT 2014 Created 6 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
OLDNEW
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/logging.h" 7 #include "base/logging.h"
8 #include "base/memory/scoped_ptr.h" 8 #include "base/memory/scoped_ptr.h"
9 #include "chrome/common/print_messages.h" 9 #include "chrome/common/print_messages.h"
10 #include "content/public/renderer/render_thread.h" 10 #include "content/public/renderer/render_thread.h"
11 #include "printing/metafile.h" 11 #include "printing/metafile.h"
12 #include "printing/metafile_impl.h"
13 #include "printing/metafile_skia_wrapper.h" 12 #include "printing/metafile_skia_wrapper.h"
14 #include "printing/page_size_margins.h" 13 #include "printing/page_size_margins.h"
14 #include "printing/pdf_metafile_skia.h"
15 #include "skia/ext/platform_device.h" 15 #include "skia/ext/platform_device.h"
16 #include "skia/ext/vector_canvas.h" 16 #include "skia/ext/vector_canvas.h"
17 #include "third_party/WebKit/public/web/WebLocalFrame.h" 17 #include "third_party/WebKit/public/web/WebLocalFrame.h"
18 18
19 #if !defined(OS_CHROMEOS) && !defined(OS_ANDROID) 19 #if !defined(OS_CHROMEOS) && !defined(OS_ANDROID)
20 #include "base/process/process_handle.h" 20 #include "base/process/process_handle.h"
21 #else 21 #else
22 #include "base/file_descriptor_posix.h" 22 #include "base/file_descriptor_posix.h"
23 #endif // !defined(OS_CHROMEOS) && !defined(OS_ANDROID) 23 #endif // !defined(OS_CHROMEOS) && !defined(OS_ANDROID)
24 24
25 namespace printing { 25 namespace printing {
26 26
27 using blink::WebFrame; 27 using blink::WebFrame;
28 28
29 bool PrintWebViewHelper::RenderPreviewPage( 29 bool PrintWebViewHelper::RenderPreviewPage(
30 int page_number, 30 int page_number,
31 const PrintMsg_Print_Params& print_params) { 31 const PrintMsg_Print_Params& print_params) {
32 PrintMsg_PrintPage_Params page_params; 32 PrintMsg_PrintPage_Params page_params;
33 page_params.params = print_params; 33 page_params.params = print_params;
34 page_params.page_number = page_number; 34 page_params.page_number = page_number;
35 scoped_ptr<Metafile> draft_metafile; 35 scoped_ptr<Metafile> draft_metafile;
36 Metafile* initial_render_metafile = print_preview_context_.metafile(); 36 Metafile* initial_render_metafile = print_preview_context_.metafile();
37 if (print_preview_context_.IsModifiable() && is_print_ready_metafile_sent_) { 37 if (print_preview_context_.IsModifiable() && is_print_ready_metafile_sent_) {
38 draft_metafile.reset(new PreviewMetafile); 38 draft_metafile.reset(new PdfMetafileSkia);
39 initial_render_metafile = draft_metafile.get(); 39 initial_render_metafile = draft_metafile.get();
40 } 40 }
41 41
42 base::TimeTicks begin_time = base::TimeTicks::Now(); 42 base::TimeTicks begin_time = base::TimeTicks::Now();
43 PrintPageInternal(page_params, 43 PrintPageInternal(page_params,
44 print_preview_context_.GetPrintCanvasSize(), 44 print_preview_context_.GetPrintCanvasSize(),
45 print_preview_context_.prepared_frame(), 45 print_preview_context_.prepared_frame(),
46 initial_render_metafile); 46 initial_render_metafile);
47 print_preview_context_.RenderedPreviewPage( 47 print_preview_context_.RenderedPreviewPage(
48 base::TimeTicks::Now() - begin_time); 48 base::TimeTicks::Now() - begin_time);
49 if (draft_metafile.get()) { 49 if (draft_metafile.get()) {
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::PrintPagesNative(blink::WebFrame* frame, 60 bool PrintWebViewHelper::PrintPagesNative(blink::WebFrame* frame,
61 int page_count, 61 int page_count,
62 const gfx::Size& canvas_size) { 62 const gfx::Size& canvas_size) {
63 NativeMetafile metafile; 63 PdfMetafileSkia metafile;
64 if (!metafile.Init()) 64 if (!metafile.Init())
65 return false; 65 return false;
66 66
67 const PrintMsg_PrintPages_Params& params = *print_pages_params_; 67 const PrintMsg_PrintPages_Params& params = *print_pages_params_;
68 std::vector<int> printed_pages; 68 std::vector<int> printed_pages;
69 69
70 if (params.pages.empty()) { 70 if (params.pages.empty()) {
71 for (int i = 0; i < page_count; ++i) { 71 for (int i = 0; i < page_count; ++i) {
72 printed_pages.push_back(i); 72 printed_pages.push_back(i);
73 } 73 }
(...skipping 115 matching lines...) Expand 10 before | Expand all | Expand 10 after
189 } 189 }
190 RenderPageContent(frame, params.page_number, canvas_area, content_area, 190 RenderPageContent(frame, params.page_number, canvas_area, content_area,
191 scale_factor, canvas.get()); 191 scale_factor, canvas.get());
192 192
193 // Done printing. Close the device context to retrieve the compiled metafile. 193 // Done printing. Close the device context to retrieve the compiled metafile.
194 if (!metafile->FinishPage()) 194 if (!metafile->FinishPage())
195 NOTREACHED() << "metafile failed"; 195 NOTREACHED() << "metafile failed";
196 } 196 }
197 197
198 } // namespace printing 198 } // namespace printing
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698