aboutsummaryrefslogtreecommitdiffstats
path: root/src/colorramp.c
diff options
context:
space:
mode:
authorJon Lund Steffensen <jonlst@gmail.com>2013-10-21 15:26:47 -0400
committerJon Lund Steffensen <jonlst@gmail.com>2013-10-21 15:29:18 -0400
commit95d8a3f7600073b4abe869078cf3db1d8497c60a (patch)
tree12ee842fcf733f8eb3978280e24c44226d470183 /src/colorramp.c
parentFix slight wobble in temperature caused by float. (diff)
downloadredshift-ng-95d8a3f7600073b4abe869078cf3db1d8497c60a.tar.gz
redshift-ng-95d8a3f7600073b4abe869078cf3db1d8497c60a.tar.bz2
redshift-ng-95d8a3f7600073b4abe869078cf3db1d8497c60a.tar.xz
colorramp: Fix slight flicker caused by improper scaling of gamma ramp values
Values generated by colorramp_fill() will be a maximum of i * 256 - 1, due to the use of UINT16_MAX. Simplest fix ought to be using (UINT16_MAX+1), which is safe, as the maximum value (255 * 256) still fits in a uint16. (Thanks to Sean Hildebrand)
Diffstat (limited to 'src/colorramp.c')
-rw-r--r--src/colorramp.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/src/colorramp.c b/src/colorramp.c
index ed399f8..4d32d7e 100644
--- a/src/colorramp.c
+++ b/src/colorramp.c
@@ -139,10 +139,10 @@ colorramp_fill(uint16_t *gamma_r, uint16_t *gamma_g, uint16_t *gamma_b,
for (int i = 0; i < size; i++) {
gamma_r[i] = pow((float)i/size, 1.0/gamma[0]) *
- UINT16_MAX * brightness * white_point[0];
+ (UINT16_MAX+1) * brightness * white_point[0];
gamma_g[i] = pow((float)i/size, 1.0/gamma[1]) *
- UINT16_MAX * brightness * white_point[1];
+ (UINT16_MAX+1) * brightness * white_point[1];
gamma_b[i] = pow((float)i/size, 1.0/gamma[2]) *
- UINT16_MAX * brightness * white_point[2];
+ (UINT16_MAX+1) * brightness * white_point[2];
}
}