1edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project/*
2edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * Copyright (C) 2006 The Android Open Source Project
3edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project *
4edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License");
5edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * you may not use this file except in compliance with the License.
6edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * You may obtain a copy of the License at
7edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project *
8edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project *      http://www.apache.org/licenses/LICENSE-2.0
9edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project *
10edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * Unless required by applicable law or agreed to in writing, software
11edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS,
12edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * See the License for the specific language governing permissions and
14edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * limitations under the License.
15edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project */
16edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project
17edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project#ifndef ANDROID_UI_RECT
18edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project#define ANDROID_UI_RECT
19edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project
208683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian#include <utils/Flattenable.h>
21edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project#include <utils/TypeHelpers.h>
22edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project#include <ui/Point.h>
23edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project
249147d11a5f1d50496908bb1f49996e3ad23e19ccDianne Hackborn#include <android/rect.h>
259147d11a5f1d50496908bb1f49996e3ad23e19ccDianne Hackborn
26edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Projectnamespace android {
27edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project
288683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopianclass Rect : public ARect, public LightFlattenablePod<Rect>
29edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project{
30edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Projectpublic:
31000e95e7ebf1a60bbb7fda604b54092f45c87f89Mathias Agopian    typedef ARect::value_type value_type;
324b8160fdfd3281d1d66c0cae9bb9c647b4333491Mathias Agopian
33edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    // we don't provide copy-ctor and operator= on purpose
34edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    // because we want the compiler generated versions
35edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project
3635801cea5f301c0e1d7a93b15a8f73f98e6b1033Mathias Agopian    inline Rect() {
37edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    }
389147d11a5f1d50496908bb1f49996e3ad23e19ccDianne Hackborn    inline Rect(int32_t w, int32_t h) {
399147d11a5f1d50496908bb1f49996e3ad23e19ccDianne Hackborn        left = top = 0; right = w; bottom = h;
40edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    }
419147d11a5f1d50496908bb1f49996e3ad23e19ccDianne Hackborn    inline Rect(int32_t l, int32_t t, int32_t r, int32_t b) {
429147d11a5f1d50496908bb1f49996e3ad23e19ccDianne Hackborn        left = l; top = t; right = r; bottom = b;
43edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    }
449147d11a5f1d50496908bb1f49996e3ad23e19ccDianne Hackborn    inline Rect(const Point& lt, const Point& rb) {
459147d11a5f1d50496908bb1f49996e3ad23e19ccDianne Hackborn        left = lt.x; top = lt.y; right = rb.x; bottom = rb.y;
46edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    }
47edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project
48edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    void makeInvalid();
494b8160fdfd3281d1d66c0cae9bb9c647b4333491Mathias Agopian
504b8160fdfd3281d1d66c0cae9bb9c647b4333491Mathias Agopian    inline void clear() {
514b8160fdfd3281d1d66c0cae9bb9c647b4333491Mathias Agopian        left = top = right = bottom = 0;
524b8160fdfd3281d1d66c0cae9bb9c647b4333491Mathias Agopian    }
534b8160fdfd3281d1d66c0cae9bb9c647b4333491Mathias Agopian
54edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    // a valid rectangle has a non negative width and height
55edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    inline bool isValid() const {
56edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project        return (width()>=0) && (height()>=0);
57edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    }
58edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project
59edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    // an empty rect has a zero width or height, or is invalid
60edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    inline bool isEmpty() const {
61edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project        return (width()<=0) || (height()<=0);
62edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    }
63edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project
64edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    inline void set(const Rect& rhs) {
65edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project        operator = (rhs);
66edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    }
67edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project
68edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    // rectangle's width
69b82203a6601728a507bc3e7d5b2b042356004aaeMathias Agopian    inline int32_t getWidth() const {
70edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project        return right-left;
71edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    }
72edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project
73edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    // rectangle's height
74b82203a6601728a507bc3e7d5b2b042356004aaeMathias Agopian    inline int32_t getHeight() const {
75edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project        return bottom-top;
76edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    }
77edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project
78b82203a6601728a507bc3e7d5b2b042356004aaeMathias Agopian    inline Rect getBounds() const {
79b82203a6601728a507bc3e7d5b2b042356004aaeMathias Agopian        return Rect(right-left, bottom-top);
80b82203a6601728a507bc3e7d5b2b042356004aaeMathias Agopian    }
81b82203a6601728a507bc3e7d5b2b042356004aaeMathias Agopian
82b82203a6601728a507bc3e7d5b2b042356004aaeMathias Agopian    inline int32_t width() const { return getWidth(); }
83b82203a6601728a507bc3e7d5b2b042356004aaeMathias Agopian    inline int32_t height() const { return getHeight(); }
84b82203a6601728a507bc3e7d5b2b042356004aaeMathias Agopian
8535801cea5f301c0e1d7a93b15a8f73f98e6b1033Mathias Agopian    void setLeftTop(const Point& lt) {
8635801cea5f301c0e1d7a93b15a8f73f98e6b1033Mathias Agopian        left = lt.x;
8735801cea5f301c0e1d7a93b15a8f73f98e6b1033Mathias Agopian        top  = lt.y;
88edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    }
8935801cea5f301c0e1d7a93b15a8f73f98e6b1033Mathias Agopian
9035801cea5f301c0e1d7a93b15a8f73f98e6b1033Mathias Agopian    void setRightBottom(const Point& rb) {
9135801cea5f301c0e1d7a93b15a8f73f98e6b1033Mathias Agopian        right = rb.x;
9235801cea5f301c0e1d7a93b15a8f73f98e6b1033Mathias Agopian        bottom  = rb.y;
93edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    }
94edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project
95edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    // the following 4 functions return the 4 corners of the rect as Point
9635801cea5f301c0e1d7a93b15a8f73f98e6b1033Mathias Agopian    Point leftTop() const {
9735801cea5f301c0e1d7a93b15a8f73f98e6b1033Mathias Agopian        return Point(left, top);
98edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    }
9935801cea5f301c0e1d7a93b15a8f73f98e6b1033Mathias Agopian    Point rightBottom() const {
10035801cea5f301c0e1d7a93b15a8f73f98e6b1033Mathias Agopian        return Point(right, bottom);
101edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    }
102edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    Point rightTop() const {
103edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project        return Point(right, top);
104edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    }
105edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    Point leftBottom() const {
106edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project        return Point(left, bottom);
107edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    }
108edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project
109edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    // comparisons
110edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    inline bool operator == (const Rect& rhs) const {
111edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project        return (left == rhs.left) && (top == rhs.top) &&
112edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project               (right == rhs.right) && (bottom == rhs.bottom);
113edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    }
114edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project
115edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    inline bool operator != (const Rect& rhs) const {
116edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project        return !operator == (rhs);
117edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    }
118edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project
119edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    // operator < defines an order which allows to use rectangles in sorted
120edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    // vectors.
121edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    bool operator < (const Rect& rhs) const;
122edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project
123edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    Rect& offsetToOrigin() {
124edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project        right -= left;
125edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project        bottom -= top;
126edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project        left = top = 0;
127edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project        return *this;
128edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    }
129edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    Rect& offsetTo(const Point& p) {
130edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project        return offsetTo(p.x, p.y);
131edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    }
132edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    Rect& offsetBy(const Point& dp) {
133edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project        return offsetBy(dp.x, dp.y);
134edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    }
135edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    Rect& operator += (const Point& rhs) {
136edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project        return offsetBy(rhs.x, rhs.y);
137edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    }
138edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    Rect& operator -= (const Point& rhs) {
139edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project        return offsetBy(-rhs.x, -rhs.y);
140edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    }
14135801cea5f301c0e1d7a93b15a8f73f98e6b1033Mathias Agopian    const Rect operator + (const Point& rhs) const;
14235801cea5f301c0e1d7a93b15a8f73f98e6b1033Mathias Agopian    const Rect operator - (const Point& rhs) const;
143edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project
1449147d11a5f1d50496908bb1f49996e3ad23e19ccDianne Hackborn    void translate(int32_t dx, int32_t dy) { // legacy, don't use.
145edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project        offsetBy(dx, dy);
146edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    }
14759332804306c054082a39e9b004146bd03ae1d30Jamie Gennis
1489147d11a5f1d50496908bb1f49996e3ad23e19ccDianne Hackborn    Rect&   offsetTo(int32_t x, int32_t y);
1499147d11a5f1d50496908bb1f49996e3ad23e19ccDianne Hackborn    Rect&   offsetBy(int32_t x, int32_t y);
150edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project    bool    intersect(const Rect& with, Rect* result) const;
15159332804306c054082a39e9b004146bd03ae1d30Jamie Gennis
15259332804306c054082a39e9b004146bd03ae1d30Jamie Gennis    // Create a new Rect by transforming this one using a graphics HAL
15359332804306c054082a39e9b004146bd03ae1d30Jamie Gennis    // transform.  This rectangle is defined in a coordinate space starting at
15459332804306c054082a39e9b004146bd03ae1d30Jamie Gennis    // the origin and extending to (width, height).  If the transform includes
15559332804306c054082a39e9b004146bd03ae1d30Jamie Gennis    // a ROT90 then the output rectangle is defined in a space extending to
15659332804306c054082a39e9b004146bd03ae1d30Jamie Gennis    // (height, width).  Otherwise the output rectangle is in the same space as
15759332804306c054082a39e9b004146bd03ae1d30Jamie Gennis    // the input.
158f15a83f5814219c167f87cb8aaea622fc8493499Jamie Gennis    Rect transform(uint32_t xform, int32_t width, int32_t height) const;
159edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project};
160edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project
161edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source ProjectANDROID_BASIC_TYPES_TRAITS(Rect)
162edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project
163edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project}; // namespace android
164edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project
165edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project#endif // ANDROID_UI_RECT
166