diff options
author | camthesaxman <cameronghall@cox.net> | 2017-10-01 11:17:34 -0500 |
---|---|---|
committer | camthesaxman <cameronghall@cox.net> | 2017-10-01 11:17:34 -0500 |
commit | f91da8a21072836d18b77380f45030bc8bd87743 (patch) | |
tree | d5a0e2e90f11420115c2dd7a998976cc87e80ce9 /src/engine/blend_palette.c | |
parent | e926119b726839bc687c503db3680899906aad0d (diff) | |
parent | 83efcc9c3d1e81b78c2cd9ceab3ac6420a5f4070 (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.c | 20 |
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); + } +} |