目前正在构建一个基于浏览器的SVG应用程序。在这个应用程序中,用户可以设置各种形状的样式和位置,包括矩形。

当我将笔画宽度应用到SVG矩形元素(比如1px)时,不同的浏览器会以不同的方式将笔画应用到矩形的偏移和插入。这被证明是很麻烦的,特别是当我试图计算一个矩形的外部宽度和视觉位置,并将其放置在其他元素旁边时。

例如:

Firefox添加了1px的插入(底部和左侧)和1px的偏移(顶部和右侧) Chrome添加了1px的插入(顶部和左侧),和1px的偏移(底部和右侧)

到目前为止,我唯一的解决方案是自己绘制实际的边界(可能是用路径工具),并将边界定位在描边元素的后面。但这种解决方案是一种令人不快的变通方法,如果可能的话,我宁愿不走这条路。

所以我的问题是,你能控制SVG的笔画宽度如何在元素上绘制吗?


当前回答

我不知道这有多大帮助,但在我的情况下,我只是创建了另一个圆,只有边界,并将其“在”另一个形状。

其他回答

这招对我很管用:

.btn {
 border: 1px solid black;
 box-shadow: inset 0 0 0 1px black;
}

Xavier Ho的解决方案是将笔画宽度增加一倍,并改变着色顺序,尽管只有在填充颜色为纯色且不透明的情况下才有效。

我已经开发了其他方法,更复杂,但适用于任何填充。它也适用于椭圆或路径(后者存在一些具有奇怪行为的角落情况,例如交叉自己的开放路径,但并不多)。

诀窍是在两层中显示形状。一个没有笔画(只有填充),另一个只有两倍宽度的笔画(透明填充),并通过一个遮罩,显示整个形状,但隐藏了没有笔画的原始形状。

  <svg width="240" height="240" viewBox="0 0 1024 1024">
  <defs>
    <path id="ld" d="M256,0 L0,512 L384,512 L128,1024 L1024,384 L640,384 L896,0 L256,0 Z"/>
    <mask id="mask">
      <use xlink:href="#ld" stroke="#FFFFFF" stroke-width="160" fill="#FFFFFF"/>
      <use xlink:href="#ld" fill="#000000"/>
    </mask>
  </defs>
  <g>
    <use xlink:href="#ld" fill="#00D2B8"/>
    <use xlink:href="#ld" stroke="#0081C6" stroke-width="160" fill="red" mask="url(#mask)"/>
  </g>
  </svg>

如上所述,你必须重新计算笔画路径坐标的偏移量,或者将其宽度翻倍,然后掩码一侧或另一侧,因为不仅SVG本身不支持Illustrator的笔画对齐,而且PostScript也不支持。

Adobe PostScript手册第二版中的笔画规范规定: 4.5.1抚摸: 描边操作符沿着当前路径绘制一条一定粗细的线。对于路径中的每个直线或曲线段,笔画一条以该段为中心,两侧平行于该段的直线。”(并强调了这一点)

规范的其余部分没有用于偏移行的位置的属性。当Illustrator让你在内部或外部对齐时,它会重新计算实际路径的偏移量(因为它仍然比套印然后掩蔽计算更便宜)。.ai文档中的路径坐标是引用,而不是被光栅化或导出为最终格式的内容。

因为Inkscape的原生格式是规范SVG,所以它不能提供规范所缺乏的特性。

我不知道这有多大帮助,但在我的情况下,我只是创建了另一个圆,只有边界,并将其“在”另一个形状。

您可以使用CSS样式的笔画和填充顺序。即先描边,后填充,得到想要的效果。

MDN油漆订购:https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute/paint-order

CSS代码:

paint-order: stroke;