summaryrefslogtreecommitdiffstats
path: root/chrome/views/painter.h
blob: e0e351904cfb67e51ca73e5d37ee44f2a8672fd4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
// Copyright (c) 2006-2008 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef CHROME_VIEWS_PAINTER_H__
#define CHROME_VIEWS_PAINTER_H__

#include <vector>

#include "base/basictypes.h"
#include "skia/include/SkColor.h"

class ChromeCanvas;
class SkBitmap;

namespace ChromeViews {

// Painter, as the name implies, is responsible for painting in a particular
// region. Think of Painter as a Border or Background that can be painted
// in any region of a View.
class Painter {
 public:
  // A convenience method for painting a Painter in a particular region.
  // This translates the canvas to x/y and paints the painter.
  static void PaintPainterAt(int x, int y, int w, int h,
                             ChromeCanvas* canvas, Painter* painter);

  // Creates a painter that draws a gradient between the two colors.
  static Painter* CreateHorizontalGradient(SkColor c1, SkColor c2);
  static Painter* CreateVerticalGradient(SkColor c1, SkColor c2);

  virtual ~Painter() {}

  // Paints the painter in the specified region.
  virtual void Paint(int w, int h, ChromeCanvas* canvas) = 0;
};

// ImagePainter paints 8 (or 9) images into a box. The four corner
// images are drawn at the size of the image, the top/left/bottom/right
// images are tiled to fit the area, and the center (if rendered) is
// stretched.
class ImagePainter : public Painter {
 public:
  enum BorderElements {
    BORDER_TOP_LEFT = 0,
    BORDER_TOP,
    BORDER_TOP_RIGHT,
    BORDER_RIGHT,
    BORDER_BOTTOM_RIGHT,
    BORDER_BOTTOM,
    BORDER_BOTTOM_LEFT,
    BORDER_LEFT,
    BORDER_CENTER
  };

  // Constructs a new ImagePainter loading the specified image names.
  // The images must be in the order defined by the BorderElements.
  // If draw_center is false, there must be 8 image names, if draw_center
  // is true, there must be 9 image names with the last giving the name
  // of the center image.
  ImagePainter(const int image_resource_names[],
               bool draw_center);

  virtual ~ImagePainter() {}

  // Paints the images.
  virtual void Paint(int w, int h, ChromeCanvas* canvas);

  // Returns the specified image. The returned image should NOT be deleted.
  SkBitmap* GetImage(BorderElements element) {
    return images_[element];
  }

 private:
  bool tile_;
  bool draw_center_;
  bool tile_center_;
  // NOTE: the images are owned by ResourceBundle. Don't free them.
  std::vector<SkBitmap*> images_;

  DISALLOW_EVIL_CONSTRUCTORS(ImagePainter);
};

// HorizontalPainter paints 3 images into a box: left, center and right. The left
// and right images are drawn to size at the left/right edges of the region.
// The center is tiled in the remaining space. All images must have the same
// height.
class HorizontalPainter : public Painter {
 public:
  // Constructs a new HorizontalPainter loading the specified image names.
  // The images must be in the order left, right and center.
  explicit HorizontalPainter(const int image_resource_names[]);

  virtual ~HorizontalPainter() {}

  // Paints the images.
  virtual void Paint(int w, int h, ChromeCanvas* canvas);

  // Height of the images.
  int height() const { return height_; }

 private:
  // The image chunks.
  enum BorderElements {
    LEFT,
    CENTER,
    RIGHT
  };

  // The height.
  int height_;
  // NOTE: the images are owned by ResourceBundle. Don't free them.
  SkBitmap* images_[3];

  DISALLOW_EVIL_CONSTRUCTORS(HorizontalPainter);
};

}

#endif  // CHROME_VIEWS_PAINTER_H__