// Copyright 2013 The Flutter Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #include #include "fml/logging.h" #include "gtest/gtest.h" #include "flutter/impeller/geometry/trig.h" namespace impeller { namespace testing { TEST(TrigTest, TrigAngles) { { Trig trig(Degrees(0.0)); EXPECT_EQ(trig.cos, 1.0); EXPECT_EQ(trig.sin, 0.0); } { Trig trig(Radians(0.0)); EXPECT_EQ(trig.cos, 1.0); EXPECT_EQ(trig.sin, 0.0); } { Trig trig(Degrees(30.0)); EXPECT_NEAR(trig.cos, sqrt(0.75), kEhCloseEnough); EXPECT_NEAR(trig.sin, 0.5, kEhCloseEnough); } { Trig trig(Radians(kPi / 6.0)); EXPECT_NEAR(trig.cos, sqrt(0.75), kEhCloseEnough); EXPECT_NEAR(trig.sin, 0.5, kEhCloseEnough); } { Trig trig(Degrees(60.0)); EXPECT_NEAR(trig.cos, 0.5, kEhCloseEnough); EXPECT_NEAR(trig.sin, sqrt(0.75), kEhCloseEnough); } { Trig trig(Radians(kPi / 3.0)); EXPECT_NEAR(trig.cos, 0.5, kEhCloseEnough); EXPECT_NEAR(trig.sin, sqrt(0.75), kEhCloseEnough); } { Trig trig(Degrees(90.0)); EXPECT_NEAR(trig.cos, 0.0, kEhCloseEnough); EXPECT_NEAR(trig.sin, 1.0, kEhCloseEnough); } { Trig trig(Radians(kPi / 2.0)); EXPECT_NEAR(trig.cos, 0.0, kEhCloseEnough); EXPECT_NEAR(trig.sin, 1.0, kEhCloseEnough); } } TEST(TrigTest, MultiplyByScalarRadius) { for (int i = 0; i <= 360; i++) { for (int i = 1; i <= 10; i++) { Scalar radius = i * 5.0f; EXPECT_EQ(Trig(Degrees(i)) * radius, Point(radius * std::cos(i * kPi / 180), radius * std::sin(i * kPi / 180))) << "at " << i << " degrees and radius " << radius; } } } } // namespace testing } // namespace impeller