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
3 // found in the LICENSE file.
5 #ifndef UI_GFX_IMAGE_IMAGE_SKIA_REP_H_
6 #define UI_GFX_IMAGE_IMAGE_SKIA_REP_H_
8 #include "third_party/skia/include/core/SkBitmap.h"
9 #include "ui/gfx/geometry/size.h"
10 #include "ui/gfx/gfx_export.h"
14 // An ImageSkiaRep represents a bitmap and the scale factor it is intended for.
15 // 0.0f scale is used to indicate that this ImageSkiaRep is used for unscaled
16 // image (the image that only returns 1.0f scale image).
17 class GFX_EXPORT ImageSkiaRep
{
19 // Create null bitmap.
23 // Note: This is for testing purpose only.
24 // Creates a bitmap with kARGB_8888_Config config with given |size| in DIP.
25 // This allocates pixels in the bitmap. It is guaranteed that the data in the
26 // bitmap are initialized but the actual values are undefined.
27 // Specifying 0 scale means the image is for unscaled image. (unscaled()
28 // returns truen, and scale() returns 1.0f;)
29 ImageSkiaRep(const gfx::Size
& size
, float scale
);
31 // Creates a bitmap with given scale.
33 ImageSkiaRep(const SkBitmap
& src
, float scale
);
35 // Returns true if the backing bitmap is null.
36 bool is_null() const { return bitmap_
.isNull(); }
38 // Get width and height of bitmap in DIP.
40 int GetHeight() const;
42 // Get width and height of bitmap in pixels.
43 int pixel_width() const { return bitmap_
.width(); }
44 int pixel_height() const { return bitmap_
.height(); }
45 Size
pixel_size() const {
46 return Size(pixel_width(), pixel_height());
49 // Retrieves the scale that the bitmap will be painted at.
50 float scale() const { return unscaled() ? 1.0f
: scale_
; }
52 bool unscaled() const { return scale_
== 0.0f
; }
54 // Mark the image to be used as scaled image.
57 // Returns backing bitmap.
58 const SkBitmap
& sk_bitmap() const { return bitmap_
; }
68 #endif // UI_GFX_IMAGE_IMAGE_SKIA_REP_H_