diff --git a/makeAllGlobs.js b/makeAllGlobs.js
new file mode 100644
index 0000000..d39d2dd
--- /dev/null
+++ b/makeAllGlobs.js
@@ -0,0 +1,51 @@
+const Jimp = require("jimp")
+
+let base, bottom, middle, top
+
+async function generateGlob(hue) {
+
+ const constructed = await base
+ .clone()
+ .composite(
+ bottom.clone().color([
+ {apply: 'hue', params: [hue]}
+ ]),
+ 0,
+ 0,
+ { mode: Jimp.BLEND_SOURCE_OVER }
+ )
+ .composite(
+ middle.clone().color([
+ {apply: 'hue', params: [hue]}
+ ]),
+ 0,
+ 0,
+ { mode: Jimp.BLEND_SOURCE_OVER }
+ )
+ .composite(
+ top.clone().color([
+ {apply: 'hue', params: [hue]}
+ ]),
+ 0,
+ 0,
+ { mode: Jimp.BLEND_SOURCE_OVER }
+ )
+ return constructed
+}
+
+async function main() {
+ base = await Jimp.read('./web/public/img/base.png')
+ bottom = await Jimp.read('./web/public/img/bottom.png')
+ middle = await Jimp.read('./web/public/img/middle.png')
+ top = await Jimp.read('./web/public/img/top.png')
+ for (let i=0; i<1800; i++) {
+ if ( i%100 === 0) {
+ process.stdout.write('x')
+ } else { process.stdout.write('.') }
+ const hue = i/5
+ const result = await generateGlob(hue)
+ await result.write('./allGlobs/' + i + '.png')
+ }
+}
+
+main()
diff --git a/package.json b/package.json
index b40911c..92437bb 100644
--- a/package.json
+++ b/package.json
@@ -23,6 +23,7 @@
"packageManager": "yarn@3.6.1",
"dependencies": {
"browserify-zlib": "^0.2.0",
+ "color-convert": "^2.0.1",
"https-browserify": "^1.0.0",
"jimp": "^0.16.2",
"js-file-download": "^0.4.12",
diff --git a/saturationBoost.js b/saturationBoost.js
new file mode 100644
index 0000000..fe8a416
--- /dev/null
+++ b/saturationBoost.js
@@ -0,0 +1,52 @@
+const Jimp = require("jimp")
+
+let base, bottom, middle, top
+
+async function generateGlob(hue, satBoost) {
+
+ const constructed = await base
+ .clone()
+ .composite(
+ bottom.clone().color([
+ {apply: 'hue', params: [hue]}, {apply: 'saturate', params: [satBoost]}
+ ]),
+ 0,
+ 0,
+ { mode: Jimp.BLEND_SOURCE_OVER }
+ )
+ .composite(
+ middle.clone().color([
+ {apply: 'hue', params: [hue]}, {apply: 'saturate', params: [satBoost]}
+ ]),
+ 0,
+ 0,
+ { mode: Jimp.BLEND_SOURCE_OVER }
+ )
+ .composite(
+ top.clone().color([
+ {apply: 'hue', params: [hue]}, {apply: 'saturate', params: [satBoost]}
+ ]),
+ 0,
+ 0,
+ { mode: Jimp.BLEND_SOURCE_OVER }
+ )
+ return constructed
+}
+
+async function main() {
+ base = await Jimp.read('./web/public/img/base.png')
+ bottom = await Jimp.read('./web/public/img/bottom.png')
+ middle = await Jimp.read('./web/public/img/middle.png')
+ top = await Jimp.read('./web/public/img/top.png')
+ for (let i=0; i<1800; i++) {
+ if ( i%100 === 0) {
+ process.stdout.write('x')
+ } else { process.stdout.write('.') }
+ const hue = i/5
+ const satBoost = i % 100
+ const result = await generateGlob(hue,satBoost)
+ await result.write('./allGlobs/' + i + '.png')
+ }
+}
+
+main()
diff --git a/web/src/pages/HomePage/HomePage.tsx b/web/src/pages/HomePage/HomePage.tsx
index 0ff1d06..f75dbba 100644
--- a/web/src/pages/HomePage/HomePage.tsx
+++ b/web/src/pages/HomePage/HomePage.tsx
@@ -19,10 +19,12 @@ import {
import Jimp from 'jimp'
import fileDownload from 'js-file-download'
+import convert from 'color-convert'
const HomePage = () => {
const [h, setH] = useState(100.0)
+ const [s, setS] = useState(0)
const [iconB64, setIconB64] = useState("")
let base, bottom, middle, top
@@ -33,7 +35,7 @@ const HomePage = () => {
bottom = await Jimp.read('/img/bottom.png')
middle = await Jimp.read('/img/middle.png')
top = await Jimp.read('/img/top.png')
- updateIcon(h).then( (val) => {
+ updateIcon(h, s).then( (val) => {
setIconB64(val)
})
}
@@ -41,13 +43,13 @@ const HomePage = () => {
}, [])
useEffect(() => {
- updateIcon(h).then( (string) => {
+ updateIcon(h, s).then( (string) => {
console.log("Changing iconB64")
setIconB64(string)
})
- }, [h])
+ }, [h, s])
- const updateIcon = async (hue) => {
+ const updateIcon = async (hue, sat) => {
const base = await Jimp.read('/img/base.png')
const bottom = await Jimp.read('/img/bottom.png')
const middle = await Jimp.read('/img/middle.png')
@@ -55,25 +57,31 @@ const HomePage = () => {
const constructed = await base
.clone()
.composite(
- bottom.color([
- {apply: 'hue', params: [hue]}
- ]),
+ bottom
+ .color([
+ {apply: 'hue', params: [hue]},
+ {apply: 'saturate', params: [sat]}
+ ]),
0,
0,
{ mode: Jimp.BLEND_SOURCE_OVER }
)
.composite(
- middle.color([
- {apply: 'hue', params: [hue]}
- ]),
+ middle
+ .color([
+ {apply: 'hue', params: [hue]},
+ {apply: 'saturate', params: [sat]}
+ ]),
0,
0,
{ mode: Jimp.BLEND_SOURCE_OVER }
)
.composite(
- top.color([
- {apply: 'hue', params: [hue]}
- ]),
+ top
+ .color([
+ {apply: 'hue', params: [hue]},
+ {apply: 'saturate', params: [sat]}
+ ]),
0,
0,
{ mode: Jimp.BLEND_SOURCE_OVER }
@@ -92,6 +100,15 @@ const HomePage = () => {
})
}
+ function gradient(hue) {
+ const offset = 210
+ const start = convert.hsv.hex((hue + offset) % 360, 27.3, 64.7)
+ const end = convert.hsv.hex((hue + offset) % 360, 100, 100)
+ const string = 'linear(to-r, #' + start + ', #' + end + ')'
+ console.log(string)
+ return string
+ }
+
return (
<>