Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1071)

Side by Side Diff: ui/gfx/geometry/cubic_bezier.h

Issue 1846733003: UI GFX Geometry: Make UnitBezier a wrapper for gfx::CubicBezier (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Add one more TODO for Range. Created 4 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « third_party/WebKit/Source/platform/blink_platform.gypi ('k') | ui/gfx/geometry/cubic_bezier.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef UI_GFX_GEOMETRY_CUBIC_BEZIER_H_ 5 #ifndef UI_GFX_GEOMETRY_CUBIC_BEZIER_H_
6 #define UI_GFX_GEOMETRY_CUBIC_BEZIER_H_ 6 #define UI_GFX_GEOMETRY_CUBIC_BEZIER_H_
7 7
8 #include "base/macros.h" 8 #include "base/macros.h"
9 #include "ui/gfx/gfx_export.h" 9 #include "ui/gfx/gfx_export.h"
10 10
11 namespace gfx { 11 namespace gfx {
12 12
13 class GFX_EXPORT CubicBezier { 13 class GFX_EXPORT CubicBezier {
14 public: 14 public:
15 CubicBezier(double x1, double y1, double x2, double y2); 15 CubicBezier(double p1x, double p1y, double p2x, double p2y);
16 ~CubicBezier();
17 16
18 // Returns an approximation of y at the given x. 17 double SampleCurveX(double t) const {
18 // `ax t^3 + bx t^2 + cx t' expanded using Horner's rule.
19 return ((ax_ * t + bx_) * t + cx_) * t;
20 }
21
22 double SampleCurveY(double t) const {
23 return ((ay_ * t + by_) * t + cy_) * t;
24 }
25
26 double SampleCurveDerivativeX(double t) const {
27 return (3.0 * ax_ * t + 2.0 * bx_) * t + cx_;
28 }
29
30 double SampleCurveDerivativeY(double t) const {
31 return (3.0 * ay_ * t + 2.0 * by_) * t + cy_;
32 }
33
34 // Given an x value, find a parametric value it came from.
35 // x must be in [0, 1] range. Doesn't use gradients.
36 double SolveCurveX(double x, double epsilon) const;
37
38 // Evaluates y at the given x with default epsilon.
19 double Solve(double x) const; 39 double Solve(double x) const;
40 // Evaluates y at the given x. The epsilon parameter provides a hint as to the
41 // required accuracy and is not guaranteed. Uses gradients if x is
42 // out of [0, 1] range.
43 double SolveWithEpsilon(double x, double epsilon) const {
44 if (x < 0.0)
45 return 0.0 + start_gradient_ * x;
46 if (x > 1.0)
47 return 1.0 + end_gradient_ * (x - 1.0);
48 return SampleCurveY(SolveCurveX(x, epsilon));
49 }
20 50
51 // Returns an approximation of dy/dx at the given x with default epsilon.
52 double Slope(double x) const;
21 // Returns an approximation of dy/dx at the given x. 53 // Returns an approximation of dy/dx at the given x.
22 double Slope(double x) const; 54 // Clamps x to range [0, 1].
55 double SlopeWithEpsilon(double x, double epsilon) const;
23 56
24 // Sets |min| and |max| to the bezier's minimum and maximium y values in the 57 // Sets |min| and |max| to the bezier's minimum and maximium y values in the
25 // interval [0, 1]. 58 // interval [0, 1].
26 void Range(double* min, double* max) const; 59 // TODO(loyso): Implement this as two independent getters.
60 void Range(double* min, double* max) const {
61 *min = range_min_;
62 *max = range_max_;
63 }
27 64
28 private: 65 private:
29 void InitGradients(); 66 void InitCoefficients(double p1x, double p1y, double p2x, double p2y);
67 void InitGradients(double p1x, double p1y, double p2x, double p2y);
68 void InitRange(double p1y, double p2y);
30 69
31 double x1_; 70 double ax_;
32 double y1_; 71 double bx_;
33 double x2_; 72 double cx_;
34 double y2_; 73
74 double ay_;
75 double by_;
76 double cy_;
35 77
36 double start_gradient_; 78 double start_gradient_;
37 double end_gradient_; 79 double end_gradient_;
38 80
81 double range_min_;
82 double range_max_;
83
39 DISALLOW_ASSIGN(CubicBezier); 84 DISALLOW_ASSIGN(CubicBezier);
40 }; 85 };
41 86
42 } // namespace gfx 87 } // namespace gfx
43 88
44 #endif // UI_GFX_GEOMETRY_CUBIC_BEZIER_H_ 89 #endif // UI_GFX_GEOMETRY_CUBIC_BEZIER_H_
OLDNEW
« no previous file with comments | « third_party/WebKit/Source/platform/blink_platform.gypi ('k') | ui/gfx/geometry/cubic_bezier.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698