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

Side by Side Diff: content/renderer/gpu/gpu_benchmarking_extension.cc

Issue 2640983002: Rename paint data structures (Closed)
Patch Set: three Rs: rebase, readme, review Created 3 years, 11 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 "content/renderer/gpu/gpu_benchmarking_extension.h" 5 #include "content/renderer/gpu/gpu_benchmarking_extension.h"
6 6
7 #include <stddef.h> 7 #include <stddef.h>
8 8
9 #include <string> 9 #include <string>
10 #include <utility> 10 #include <utility>
11 11
12 #include "base/base64.h" 12 #include "base/base64.h"
13 #include "base/command_line.h" 13 #include "base/command_line.h"
14 #include "base/files/file_path.h" 14 #include "base/files/file_path.h"
15 #include "base/files/file_util.h" 15 #include "base/files/file_util.h"
16 #include "base/macros.h" 16 #include "base/macros.h"
17 #include "base/memory/ptr_util.h" 17 #include "base/memory/ptr_util.h"
18 #include "base/strings/string_number_conversions.h" 18 #include "base/strings/string_number_conversions.h"
19 #include "cc/layers/layer.h" 19 #include "cc/layers/layer.h"
20 #include "cc/paint/paint_canvas.h"
20 #include "content/common/child_process_messages.h" 21 #include "content/common/child_process_messages.h"
21 #include "content/common/input/synthetic_gesture_params.h" 22 #include "content/common/input/synthetic_gesture_params.h"
22 #include "content/common/input/synthetic_pinch_gesture_params.h" 23 #include "content/common/input/synthetic_pinch_gesture_params.h"
23 #include "content/common/input/synthetic_pointer_action_list_params.h" 24 #include "content/common/input/synthetic_pointer_action_list_params.h"
24 #include "content/common/input/synthetic_pointer_action_params.h" 25 #include "content/common/input/synthetic_pointer_action_params.h"
25 #include "content/common/input/synthetic_smooth_drag_gesture_params.h" 26 #include "content/common/input/synthetic_smooth_drag_gesture_params.h"
26 #include "content/common/input/synthetic_smooth_scroll_gesture_params.h" 27 #include "content/common/input/synthetic_smooth_scroll_gesture_params.h"
27 #include "content/common/input/synthetic_tap_gesture_params.h" 28 #include "content/common/input/synthetic_tap_gesture_params.h"
28 #include "content/public/child/v8_value_converter.h" 29 #include "content/public/child/v8_value_converter.h"
29 #include "content/public/common/content_switches.h" 30 #include "content/public/common/content_switches.h"
(...skipping 100 matching lines...) Expand 10 before | Expand all | Expand 10 after
130 // Let skia register known effect subclasses. This basically enables 131 // Let skia register known effect subclasses. This basically enables
131 // reflection on those subclasses required for picture serialization. 132 // reflection on those subclasses required for picture serialization.
132 SkiaBenchmarking::Initialize(); 133 SkiaBenchmarking::Initialize();
133 } 134 }
134 135
135 // Recursively serializes the layer tree. 136 // Recursively serializes the layer tree.
136 // Each layer in the tree is serialized into a separate skp file 137 // Each layer in the tree is serialized into a separate skp file
137 // in the given directory. 138 // in the given directory.
138 void Serialize(const cc::Layer* root_layer) { 139 void Serialize(const cc::Layer* root_layer) {
139 for (auto* layer : *root_layer->GetLayerTree()) { 140 for (auto* layer : *root_layer->GetLayerTree()) {
140 sk_sp<SkPicture> picture = layer->GetPicture(); 141 sk_sp<const SkPicture> picture = cc::ToSkPicture(layer->GetPicture());
141 if (!picture) 142 if (!picture)
142 continue; 143 continue;
143 144
144 // Serialize picture to file. 145 // Serialize picture to file.
145 // TODO(alokp): Note that for this to work Chrome needs to be launched 146 // TODO(alokp): Note that for this to work Chrome needs to be launched
146 // with 147 // with
147 // --no-sandbox command-line flag. Get rid of this limitation. 148 // --no-sandbox command-line flag. Get rid of this limitation.
148 // CRBUG: 139640. 149 // CRBUG: 139640.
149 std::string filename = "layer_" + base::IntToString(layer_id_++) + ".skp"; 150 std::string filename = "layer_" + base::IntToString(layer_id_++) + ".skp";
150 std::string filepath = dirpath_.AppendASCII(filename).MaybeAsASCII(); 151 std::string filepath = dirpath_.AppendASCII(filename).MaybeAsASCII();
(...skipping 314 matching lines...) Expand 10 before | Expand all | Expand 10 after
465 const float kPageWidth = 612.0f; // 8.5 inch 466 const float kPageWidth = 612.0f; // 8.5 inch
466 const float kPageHeight = 792.0f; // 11 inch 467 const float kPageHeight = 792.0f; // 11 inch
467 const float kMarginTop = 29.0f; // 0.40 inch 468 const float kMarginTop = 29.0f; // 0.40 inch
468 const float kMarginLeft = 29.0f; // 0.40 inch 469 const float kMarginLeft = 29.0f; // 0.40 inch
469 const int kContentWidth = 555; // 7.71 inch 470 const int kContentWidth = 555; // 7.71 inch
470 const int kContentHeight = 735; // 10.21 inch 471 const int kContentHeight = 735; // 10.21 inch
471 blink::WebPrintParams params(blink::WebSize(kContentWidth, kContentHeight)); 472 blink::WebPrintParams params(blink::WebSize(kContentWidth, kContentHeight));
472 params.printerDPI = 300; 473 params.printerDPI = 300;
473 int page_count = frame->printBegin(params); 474 int page_count = frame->printBegin(params);
474 for (int i = 0; i < page_count; ++i) { 475 for (int i = 0; i < page_count; ++i) {
475 SkCanvas* canvas = doc->beginPage(kPageWidth, kPageHeight); 476 SkCanvas* sk_canvas = doc->beginPage(kPageWidth, kPageHeight);
476 SkAutoCanvasRestore auto_restore(canvas, true); 477 cc::PaintCanvasPassThrough canvas(sk_canvas);
477 canvas->translate(kMarginLeft, kMarginTop); 478 cc::PaintCanvasAutoRestore auto_restore(&canvas, true);
479 canvas.translate(kMarginLeft, kMarginTop);
478 480
479 #if defined(OS_WIN) || defined(OS_MACOSX) 481 #if defined(OS_WIN) || defined(OS_MACOSX)
480 float page_shrink = frame->getPrintPageShrink(i); 482 float page_shrink = frame->getPrintPageShrink(i);
481 DCHECK(page_shrink > 0); 483 DCHECK(page_shrink > 0);
482 canvas->scale(page_shrink, page_shrink); 484 canvas.scale(page_shrink, page_shrink);
483 #endif 485 #endif
484 486
485 frame->printPage(i, canvas); 487 frame->printPage(i, &canvas);
486 } 488 }
487 frame->printEnd(); 489 frame->printEnd();
488 } 490 }
489 491
490 static void PrintDocumentTofile(v8::Isolate* isolate, 492 static void PrintDocumentTofile(v8::Isolate* isolate,
491 const std::string& filename, 493 const std::string& filename,
492 sk_sp<SkDocument> (*make_doc)(SkWStream*)) { 494 sk_sp<SkDocument> (*make_doc)(SkWStream*)) {
493 GpuBenchmarkingContext context; 495 GpuBenchmarkingContext context;
494 if (!context.Init(true)) 496 if (!context.Init(true))
495 return; 497 return;
(...skipping 601 matching lines...) Expand 10 before | Expand all | Expand 10 after
1097 &gpu_driver_bug_workarounds))) { 1099 &gpu_driver_bug_workarounds))) {
1098 return; 1100 return;
1099 } 1101 }
1100 1102
1101 v8::Local<v8::Value> result; 1103 v8::Local<v8::Value> result;
1102 if (gin::TryConvertToV8(args->isolate(), gpu_driver_bug_workarounds, &result)) 1104 if (gin::TryConvertToV8(args->isolate(), gpu_driver_bug_workarounds, &result))
1103 args->Return(result); 1105 args->Return(result);
1104 } 1106 }
1105 1107
1106 } // namespace content 1108 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698