当我在元素上使用过滤器时,为什么从该部分引用的形状看起来不同(剪裁!)?
代码段:
<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>
上的示例
答案 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>