diff options
author | danakj@chromium.org <danakj@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-11-05 20:46:13 +0000 |
---|---|---|
committer | danakj@chromium.org <danakj@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-11-05 20:46:13 +0000 |
commit | c9c1ebe24790fb34fa9f0704b7963cea511c6f2a (patch) | |
tree | fdd43e025e44ae4d9515ebe03a3e4c54f7133d51 /cc/math_util.h | |
parent | 6e3d7e7d274a3e8347e49910ab6f873f37e15989 (diff) | |
download | chromium_src-c9c1ebe24790fb34fa9f0704b7963cea511c6f2a.zip chromium_src-c9c1ebe24790fb34fa9f0704b7963cea511c6f2a.tar.gz chromium_src-c9c1ebe24790fb34fa9f0704b7963cea511c6f2a.tar.bz2 |
cc: Remove all remaining use of WebCore Rect/Point/Size types from the compositor.
This change removes all IntPoint/FloatRect/IntSize/etc from the compositor.
There remains an indirect dependency on these types through the
WebCore::Region class, which we wrap but need to replace. However, the wrapper
there hides the WebCore types inside it, so there are now no references to the
types from anywhere else in the compositor.
I went back and forth on how to deal with scroll "positions". The name suggested
that they should be Points, and that the deltas should be Vectors. However this
lent itself to super awkward math at times. In the end, it was much cleaner to
make all scroll "positions" into scroll "offsets" and represent everything as
Vectors.
Covered by existing tests; no change in behaviour.
R=enne
BUG=147395
Relanding: https://codereview.chromium.org/11367080/
Review URL: https://codereview.chromium.org/11366089
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@166027 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'cc/math_util.h')
-rw-r--r-- | cc/math_util.h | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/cc/math_util.h b/cc/math_util.h index 7d22c6c..1caf659 100644 --- a/cc/math_util.h +++ b/cc/math_util.h @@ -18,12 +18,11 @@ namespace gfx { class QuadF; class Rect; class RectF; +class Vector2dF; } namespace cc { -class FloatSize; - struct HomogeneousCoordinate { HomogeneousCoordinate(double newX, double newY, double newZ, double newW) : x(newX) @@ -104,10 +103,10 @@ public: // Returns the smallest angle between the given two vectors in degrees. Neither vector is // assumed to be normalized. - static float smallestAngleBetweenVectors(const FloatSize&, const FloatSize&); + static float smallestAngleBetweenVectors(gfx::Vector2dF, gfx::Vector2dF); // Projects the |source| vector onto |destination|. Neither vector is assumed to be normalized. - static FloatSize projectVector(const FloatSize& source, const FloatSize& destination); + static gfx::Vector2dF projectVector(gfx::Vector2dF source, gfx::Vector2dF destination); }; } // namespace cc |