summaryrefslogtreecommitdiff
path: root/src/engine/blend_palette.c
diff options
context:
space:
mode:
authorcamthesaxman <cameronghall@cox.net>2017-10-01 11:17:34 -0500
committercamthesaxman <cameronghall@cox.net>2017-10-01 11:17:34 -0500
commitf91da8a21072836d18b77380f45030bc8bd87743 (patch)
treed5a0e2e90f11420115c2dd7a998976cc87e80ce9 /src/engine/blend_palette.c
parente926119b726839bc687c503db3680899906aad0d (diff)
parent83efcc9c3d1e81b78c2cd9ceab3ac6420a5f4070 (diff)
Merge remote-tracking branch 'upstream/master' into script_cmd_renaming
Diffstat (limited to 'src/engine/blend_palette.c')
-rw-r--r--src/engine/blend_palette.c20
1 files changed, 20 insertions, 0 deletions
diff --git a/src/engine/blend_palette.c b/src/engine/blend_palette.c
new file mode 100644
index 000000000..843c50ac1
--- /dev/null
+++ b/src/engine/blend_palette.c
@@ -0,0 +1,20 @@
+#include "global.h"
+#include "blend_palette.h"
+#include "palette.h"
+
+void BlendPalette(u16 palOffset, u16 numEntries, u8 coeff, u16 blendColor)
+{
+ u16 i;
+ for (i = 0; i < numEntries; i++)
+ {
+ u16 index = i + palOffset;
+ struct PlttData *data1 = (struct PlttData *)&gPlttBufferUnfaded[index];
+ s8 r = data1->r;
+ s8 g = data1->g;
+ s8 b = data1->b;
+ struct PlttData *data2 = (struct PlttData *)&blendColor;
+ gPlttBufferFaded[index] = ((r + (((data2->r - r) * coeff) >> 4)) << 0)
+ | ((g + (((data2->g - g) * coeff) >> 4)) << 5)
+ | ((b + (((data2->b - b) * coeff) >> 4)) << 10);
+ }
+}