Index: include/core/SkFixed.h |
diff --git a/include/core/SkFixed.h b/include/core/SkFixed.h |
index f3326618433dbaa060f5f950ea85d101489e27da..1bb13f6fc2232ec36ea65dd382cc668652d2bdc3 100644 |
--- a/include/core/SkFixed.h |
+++ b/include/core/SkFixed.h |
@@ -150,4 +150,17 @@ typedef int64_t SkFixed3232; // 32.32 |
#define SkScalarToFixed3232(x) SkFloatToFixed3232(x) |
+/////////////////////////////////////////////////////////////////////////////// |
+ |
+// 64bits wide, with a 16bit bias. Useful when accumulating lots of 16.16 so |
+// we don't overflow along the way |
+typedef int64_t Sk48Dot16; |
mtklein
2015/03/05 21:00:03
Let's harmonize the names of SkFixed3232 and Sk48D
bungeman-skia
2015/03/05 21:17:56
As seen here, I pulled Sk48Dot16 out of SkPaint be
|
+ |
+static inline float Sk48Dot16ToScalar(Sk48Dot16 x) { |
+ return (float) (x * 1.5258789e-5); // x * (1 / 65536.0f) |
+} |
+#define SkFloatTo48Dot16(x) ((Sk48Dot16)((x) * SK_Fixed1)) |
reed1
2015/03/09 16:33:56
I know the value is correct, but it might read cle
bungeman-skia
2015/03/09 17:49:12
Made things line up in a more sane way.
|
+ |
+#define SkScalarTo48Dot16(x) SkFloatTo48Dot16(x) |
+ |
#endif |