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

Side by Side Diff: ui/compositor/canvas_painter.cc

Issue 2877483003: Implements core logic for Pixel Canvas (Closed)
Patch Set: Update tests Created 3 years, 5 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 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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 "ui/compositor/canvas_painter.h" 5 #include "ui/compositor/canvas_painter.h"
6 6
7 #include "cc/paint/display_item_list.h" 7 #include "cc/paint/display_item_list.h"
8 #include "ui/compositor/compositor_switches.h"
8 9
9 namespace ui { 10 namespace ui {
10 11
11 CanvasPainter::CanvasPainter(SkBitmap* output, 12 CanvasPainter::CanvasPainter(SkBitmap* output,
12 const gfx::Size& paint_size, 13 const gfx::Size& paint_size,
13 float raster_scale, 14 float raster_scale,
14 SkColor clear_color) 15 SkColor clear_color)
15 : output_(output), 16 : output_(output),
16 paint_size_(paint_size), 17 paint_size_(paint_size),
17 raster_scale_(raster_scale), 18 raster_scale_(raster_scale),
18 clear_color_(clear_color), 19 clear_color_(clear_color),
19 list_(new cc::DisplayItemList), 20 list_(new cc::DisplayItemList),
20 context_(list_.get(), raster_scale, gfx::Rect(paint_size_)) {} 21 context_(list_.get(),
22 raster_scale,
23 gfx::ScaleToRoundedRect(
24 gfx::Rect(paint_size_),
25 IsPixelCanvasRecordingEnabled() ? raster_scale : 1.f)) {}
danakj 2017/07/21 17:29:39 Rather than reading the command line and trying to
malaykeshav 2017/07/21 23:30:17 Done
21 26
22 CanvasPainter::~CanvasPainter() { 27 CanvasPainter::~CanvasPainter() {
23 gfx::Size pixel_size = gfx::ScaleToCeiledSize(paint_size_, raster_scale_); 28 gfx::Size pixel_size = gfx::ScaleToCeiledSize(paint_size_, raster_scale_);
24 SkImageInfo info = SkImageInfo::MakeN32( 29 SkImageInfo info = SkImageInfo::MakeN32(
25 pixel_size.width(), pixel_size.height(), kPremul_SkAlphaType); 30 pixel_size.width(), pixel_size.height(), kPremul_SkAlphaType);
26 if (!output_->tryAllocPixels(info)) 31 if (!output_->tryAllocPixels(info))
27 return; 32 return;
28 33
29 SkCanvas canvas(*output_); 34 SkCanvas canvas(*output_);
30 canvas.clear(clear_color_); 35 canvas.clear(clear_color_);
31 36
32 canvas.scale(raster_scale_, raster_scale_); 37 canvas.scale(raster_scale_, raster_scale_);
33 38
34 list_->Finalize(); 39 list_->Finalize();
35 list_->Raster(&canvas, nullptr); 40 list_->Raster(&canvas, nullptr);
36 } 41 }
37 42
38 } // namespace ui 43 } // namespace ui
OLDNEW
« no previous file with comments | « ui/compositor/BUILD.gn ('k') | ui/compositor/compositor.cc » ('j') | ui/compositor/compositor.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698