aboutsummaryrefslogtreecommitdiff
path: root/src/tools/svg-mesh-gradient-generator/svg-mesh-gradient-generator.vue
blob: e7a32fd47d53521d7873a297d1faf266de46c1bb (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
<template>
  <svg viewBox="0 0 3000 2000" fill="none" xmlns="http://www.w3.org/2000/svg">
    <defs>
      <radialGradient
        v-for="{ id, cx, cy, fx, fy, color } of gradients"
        :id="id"
        :key="id"
        :cx="cx"
        :cy="cy"
        r="100%"
        :fx="fx"
        :fy="fy"
        gradientUnits="objectBoundingBox"
      >
        <stop offset="0" :stop-color="color" stop-opacity="1"></stop>
        <stop offset="0.5" :stop-color="color + '00'" stop-opacity="0"></stop>
      </radialGradient>
    </defs>
    <rect v-for="{ id, fill } of gradients" :key="id" x="0" y="0" width="100%" height="100%" :fill="fill"></rect>
  </svg>
</template>

<script setup lang="ts">
import _ from 'lodash';
import { ref, computed } from 'vue';

const randomPercent = () => `${Math.random() * 100}%`;
const randomColor = () => '#' + (((1 << 24) * Math.random()) | 0).toString(16).padStart(6, '0');

const quantity = ref(5);

const gradients = computed(() =>
  Array.from({ length: quantity.value }, () => {
    const id = _.uniqueId('id-');

    return {
      id,
      fill: `url(#${id})`,
      cx: randomPercent(),
      cy: randomPercent(),
      fx: randomPercent(),
      fy: randomPercent(),
      color: randomColor(),
    };
  }),
);
</script>

<style lang="less" scoped></style>