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

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

Issue 6665046: Unfork VectorPlatformCanvas. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Address comments Created 9 years, 9 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
« no previous file with comments | « no previous file | chrome/renderer/print_web_view_helper_win.cc » ('j') | skia/ext/vector_canvas.cc » ('J')
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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 #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/scoped_ptr.h" 9 #include "base/scoped_ptr.h"
10 #include "chrome/common/render_messages.h" 10 #include "chrome/common/render_messages.h"
(...skipping 201 matching lines...) Expand 10 before | Expand all | Expand 10 after
212 &margin_top_in_points, 212 &margin_top_in_points,
213 &margin_right_in_points, 213 &margin_right_in_points,
214 &margin_bottom_in_points, 214 &margin_bottom_in_points,
215 &margin_left_in_points); 215 &margin_left_in_points);
216 216
217 gfx::Size page_size( 217 gfx::Size page_size(
218 content_width_in_points + margin_right_in_points + 218 content_width_in_points + margin_right_in_points +
219 margin_left_in_points, 219 margin_left_in_points,
220 content_height_in_points + margin_top_in_points + 220 content_height_in_points + margin_top_in_points +
221 margin_bottom_in_points); 221 margin_bottom_in_points);
222 gfx::Point content_origin(margin_left_in_points, margin_top_in_points);
222 223
223 cairo_t* cairo_context = 224 skia::PlatformDevice* device = metafile->StartPageForVectorCanvas(
224 metafile->StartPage(page_size, 225 page_size, content_origin, 1.0f);
225 margin_top_in_points, 226 if (!device)
226 margin_left_in_points);
227 if (!cairo_context)
228 return; 227 return;
229 228
230 canvas->reset(new skia::VectorCanvas(cairo_context, 229 canvas->reset(new skia::VectorCanvas(device));
231 canvas_size.width(),
232 canvas_size.height()));
233 frame->printPage(params.page_number, canvas->get()); 230 frame->printPage(params.page_number, canvas->get());
234 231
235 // TODO(myhuang): We should handle transformation for paper margins. 232 // TODO(myhuang): We should handle transformation for paper margins.
236 // TODO(myhuang): We should render the header and the footer. 233 // TODO(myhuang): We should render the header and the footer.
237 234
238 // Done printing. Close the device context to retrieve the compiled metafile. 235 // Done printing. Close the device context to retrieve the compiled metafile.
239 if (!metafile->FinishPage()) 236 if (!metafile->FinishPage())
240 NOTREACHED() << "metafile failed"; 237 NOTREACHED() << "metafile failed";
241 } 238 }
OLDNEW
« no previous file with comments | « no previous file | chrome/renderer/print_web_view_helper_win.cc » ('j') | skia/ext/vector_canvas.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698