blob: 1a7082bda660ae89ff28225d9905bf84977ccb7d [file] [log] [blame]
Chris Craike0bb87d2014-04-22 17:55:41 -07001/*
2 * Copyright (C) 2014 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16#ifndef MATHUTILS_H
17#define MATHUTILS_H
18
19namespace android {
20namespace uirenderer {
21
22class MathUtils {
23private:
24 static const float gNonZeroEpsilon = 0.001f;
25public:
26 /**
27 * Check for floats that are close enough to zero.
28 */
29 inline static bool isZero(float value) {
30 return (value >= -gNonZeroEpsilon) && (value <= gNonZeroEpsilon);
31 }
Chris Craikcc39e162014-04-25 18:34:11 -070032
33 inline static bool isPositive(float value) {
34 return value >= gNonZeroEpsilon;
35 }
John Reck315c3292014-05-09 19:21:04 -070036
37 inline static int min(int a, int b) {
38 return a < b ? a : b;
39 }
40
41 inline static float lerp(float v1, float v2, float t) {
42 return v1 + ((v2 - v1) * t);
43 }
Chris Craike0bb87d2014-04-22 17:55:41 -070044}; // class MathUtils
45
46} /* namespace uirenderer */
47} /* namespace android */
48
Chris Craike4aa95e2014-05-08 13:57:05 -070049#endif /* MATHUTILS_H */