diff --git a/src/components/util/HexUtils.ts b/src/components/util/HexUtils.ts index 4a1e5aa4..1721051d 100644 --- a/src/components/util/HexUtils.ts +++ b/src/components/util/HexUtils.ts @@ -53,10 +53,8 @@ export class Gradient { color = this.gradients[0].colorAt(adjustedStep); } else { - const segment = this.gradients[this.gradient].upperRange - this.gradients[this.gradient].lowerRange; - const index = Math.min(Math.floor(adjustedStep / segment), this.gradients.length - 1); - const gradient = this.gradients[index]; - color = gradient.colorAt(adjustedStep); + const gradient = this.gradients[this.gradient]; + color = gradient?.colorAt(adjustedStep); if (adjustedStep >= gradient.upperRange) { this.gradient++; if (this.gradient > this.gradients.length) this.gradient = 0; diff --git a/src/routes/resources/animtab/index.tsx b/src/routes/resources/animtab/index.tsx index 403325ee..058a38c4 100644 --- a/src/routes/resources/animtab/index.tsx +++ b/src/routes/resources/animtab/index.tsx @@ -135,13 +135,14 @@ export default component$(() => {
`${color.hex} ${color.pos}%`).join(', ')});`} - onClick$={(e, el) => { + onMouseDown$={(e, el) => { if (e.target != el) return; const rect = el.getBoundingClientRect(); - const pos = (e.clientX - rect.left) / rect.width * 100; + const pos = Math.round((e.clientX - rect.left) / rect.width * store.text.length) / store.text.length * 100; + if (store.colors.find(c => c.pos == pos)) return; const newColors = [...store.colors]; newColors.push({ hex: getRandomColor(), pos }); - store.colors = newColors; + store.colors = sortColors(newColors); }} onMouseEnter$={(e, el) => { const abortController = new AbortController(); @@ -151,8 +152,10 @@ export default component$(() => { addbutton.classList.add('opacity-0'); return; } + const pos = Math.round((e.clientX - el.getBoundingClientRect().left) / el.getBoundingClientRect().width * store.text.length) / store.text.length * 100; + if (store.colors.find(c => c.pos == pos)) return; addbutton.classList.remove('opacity-0'); - addbutton.style.left = `${(e.clientX - el.getBoundingClientRect().left) / el.getBoundingClientRect().width * 100}%`; + addbutton.style.left = `${pos}%`; }, { signal: abortController.signal }); el.addEventListener('mouseleave', () => { const addbutton = document.getElementById('add-button')!; @@ -172,11 +175,11 @@ export default component$(() => { const colormap = document.getElementById('colormap')!; const rect = colormap.getBoundingClientRect(); document.addEventListener('mousemove', e => { - const newColors = [...store.colors]; - newColors[i].pos = (e.clientX - rect.left) / rect.width * 100; - if (newColors[i].pos < 0) newColors[i].pos = 0; - if (newColors[i].pos > 100) newColors[i].pos = 100; - store.colors = newColors; + let pos = Math.round((((e.clientX - rect.left) / rect.width) * store.text.length)) / store.text.length * 100; + if (pos < 0) pos = 0; + if (pos > 100) pos = 100; + if (store.colors.find(c => c.pos == pos)) return; + color.pos = pos; }, { signal: abortController.signal }); document.addEventListener('mouseup', () => { abortController.abort(); diff --git a/src/routes/resources/rgb/index.tsx b/src/routes/resources/rgb/index.tsx index 3b01b1a4..08ebb2a3 100644 --- a/src/routes/resources/rgb/index.tsx +++ b/src/routes/resources/rgb/index.tsx @@ -67,7 +67,7 @@ export default component$(() => { Wanna automate generating gradients or use this in your own project? We have an API! -