chrome和firefox之间的SVG模式不一致

时间:2012-01-19 16:35:30

标签: firefox google-chrome svg

我有一个渐变覆盖指定为图案的纯色(红色):

<svg width="480" height="480">
    <defs>

        <pattern width="1" height="1" x="0" y="0" id="pattern">
            <rect width="240" height="240" x="0" y="0" fill="rgba(255,0,0,1)"/>
            <rect width="240" height="240" x="0" y="0" fill="url(#gradient)"/>
        </pattern>

        <linearGradient id="gradient" x1="0" y1="1" x2="0" y2="0">
            <stop offset="0%" stop-color="rgb(0,0,0)" stop-opacity="1"/>
            <stop offset="100%" stop-color="rgb(0,0,0)" stop-opacity="0"/>
        </linearGradient>

    </defs>
    <path
      transform="matrix(1,0,0,1,200,200)"
      d="M0 0M 120 0 A 120 120 0 0 0 -120 0 A 120 120 0 0 0 120 0"
      fill="url(#pattern)"
    />
</svg>

左:Firefox。右:Chrome

enter image description here

右侧的那个(Chrome)是正确的。

有谁知道如何在Firefox中使用它?

现场直播:http://jsbin.com/eyenoh/edit#html,live

1 个答案:

答案 0 :(得分:3)

通过使用对象边界框作为模式内容的坐标系,我能够使它工作。

<pattern width="1" height="1" x="0" y="0" id="pattern" patternContentUnits="objectBoundingBox">
    <rect width="1" height="1" x="0" y="0" fill="rgba(255,0,0,1)"/>
    <rect width="1" height="1" x="0" y="0" fill="url(#gradient)"/>
</pattern>

在此处查看: http://jsbin.com/efesev/edit#html,live

我会尝试进一步调查。看起来像是错误报告的好候选人。