您可以控制SVG的笔划宽度的绘制方式吗?

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


当我将a stroke-width应用于rectsay 的SVG 元素时1px,笔触rect将由不同的浏览器以不同的方式应用于的offset和inset。事实证明这很麻烦,尤其是当我尝试计算矩形的外部宽度和可视位置并将其放置在其他元素旁边时。


例如:


Firefox会添加1px的插图(底部和左侧)和1px的偏移量(顶部和右侧)

Chrome会添加1px的插图(顶部和左侧)和1px的偏移量(底部和右侧)

到目前为止,我唯一的解决方案是自己绘制实际边界(可能使用path工具)并将边界放置在描边元素的后面。但是,此解决方案是一个不愉快的解决方法,如果可能的话,我宁愿不走这条路。


所以我的问题是,您可以控制stroke-width在元素上绘制SVG的方式吗?


忽然笑
浏览 578回答 3
3回答

PIPIONE

不可以,您不能指定笔划是在元素内部还是外部绘制的。我在2003年向SVG工作组提出了有关此功能的建议,但没有得到任何支持(或讨论)。正如我在提案中指出的那样,您可以通过将笔触宽度加倍,然后使用剪切路径将对象剪切到自身,来获得与“内部”相同的视觉效果,并且您可以通过将笔触宽度加倍,然后将对象的无笔触副本覆盖在其自身上,来获得与“外部”相同的视觉效果。编辑:此答案将来可能是错误的。通过与(用于“内部”)或与(用于“外部”)结合使用SVG矢量效果,应该有可能获得这些结果。但是,Vector Effects仍然是一个工作草案模块,尚无我能找到的实现。veStrokePathveIntersectveExclude编辑2:SVG 2草案规范包括一个stroke-alignment属性(可能的值|可能的|之外)。此属性可能最终使其成为UA。编辑3:有趣且令人失望的是,SVG工作组已从stroke-alignmentSVG 2中删除。您可以在此处看到散文后描述的一些担忧。

慕田峪4524236

我找到了一种简单的方法,它有一些限制,但对我有用:在defs中定义形状定义参考形状的剪切路径使用它,并在修剪外部时将其加倍这是一个工作示例:<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"/> <clipPath id="clip"> <use xlink:href="#ld"/> </clipPath></defs><g> <use xlink:href="#ld" stroke="#0081C6" stroke-width="160" fill="#00D2B8" clip-path="url(#clip)"/></g></svg>
打开App,查看更多内容
随时随地看视频慕课网APP