SVG 剪辑路径问题
SVG clipPath issue
我有一个 svg 标签,里面有两个圆形元素,它们彼此相同。具有相同的 X 和 Y 和 R。但是当我将其中一个放在 clipPath 中并将其 link 到图像或 div 时,剪切圆的位置将会改变。有什么问题吗?
如果有人能提供帮助,我们将不胜感激。
这里是 html 代码:
<div class="clip-background"></div>
<svg width="500" height="500">
<clipPath id="clipping-area">
<circle cx="200" cy="200" r="100">
</clipPath>
<circle class="circle-border" cx="200" cy="200" r="100">
</svg>
这里是 css 代码:
.clip-background{
position:absolute;
width:500px;
height:500px;
background-color:pink;
clip-path: url(#clipping-area);
-webkit-clip-path: url(#clipping-area);
}
.circle-border{
fill:none;
stroke:#666;
stroke-width:2;
}
发生这种情况是因为在您的 clipPath 中,圆的坐标被视为相对于页面左上角的坐标。而 SVG 中的圆坐标是相对于 <svg>
的左上角的。但是 SVG 受 HTML <body>
上默认 margins/paddings 的影响。所以不在同一个地方。
如果您以标准方式去除正文边距:
BODY {
padding: 0;
margin: 0;
}
你会看到他们都排成一行。
我有一个 svg 标签,里面有两个圆形元素,它们彼此相同。具有相同的 X 和 Y 和 R。但是当我将其中一个放在 clipPath 中并将其 link 到图像或 div 时,剪切圆的位置将会改变。有什么问题吗? 如果有人能提供帮助,我们将不胜感激。
这里是 html 代码:
<div class="clip-background"></div>
<svg width="500" height="500">
<clipPath id="clipping-area">
<circle cx="200" cy="200" r="100">
</clipPath>
<circle class="circle-border" cx="200" cy="200" r="100">
</svg>
这里是 css 代码:
.clip-background{
position:absolute;
width:500px;
height:500px;
background-color:pink;
clip-path: url(#clipping-area);
-webkit-clip-path: url(#clipping-area);
}
.circle-border{
fill:none;
stroke:#666;
stroke-width:2;
}
发生这种情况是因为在您的 clipPath 中,圆的坐标被视为相对于页面左上角的坐标。而 SVG 中的圆坐标是相对于 <svg>
的左上角的。但是 SVG 受 HTML <body>
上默认 margins/paddings 的影响。所以不在同一个地方。
如果您以标准方式去除正文边距:
BODY {
padding: 0;
margin: 0;
}
你会看到他们都排成一行。