Updating trunk VERSION from 2139.0 to 2140.0
[chromium-blink-merge.git] / ui / gfx / image / image_skia_rep.h
blob47f6713acf5d0a87fddd5020badd1c05c9ad783c
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/gfx_export.h"
10 #include "ui/gfx/size.h"
12 namespace gfx {
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 {
18 public:
19 // Create null bitmap.
20 ImageSkiaRep();
21 ~ImageSkiaRep();
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.
32 // Adds ref to |src|.
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.
39 int GetWidth() const;
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.
55 void SetScaled();
57 // Returns backing bitmap.
58 const SkBitmap& sk_bitmap() const { return bitmap_; }
60 private:
61 friend class ImageSkia;
62 SkBitmap& mutable_sk_bitmap() { return bitmap_; }
64 SkBitmap bitmap_;
66 float scale_;
69 } // namespace gfx
71 #endif // UI_GFX_IMAGE_IMAGE_SKIA_REP_H_