简体   繁体   中英

SVG Intersection set color

So I've got an SVG shape that I'm animating using GSAP, and you can find it in this codepen here . What I want to happen is that when the lines intersect the pink circle, the inner lines turn white, like in this image: 在此处输入图像描述

I've tried using CSS Blendmodes, like so:

line {
  mix-blend-mode: screen;
}

Is there any way I'm able to do this? Either with CSS or with JavaScript?

I don't know React, so this may collide with your further plans, but you could just mask it out in SVG. You put the circle over the lines, but remove the part that covers them using a mask . Then you put another circle, white, behind the pink circle but still over the lines. This circle is then visible through the removed parts of the pink circle, so it looks as if the lines were turning white.

This, however, requires a reorganisation of the SVG:

(CodePen with your animation here )

 <svg xmlns="http://www.w3.org/2000/svg" width="712.828" height="1100.5" viewBox="0 0 712.828 1100.5"> <defs> <.-- define things that are reused --> <g id="Lines" fill="none" stroke-width="4"> <.-- define a group of lines --> <line id="Line_0" data-name="Line 6" x1="710" y2="710" transform="translate(1.414 184)" /> <line id="Line_1" data-name="Line 1" y2="929" transform="translate(215.414 171.5)" /> <line id="Line_2" data-name="Line 2" y2="894" transform="translate(231.414)" /> <line id="Line_3" data-name="Line 47" y2="842" transform="translate(247,414 92)" /> </g> <circle id="Circle" data-name="Ellipse 1" cx="202" cy="202" r="202" transform="translate(185.414 445)"/> </defs> <.-- the rest of your elements should be at this place. but they are not important for this demonstration --> <use href="#Lines" stroke="#2d2334" fill="none"/> <.-- display the lines --> <mask id="Mask"> <rect width="100%" height="100%" fill="white"/> <.-- white everywhere = keep everything.,. --> <use href="#Lines" stroke="black"/> <!-- ...except for lines' area (black) --> </mask> <use href="#Circle" fill="#ffffff"/> <!-- background circle - color of the intersection --> <use href="#Circle" fill="#d80b8c" mask="url(#Mask)"/> <!-- the circle with lines masked out, so the background circle is visible through lines' area --> </svg>

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM