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_RECT_F_H_
6 #define UI_GFX_RECT_F_H_
10 #include "ui/gfx/point_f.h"
11 #include "ui/gfx/rect_base.h"
12 #include "ui/gfx/size_f.h"
13 #include "ui/gfx/vector2d_f.h"
19 // A floating version of gfx::Rect.
20 class GFX_EXPORT RectF
21 : public RectBase
<RectF
, PointF
, SizeF
, InsetsF
, Vector2dF
, float> {
24 : RectBase
<RectF
, PointF
, SizeF
, InsetsF
, Vector2dF
, float>
27 RectF(float width
, float height
)
28 : RectBase
<RectF
, PointF
, SizeF
, InsetsF
, Vector2dF
, float>
29 (SizeF(width
, height
)) {}
31 RectF(float x
, float y
, float width
, float height
)
32 : RectBase
<RectF
, PointF
, SizeF
, InsetsF
, Vector2dF
, float>
33 (PointF(x
, y
), SizeF(width
, height
)) {}
35 explicit RectF(const SizeF
& size
)
36 : RectBase
<RectF
, PointF
, SizeF
, InsetsF
, Vector2dF
, float>
39 RectF(const PointF
& origin
, const SizeF
& size
)
40 : RectBase
<RectF
, PointF
, SizeF
, InsetsF
, Vector2dF
, float>
45 // Scales the rectangle by |scale|.
46 void Scale(float scale
) {
50 void Scale(float x_scale
, float y_scale
) {
51 set_origin(ScalePoint(origin(), x_scale
, y_scale
));
52 set_size(ScaleSize(size(), x_scale
, y_scale
));
55 // This method reports if the RectF can be safely converted to an integer
56 // Rect. When it is false, some dimension of the RectF is outside the bounds
57 // of what an integer can represent, and converting it to a Rect will require
59 bool IsExpressibleAsRect() const;
61 std::string
ToString() const;
64 inline bool operator==(const RectF
& lhs
, const RectF
& rhs
) {
65 return lhs
.origin() == rhs
.origin() && lhs
.size() == rhs
.size();
68 inline bool operator!=(const RectF
& lhs
, const RectF
& rhs
) {
72 inline RectF
operator+(const RectF
& lhs
, const Vector2dF
& rhs
) {
73 return RectF(lhs
.x() + rhs
.x(), lhs
.y() + rhs
.y(),
74 lhs
.width(), lhs
.height());
77 inline RectF
operator-(const RectF
& lhs
, const Vector2dF
& rhs
) {
78 return RectF(lhs
.x() - rhs
.x(), lhs
.y() - rhs
.y(),
79 lhs
.width(), lhs
.height());
82 inline RectF
operator+(const Vector2dF
& lhs
, const RectF
& rhs
) {
86 GFX_EXPORT RectF
IntersectRects(const RectF
& a
, const RectF
& b
);
87 GFX_EXPORT RectF
UnionRects(const RectF
& a
, const RectF
& b
);
88 GFX_EXPORT RectF
SubtractRects(const RectF
& a
, const RectF
& b
);
90 inline RectF
ScaleRect(const RectF
& r
, float x_scale
, float y_scale
) {
91 return RectF(r
.x() * x_scale
, r
.y() * y_scale
,
92 r
.width() * x_scale
, r
.height() * y_scale
);
95 inline RectF
ScaleRect(const RectF
& r
, float scale
) {
96 return ScaleRect(r
, scale
, scale
);
99 // Constructs a rectangle with |p1| and |p2| as opposite corners.
101 // This could also be thought of as "the smallest rect that contains both
102 // points", except that we consider points on the right/bottom edges of the
103 // rect to be outside the rect. So technically one or both points will not be
104 // contained within the rect, because they will appear on one of these edges.
105 GFX_EXPORT RectF
BoundingRect(const PointF
& p1
, const PointF
& p2
);
107 #if !defined(COMPILER_MSVC)
108 extern template class RectBase
<RectF
, PointF
, SizeF
, InsetsF
, Vector2dF
, float>;
113 #endif // UI_GFX_RECT_F_H_