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

Side by Side Diff: ui/gfx/canvas.cc

Issue 2615493003: use SkSurface behind gfx::Canvas (Closed)
Patch Set: anon namespace 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
« no previous file with comments | « ui/gfx/canvas.h ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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 "ui/gfx/canvas.h" 5 #include "ui/gfx/canvas.h"
6 6
7 #include <cmath> 7 #include <cmath>
8 #include <limits> 8 #include <limits>
9 9
10 #include "base/i18n/rtl.h" 10 #include "base/i18n/rtl.h"
11 #include "base/logging.h" 11 #include "base/logging.h"
12 #include "third_party/skia/include/core/SkBitmap.h" 12 #include "third_party/skia/include/core/SkBitmap.h"
13 #include "third_party/skia/include/core/SkPath.h" 13 #include "third_party/skia/include/core/SkPath.h"
14 #include "third_party/skia/include/core/SkRefCnt.h" 14 #include "third_party/skia/include/core/SkRefCnt.h"
15 #include "third_party/skia/include/core/SkSurface.h"
15 #include "third_party/skia/include/effects/SkGradientShader.h" 16 #include "third_party/skia/include/effects/SkGradientShader.h"
16 #include "ui/gfx/font_list.h" 17 #include "ui/gfx/font_list.h"
17 #include "ui/gfx/geometry/insets_f.h" 18 #include "ui/gfx/geometry/insets_f.h"
18 #include "ui/gfx/geometry/rect.h" 19 #include "ui/gfx/geometry/rect.h"
19 #include "ui/gfx/geometry/rect_conversions.h" 20 #include "ui/gfx/geometry/rect_conversions.h"
20 #include "ui/gfx/geometry/rect_f.h" 21 #include "ui/gfx/geometry/rect_f.h"
21 #include "ui/gfx/geometry/safe_integer_conversions.h" 22 #include "ui/gfx/geometry/safe_integer_conversions.h"
22 #include "ui/gfx/geometry/size_conversions.h" 23 #include "ui/gfx/geometry/size_conversions.h"
23 #include "ui/gfx/scoped_canvas.h" 24 #include "ui/gfx/scoped_canvas.h"
24 #include "ui/gfx/skia_util.h" 25 #include "ui/gfx/skia_util.h"
25 #include "ui/gfx/transform.h" 26 #include "ui/gfx/transform.h"
26 27
27 namespace gfx { 28 namespace gfx {
28 29
30 namespace {
Alexei Svitkine (slow) 2017/01/06 16:02:51 Nit: Add empty lines within the namespace.
reed1 2017/01/06 16:10:11 Done.
31 sk_sp<SkSurface> CreateSurface(const Size& size, bool is_opaque) {
32 // SkSurface cannot be zero-sized, but clients of Canvas sometimes request
33 // that (and then later resize).
34 int width = std::max(size.width(), 1);
35 int height = std::max(size.height(), 1);
36 SkAlphaType alpha = is_opaque ? kOpaque_SkAlphaType : kPremul_SkAlphaType;
37 SkImageInfo info = SkImageInfo::MakeN32(width, height, alpha);
38 return SkSurface::MakeRaster(info);
39 }
40 } // namespace
41
29 Canvas::Canvas(const Size& size, float image_scale, bool is_opaque) 42 Canvas::Canvas(const Size& size, float image_scale, bool is_opaque)
30 : image_scale_(image_scale) { 43 : image_scale_(image_scale) {
31 Size pixel_size = ScaleToCeiledSize(size, image_scale); 44 Size pixel_size = ScaleToCeiledSize(size, image_scale);
32 canvas_owner_ = skia::CreatePlatformCanvas(pixel_size.width(), 45 surface_ = CreateSurface(pixel_size, is_opaque);
33 pixel_size.height(), is_opaque); 46 canvas_ = surface_->getCanvas();
34 canvas_ = canvas_owner_.get();
35 47
36 #if !defined(USE_CAIRO) 48 #if !defined(USE_CAIRO)
37 // skia::PlatformCanvas instances are initialized to 0 by Cairo, but 49 // skia::PlatformCanvas instances are initialized to 0 by Cairo, but
38 // uninitialized on other platforms. 50 // uninitialized on other platforms.
39 if (!is_opaque) 51 if (!is_opaque)
40 canvas_->clear(SkColorSetARGB(0, 0, 0, 0)); 52 canvas_->clear(SkColorSetARGB(0, 0, 0, 0));
41 #endif 53 #endif
42 54
43 SkScalar scale_scalar = SkFloatToScalar(image_scale); 55 SkScalar scale_scalar = SkFloatToScalar(image_scale);
44 canvas_->scale(scale_scalar, scale_scalar); 56 canvas_->scale(scale_scalar, scale_scalar);
45 } 57 }
46 58
47 Canvas::Canvas() 59 Canvas::Canvas()
48 : image_scale_(1.f), 60 : image_scale_(1.f),
49 canvas_owner_(skia::CreatePlatformCanvas(0, 0, false)), 61 surface_(CreateSurface({0, 0}, false)),
50 canvas_(canvas_owner_.get()) {} 62 canvas_(surface_->getCanvas()) {}
51 63
52 Canvas::Canvas(SkCanvas* canvas, float image_scale) 64 Canvas::Canvas(SkCanvas* canvas, float image_scale)
53 : image_scale_(image_scale), canvas_(canvas) { 65 : image_scale_(image_scale), canvas_(canvas) {
54 DCHECK(canvas_); 66 DCHECK(canvas_);
55 } 67 }
56 68
57 Canvas::~Canvas() { 69 Canvas::~Canvas() {
58 } 70 }
59 71
60 void Canvas::RecreateBackingCanvas(const Size& size, 72 void Canvas::RecreateBackingCanvas(const Size& size,
61 float image_scale, 73 float image_scale,
62 bool is_opaque) { 74 bool is_opaque) {
63 image_scale_ = image_scale; 75 image_scale_ = image_scale;
64 Size pixel_size = ScaleToFlooredSize(size, image_scale); 76 Size pixel_size = ScaleToFlooredSize(size, image_scale);
65 canvas_owner_ = skia::CreatePlatformCanvas(pixel_size.width(), 77 surface_ = CreateSurface(pixel_size, is_opaque);
66 pixel_size.height(), is_opaque); 78 canvas_ = surface_->getCanvas();
67 canvas_ = canvas_owner_.get();
68 79
69 SkScalar scale_scalar = SkFloatToScalar(image_scale); 80 SkScalar scale_scalar = SkFloatToScalar(image_scale);
70 canvas_->scale(scale_scalar, scale_scalar); 81 canvas_->scale(scale_scalar, scale_scalar);
71 } 82 }
72 83
73 // static 84 // static
74 void Canvas::SizeStringInt(const base::string16& text, 85 void Canvas::SizeStringInt(const base::string16& text,
75 const FontList& font_list, 86 const FontList& font_list,
76 int* width, 87 int* width,
77 int* height, 88 int* height,
(...skipping 510 matching lines...) Expand 10 before | Expand all | Expand 10 after
588 p.setFilterQuality(filter ? kLow_SkFilterQuality : kNone_SkFilterQuality); 599 p.setFilterQuality(filter ? kLow_SkFilterQuality : kNone_SkFilterQuality);
589 p.setShader(CreateImageRepShaderForScale( 600 p.setShader(CreateImageRepShaderForScale(
590 image_rep, SkShader::kRepeat_TileMode, shader_scale, 601 image_rep, SkShader::kRepeat_TileMode, shader_scale,
591 remove_image_scale ? image_rep.scale() : 1.f)); 602 remove_image_scale ? image_rep.scale() : 1.f));
592 603
593 // The rect will be filled by the bitmap. 604 // The rect will be filled by the bitmap.
594 canvas_->drawRect(dest_rect, p); 605 canvas_->drawRect(dest_rect, p);
595 } 606 }
596 607
597 } // namespace gfx 608 } // namespace gfx
OLDNEW
« no previous file with comments | « ui/gfx/canvas.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698