1*c8dee2aaSAndroid Build Coastguard Worker /* 2*c8dee2aaSAndroid Build Coastguard Worker * Copyright 2014 Google Inc. 3*c8dee2aaSAndroid Build Coastguard Worker * 4*c8dee2aaSAndroid Build Coastguard Worker * Use of this source code is governed by a BSD-style license that can be 5*c8dee2aaSAndroid Build Coastguard Worker * found in the LICENSE file. 6*c8dee2aaSAndroid Build Coastguard Worker */ 7*c8dee2aaSAndroid Build Coastguard Worker 8*c8dee2aaSAndroid Build Coastguard Worker #include "src/utils/SkMatrix22.h" 9*c8dee2aaSAndroid Build Coastguard Worker 10*c8dee2aaSAndroid Build Coastguard Worker #include "include/core/SkMatrix.h" 11*c8dee2aaSAndroid Build Coastguard Worker #include "include/core/SkPoint.h" 12*c8dee2aaSAndroid Build Coastguard Worker #include "include/core/SkScalar.h" 13*c8dee2aaSAndroid Build Coastguard Worker SkComputeGivensRotation(const SkVector & h,SkMatrix * G)14*c8dee2aaSAndroid Build Coastguard Workervoid SkComputeGivensRotation(const SkVector& h, SkMatrix* G) { 15*c8dee2aaSAndroid Build Coastguard Worker const SkScalar& a = h.fX; 16*c8dee2aaSAndroid Build Coastguard Worker const SkScalar& b = h.fY; 17*c8dee2aaSAndroid Build Coastguard Worker SkScalar c, s; 18*c8dee2aaSAndroid Build Coastguard Worker if (0 == b) { 19*c8dee2aaSAndroid Build Coastguard Worker c = SkScalarCopySign(SK_Scalar1, a); 20*c8dee2aaSAndroid Build Coastguard Worker s = 0; 21*c8dee2aaSAndroid Build Coastguard Worker //r = SkScalarAbs(a); 22*c8dee2aaSAndroid Build Coastguard Worker } else if (0 == a) { 23*c8dee2aaSAndroid Build Coastguard Worker c = 0; 24*c8dee2aaSAndroid Build Coastguard Worker s = -SkScalarCopySign(SK_Scalar1, b); 25*c8dee2aaSAndroid Build Coastguard Worker //r = SkScalarAbs(b); 26*c8dee2aaSAndroid Build Coastguard Worker } else if (SkScalarAbs(b) > SkScalarAbs(a)) { 27*c8dee2aaSAndroid Build Coastguard Worker SkScalar t = a / b; 28*c8dee2aaSAndroid Build Coastguard Worker SkScalar u = SkScalarCopySign(SkScalarSqrt(SK_Scalar1 + t*t), b); 29*c8dee2aaSAndroid Build Coastguard Worker s = -SK_Scalar1 / u; 30*c8dee2aaSAndroid Build Coastguard Worker c = -s * t; 31*c8dee2aaSAndroid Build Coastguard Worker //r = b * u; 32*c8dee2aaSAndroid Build Coastguard Worker } else { 33*c8dee2aaSAndroid Build Coastguard Worker SkScalar t = b / a; 34*c8dee2aaSAndroid Build Coastguard Worker SkScalar u = SkScalarCopySign(SkScalarSqrt(SK_Scalar1 + t*t), a); 35*c8dee2aaSAndroid Build Coastguard Worker c = SK_Scalar1 / u; 36*c8dee2aaSAndroid Build Coastguard Worker s = -c * t; 37*c8dee2aaSAndroid Build Coastguard Worker //r = a * u; 38*c8dee2aaSAndroid Build Coastguard Worker } 39*c8dee2aaSAndroid Build Coastguard Worker 40*c8dee2aaSAndroid Build Coastguard Worker G->setSinCos(s, c); 41*c8dee2aaSAndroid Build Coastguard Worker } 42