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

Jam*_*mes 6 firefox svg google-chrome

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

<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>
Run Code Online (Sandbox Code Playgroud)

左:Firefox.右:Chrome

在此输入图像描述

右边的那个(Chrome)是正确的.

有谁知道如何在Firefox中使这项工作?

现场观看:http://jsbin.com/eyenoh/edit#html,live

Tsv*_*nev 2

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

<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>
Run Code Online (Sandbox Code Playgroud)

在这里查看: http: //jsbin.com/efesev/edit#html,live

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