| OLD | NEW |
| 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" |
| (...skipping 10 matching lines...) Expand all Loading... |
| 21 #include "ui/gfx/geometry/size_conversions.h" | 21 #include "ui/gfx/geometry/size_conversions.h" |
| 22 #include "ui/gfx/scoped_canvas.h" | 22 #include "ui/gfx/scoped_canvas.h" |
| 23 #include "ui/gfx/skia_util.h" | 23 #include "ui/gfx/skia_util.h" |
| 24 #include "ui/gfx/transform.h" | 24 #include "ui/gfx/transform.h" |
| 25 | 25 |
| 26 namespace gfx { | 26 namespace gfx { |
| 27 | 27 |
| 28 Canvas::Canvas(const Size& size, float image_scale, bool is_opaque) | 28 Canvas::Canvas(const Size& size, float image_scale, bool is_opaque) |
| 29 : image_scale_(image_scale) { | 29 : image_scale_(image_scale) { |
| 30 Size pixel_size = ScaleToCeiledSize(size, image_scale); | 30 Size pixel_size = ScaleToCeiledSize(size, image_scale); |
| 31 canvas_owner_ = skia::CreatePlatformCanvas(pixel_size.width(), | 31 canvas_ = sk_sp<SkCanvas>(skia::CreatePlatformCanvas(pixel_size.width(), |
| 32 pixel_size.height(), is_opaque); | 32 pixel_size.height(), |
| 33 canvas_ = canvas_owner_.get(); | 33 is_opaque)); |
| 34 | |
| 35 #if !defined(USE_CAIRO) | 34 #if !defined(USE_CAIRO) |
| 36 // skia::PlatformCanvas instances are initialized to 0 by Cairo, but | 35 // skia::PlatformCanvas instances are initialized to 0 by Cairo, but |
| 37 // uninitialized on other platforms. | 36 // uninitialized on other platforms. |
| 38 if (!is_opaque) | 37 if (!is_opaque) |
| 39 canvas_->clear(SkColorSetARGB(0, 0, 0, 0)); | 38 canvas_->clear(SkColorSetARGB(0, 0, 0, 0)); |
| 40 #endif | 39 #endif |
| 41 | 40 |
| 42 SkScalar scale_scalar = SkFloatToScalar(image_scale); | 41 SkScalar scale_scalar = SkFloatToScalar(image_scale); |
| 43 canvas_->scale(scale_scalar, scale_scalar); | 42 canvas_->scale(scale_scalar, scale_scalar); |
| 44 } | 43 } |
| 45 | 44 |
| 46 Canvas::Canvas() | 45 Canvas::Canvas() |
| 47 : image_scale_(1.f), | 46 : image_scale_(1.f), |
| 48 canvas_owner_(skia::CreatePlatformCanvas(0, 0, false)), | 47 canvas_(sk_sp<SkCanvas>(skia::CreatePlatformCanvas(0, 0, false))) {} |
| 49 canvas_(canvas_owner_.get()) {} | |
| 50 | 48 |
| 51 Canvas::Canvas(SkCanvas* canvas, float image_scale) | 49 Canvas::Canvas(sk_sp<SkCanvas> canvas, float image_scale) |
| 52 : image_scale_(image_scale), canvas_(canvas) { | 50 : image_scale_(image_scale), canvas_(std::move(canvas)) { |
| 53 DCHECK(canvas_); | 51 DCHECK(canvas_); |
| 54 } | 52 } |
| 55 | 53 |
| 56 Canvas::~Canvas() { | 54 Canvas::~Canvas() { |
| 57 } | 55 } |
| 58 | 56 |
| 59 void Canvas::RecreateBackingCanvas(const Size& size, | 57 void Canvas::RecreateBackingCanvas(const Size& size, |
| 60 float image_scale, | 58 float image_scale, |
| 61 bool is_opaque) { | 59 bool is_opaque) { |
| 62 image_scale_ = image_scale; | 60 image_scale_ = image_scale; |
| 63 Size pixel_size = ScaleToFlooredSize(size, image_scale); | 61 Size pixel_size = ScaleToFlooredSize(size, image_scale); |
| 64 canvas_owner_ = skia::CreatePlatformCanvas(pixel_size.width(), | 62 canvas_ = sk_sp<SkCanvas>(skia::CreatePlatformCanvas(pixel_size.width(), |
| 65 pixel_size.height(), is_opaque); | 63 pixel_size.height(), |
| 66 canvas_ = canvas_owner_.get(); | 64 is_opaque)); |
| 67 | |
| 68 SkScalar scale_scalar = SkFloatToScalar(image_scale); | 65 SkScalar scale_scalar = SkFloatToScalar(image_scale); |
| 69 canvas_->scale(scale_scalar, scale_scalar); | 66 canvas_->scale(scale_scalar, scale_scalar); |
| 70 } | 67 } |
| 71 | 68 |
| 72 // static | 69 // static |
| 73 void Canvas::SizeStringInt(const base::string16& text, | 70 void Canvas::SizeStringInt(const base::string16& text, |
| 74 const FontList& font_list, | 71 const FontList& font_list, |
| 75 int* width, | 72 int* width, |
| 76 int* height, | 73 int* height, |
| 77 int line_height, | 74 int line_height, |
| (...skipping 523 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 601 p.setFilterQuality(filter ? kLow_SkFilterQuality : kNone_SkFilterQuality); | 598 p.setFilterQuality(filter ? kLow_SkFilterQuality : kNone_SkFilterQuality); |
| 602 p.setShader(CreateImageRepShaderForScale( | 599 p.setShader(CreateImageRepShaderForScale( |
| 603 image_rep, SkShader::kRepeat_TileMode, shader_scale, | 600 image_rep, SkShader::kRepeat_TileMode, shader_scale, |
| 604 remove_image_scale ? image_rep.scale() : 1.f)); | 601 remove_image_scale ? image_rep.scale() : 1.f)); |
| 605 | 602 |
| 606 // The rect will be filled by the bitmap. | 603 // The rect will be filled by the bitmap. |
| 607 canvas_->drawRect(dest_rect, p); | 604 canvas_->drawRect(dest_rect, p); |
| 608 } | 605 } |
| 609 | 606 |
| 610 } // namespace gfx | 607 } // namespace gfx |
| OLD | NEW |