From 6164149b53ea517b04f45b52a4eadb1dc3f1ca35 Mon Sep 17 00:00:00 2001 From: Erin Peach Date: Thu, 6 Dec 2018 12:06:46 -0800 Subject: [PATCH 1/2] Update how Alpha is set for rainbow color objects --- src/Effects.js | 19 +++++++++---------- 1 file changed, 9 insertions(+), 10 deletions(-) diff --git a/src/Effects.js b/src/Effects.js index f1517cfb..a1d5f063 100644 --- a/src/Effects.js +++ b/src/Effects.js @@ -58,6 +58,11 @@ module.exports = class Effects { return p5.lerpColor(p5.color(prev), p5.color(next), remainder); }; + /* Given a p5.Color object, creates a new color object with the given alpha value*/ + const setAlphaForColor = (color, alpha) => { + return p5.color(color._getRed(), color._getGreen(), color._getBlue(), alpha); + }; + const randomColorFromPalette = () => { const palette = this.palettes[this.currentPalette]; return palette[randomNumber(0, palette.length - 1)]; @@ -173,27 +178,21 @@ module.exports = class Effects { this.update(); } p5.push(); - let backgroundColor = lerpColorFromPalette(0.5); - // Hack to set alpha for p5 - backgroundColor._array[3] = 0.25; + let backgroundColor = setAlphaForColor(lerpColorFromPalette(0.5), 0.5 * 255); p5.background(backgroundColor); p5.noFill(); p5.strokeWeight(50); let d, i; for (i = 0; i < 7; i++) { - let paletteColor = lerpColorFromPalette(i * 0.14); - paletteColor._array[3] = 0.5; + let paletteColor = setAlphaForColor(lerpColorFromPalette(i * 0.14), 0.5 * 255); p5.stroke(paletteColor); d = 150 + i * 100; p5.arc(0, 400, d, d, -90, 0); if (this.lengths[i] > 0) { // Hack to set RGB and Alpha values of p5 color objects let [red, green, blue] = paletteColor.levels; - paletteColor.levels[0] = red - 20; - paletteColor.levels[1] = green - 20; - paletteColor.levels[2] = blue - 20; - paletteColor._array[3] = 1 - this.lengths[i] / 90; - p5.stroke(paletteColor); + let strokeColor = p5.color(red - 20, green - 20, blue - 20, (1 - this.lengths[i] / 90) * 255); + p5.stroke(strokeColor); p5.arc(0, 400, d, d, -90, -90 + this.lengths[i]); this.lengths[i] = (this.lengths[i] + bpm / 50) % 90; } From 9b9d3265794abca4370e546df28c084e1b0be9e9 Mon Sep 17 00:00:00 2001 From: Erin Peach Date: Mon, 17 Dec 2018 16:08:43 -0800 Subject: [PATCH 2/2] Use p5.red to get RGB colors --- src/Effects.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Effects.js b/src/Effects.js index b162b880..818487c2 100644 --- a/src/Effects.js +++ b/src/Effects.js @@ -60,7 +60,7 @@ module.exports = class Effects { /* Given a p5.Color object, creates a new color object with the given alpha value*/ const setAlphaForColor = (color, alpha) => { - return p5.color(color._getRed(), color._getGreen(), color._getBlue(), alpha); + return p5.color(p5.red(color), p5.green(color), p5.blue(color), alpha); }; const randomColorFromPalette = () => {