Upstream version 11.40.277.0
[platform/framework/web/crosswalk.git] / src / ui / gfx / image / image_skia_rep.h
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.
4
5 #ifndef UI_GFX_IMAGE_IMAGE_SKIA_REP_H_
6 #define UI_GFX_IMAGE_IMAGE_SKIA_REP_H_
7
8 #include "third_party/skia/include/core/SkBitmap.h"
9 #include "ui/gfx/gfx_export.h"
10 #include "ui/gfx/size.h"
11
12 namespace gfx {
13
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();
22
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);
30
31   // Creates a bitmap with given scale.
32   // Adds ref to |src|.
33   ImageSkiaRep(const SkBitmap& src, float scale);
34
35   // Returns true if the backing bitmap is null.
36   bool is_null() const { return bitmap_.isNull(); }
37
38   // Get width and height of bitmap in DIP.
39   int GetWidth() const;
40   int GetHeight() const;
41
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());
47   }
48
49   // Retrieves the scale that the bitmap will be painted at.
50   float scale() const { return unscaled() ? 1.0f : scale_; }
51
52   bool unscaled() const { return scale_ == 0.0f; }
53
54   // Mark the image to be used as scaled image.
55   void SetScaled();
56
57   // Returns backing bitmap.
58   const SkBitmap& sk_bitmap() const { return bitmap_; }
59
60  private:
61   friend class ImageSkia;
62   SkBitmap& mutable_sk_bitmap() { return bitmap_; }
63
64   SkBitmap bitmap_;
65
66   float scale_;
67 };
68
69 }  // namespace gfx
70
71 #endif  // UI_GFX_IMAGE_IMAGE_SKIA_REP_H_