[英]Catch changes on SVG element circle and change attributes elsewhere via js
[英]change circle svg element to path with js manipulation
svg 和 js 混合在一起是全新的,在这里需要一些帮助。
我在我的网站上使用这个脚本: https://www.techdezine.com/background-blur-image-revealed-with-mouse-action/
我正在尝试更改圆形(使用 < circle > 元素)。
到菱形(或可能是路径元素)( 链接到示例),因此 javascript 仍将更新不同形状的鼠标位置坐标
它包含这个 html
<div class="pic">
<svg class="blur" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="100%">
<image filter="url(#filter2)" xlink:href="female.jpg" width="100%" height="100%"></image>
<filter id="filter2">
<feGaussianBlur stdDeviation="5" />
</filter>
<mask id="mask1">
<circle cx="-50%" cy="-50%" r="40" fill="white" filter="url(#filter2)" />
</mask>
<image xlink:href="female.jpg" width="100%" height="100%" mask="url(#mask1)"></image>
</svg>
</div>
并正在使用此 JS 进行操作
$('.pic').mousemove(function (event) {
event.preventDefault();
var upX = event.clientX;
var upY = event.clientY;
var mask = $('#mask1 circle')[0];
mask.setAttribute("cy", (upY - 5) + 'px');
mask.setAttribute("cx", (upX) + 'px');
});
任何想法如何做到这一点,我太长了,仍然不知道。
解决方案
我设置了 transform="translate()" 属性,而不是 CY 和 CX 的 setAttributes。 它工作得很好。
$('.pic').mousemove(function (event) {
event.preventDefault();
var upX = event.clientX;
var upY = event.clientY;
var mask = $('#mask1 circle')[0];
var mask = jQuery('#mask1 polygon')[0];
mask.setAttribute("transform", "translate(" + (upX) + ',' + (upY) + ')' );
});
和 HTML
<mask id="mask1">
<polygon fill="white" points="69.445,125 125,28.774 180.556,125
125,221.227 " transform="translate(-125,-125)"/>
</mask>
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.