| /* |
| * Copyright 2014 Google Inc. |
| * |
| * Use of this source code is governed by a BSD-style license that can be |
| * found in the LICENSE file. |
| */ |
| |
| #include "SkMatrix.h" |
| #include "SkMatrix22.h" |
| #include "SkPoint.h" |
| #include "SkScalar.h" |
| |
| void SkComputeGivensRotation(const SkVector& h, SkMatrix* G) { |
| const SkScalar& a = h.fX; |
| const SkScalar& b = h.fY; |
| SkScalar c, s; |
| if (0 == b) { |
| c = SkScalarCopySign(SK_Scalar1, a); |
| s = 0; |
| //r = SkScalarAbs(a); |
| } else if (0 == a) { |
| c = 0; |
| s = -SkScalarCopySign(SK_Scalar1, b); |
| //r = SkScalarAbs(b); |
| } else if (SkScalarAbs(b) > SkScalarAbs(a)) { |
| SkScalar t = a / b; |
| SkScalar u = SkScalarCopySign(SkScalarSqrt(SK_Scalar1 + t*t), b); |
| s = -SK_Scalar1 / u; |
| c = -s * t; |
| //r = b * u; |
| } else { |
| SkScalar t = b / a; |
| SkScalar u = SkScalarCopySign(SkScalarSqrt(SK_Scalar1 + t*t), a); |
| c = SK_Scalar1 / u; |
| s = -c * t; |
| //r = a * u; |
| } |
| |
| G->setSinCos(s, c); |
| } |