为什么SVG feColorMatrix + <use xlink:href =“#”>导致剪切路径?

时间:2017-06-24 18:07:43

标签: svg svg-filters

当我在元素上使用过滤器时,为什么从该部分引用的形状看起来不同(剪裁!)?

  • 正确显示白色星星(“尖尖”角落)
  • 但棕色(过滤过的)星星被奇怪地剪掉了

代码段:

    <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200">
        <filter id="colorScheme">
            <feColorMatrix in="SourceGraphic" type="matrix" color-interpolation-filters="sRGB"  values="0.5 0.0   0.0   0.0 0.0 0.0   0.3 0.0   0.0 0.0 0.0   0.0   0.0   0.0 0.0 0.0   0.0   0.0   1.0 0.0"/>
        </filter>
        <defs>
            <g id="shape_star">
                <path d="M 50.000001,16.850071 60.828477,38.790929 85.041657,42.309326 67.520845,59.387917 71.656934,83.503263 50,72.117556 28.343064,83.503262 32.479155,59.387917 14.958344,42.309324 39.171522,38.790929 Z"/>
            </g>
            <g id="img_star_active">
                <use xlink:href="#shape_star" style="stroke: #FFFFFF; stroke-width: 10; fill: #FFFFFF;"/>
            </g>
            <g id="img_star_inactive">
                <use xlink:href="#shape_star" style="stroke: #FFFFFF; stroke-width: 10; fill: none; "/>
            </g>
        </defs>
        <use xlink:href="#img_star_active" filter="url(#colorScheme)"/>
        <use xlink:href="#img_star_inactive" transform="translate(100,0)" filter="url(#colorScheme)"/>
        <use xlink:href="#img_star_active" transform="translate(0,100)" />
        <use xlink:href="#img_star_inactive" transform="translate(100,100)"/>
    </svg>

请参阅https://jsfiddle.net/kx2zjnec/3/

上的示例

1 个答案:

答案 0 :(得分:1)

在相对于源grafic的边界框描述的边界框处过滤结果为clipped,但在这种情况下显然不包括笔划宽度。我不得不承认我不明白为什么会这样,但解决方案很简单:提高过滤区域的大小(1是边界框的宽度/高度):

    <filter id="colorScheme" x="-0.2" y="-0.2" width="1.4" height="1.4">
        <feColorMatrix in="SourceGraphic" type="matrix" color-interpolation-filters="sRGB"  values="0.5 0.0   0.0   0.0 0.0 0.0   0.3 0.0   0.0 0.0 0.0   0.0   0.0   0.0 0.0 0.0   0.0   0.0   1.0 0.0"/>
    </filter>