html - SVG 剪辑路径问题

标签 html css svg clip-path

我有一个 svg 标签,里面有两个圆形元素,它们彼此相同。具有相同的 X、Y 和 R。但是当我将其中一个放在 clipPath 中并将其链接到图像或 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;
}

codepen here.

最佳答案

发生这种情况是因为在您的 clipPath 中,圆的坐标被视为相对于页面左上角的坐标。而 SVG 中的圆坐标是相对于 <svg> 的左上角的.但是 SVG 受 HTML 上默认边距/填充的影响 <body> .所以不在同一个地方。

如果您以标准方式去除主体边距:

BODY {
  padding: 0;
  margin: 0;
}

你会看到它们都排成一行。

http://codepen.io/anon/pen/VjjOzm

关于html - SVG 剪辑路径问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37879061/

相关文章:

html - 在没有 JavaScript 的情况下选中复选框时隐藏 div

html - 使 IE 10 重复 svg 背景

javascript - HTML/CSS : Focus a paragraph

jquery - 如何为动态创建的不同组件重用相同的代码?

javascript - 使用 lit-html 用 Shadow DOM 封装自定义元素的 CSS

jquery - float : right reverses the order of the items

javascript - 带有开始圆的 SVG 进度条动画

jquery - 如何使用 Snap Svg 触发?

javascript - 从 AJAX 在 javascript 中创建列表

javascript - 使 anchor 文本成为 href 的一部分?