typescript 在SVG中根据路径弯曲渐变[副本]

lrl1mhuk  于 2023-01-10  发布在  TypeScript
关注(0)|答案(1)|浏览(96)
    • 此问题在此处已有答案**:

Can I apply a gradient along an SVG path?(7个答案)
Gradient across path in SVG(2个答案)
昨天关门了。
我有一个SVG路径和一个[x, y] "转折点"列表,这些转折点或多或少地描述了路径的方向。

<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1024 1024">
  <g transform="scale(1, -1) translate(0, -900)">
    <path style="stroke: #333; stroke-width: 10px; stroke-linejoin: round; paint-order: stroke;" fill="#00FF00" d="M 516 320 Q 519 321 599 382 Q 636 410 663 419 Q 682 425 676 441 Q 673 457 610 492 Q 592 502 570 494 Q 510 472 420 447 Q 396 440 339 442 Q 317 443 324 423 Q 331 411 350 400 Q 378 384 411 402 Q 433 411 546 449 Q 559 455 570 448 Q 582 441 576 427 Q 546 382 508 326 C 493 304 493 304 516 320 Z"></path>
  </g>
</svg>

The "turning points" plotted:

<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1024 1024">
  <g transform="scale(1, -1) translate(0, -900)">
    <path style="stroke: #333; stroke-width: 10px; stroke-linejoin: round; paint-order: stroke;" fill="#00FF00" d="M 516 320 Q 519 321 599 382 Q 636 410 663 419 Q 682 425 676 441 Q 673 457 610 492 Q 592 502 570 494 Q 510 472 420 447 Q 396 440 339 442 Q 317 443 324 423 Q 331 411 350 400 Q 378 384 411 402 Q 433 411 546 449 Q 559 455 570 448 Q 582 441 576 427 Q 546 382 508 326 C 493 304 493 304 516 320 Z"></path>
    <circle cx="334" cy="430" r="10"></circle>
    <circle cx="355" cy="420" r="10"></circle>
    <circle cx="383" cy="417" r="10"></circle>
    <circle cx="557" cy="471" r="10"></circle>
    <circle cx="593" cy="467" r="10"></circle>
    <circle cx="617" cy="442" r="10"></circle>
    <circle cx="615" cy="437" r="10"></circle>
    <circle cx="577" cy="388" r="10"></circle>
    <circle cx="514" cy="326" r="10"></circle>
  </g>
</svg>

转折点可能是这样一个列表:

[ 334, 430 ],
[ 355, 420 ],
[ 383, 417 ],
[ 557, 471 ],
[ 593, 467 ],
[ 617, 442 ],
[ 615, 437 ],
[ 577, 388 ],
[ 514, 326 ]

当前路径是纯色,通过fill="#00FF00"属性。
但是基于这些关于转折点的信息,我如何将每条路径的颜色设置为沿着路径曲线的渐变呢?

tp5buhyn

tp5buhyn1#

必须使用linearGradient元素指定渐变,并为其分配一个特殊的id,然后使用url()函数将此渐变指定为path元素的fill属性值。

相关问题