svg - 是否可以将变换矩阵应用于 SVG 滤镜效果

标签 svg dropshadow svg-filters

我正在尝试在 SVG 中重新创建一个像图钉这样的 iphone map ,并且我把图钉部分放下了,但我想知道如何解决阴影问题。我看过一堆阴影示例,但它们都只是将原始图像偏移了几个像素。是否可以将变换矩阵应用于过滤器使其倾斜?

到目前为止,这是引脚 SVG:

<svg xmlns="http://www.w3.org/2000/svg" version="1.1">
    <defs>
        <radialGradient id="SVGID_1_" cx="29.3623" cy="31.1719" r="11.6241" gradientTransform="matrix(1.1875 0 0 1.1875 -30.8438 -30.2812)" gradientUnits="userSpaceOnUse">
            <stop  offset="0.2637" style="stop-color:#FF0000"/>
            <stop  offset="1" style="stop-color:#6D0000"/>
        </radialGradient>
    </defs>
    <rect x="9.251" y="13.844" fill="#CCCCCC" stroke="#7C7C7C" width="2" height="24.83"/>
    <circle fill="url(#SVGID_1_)" stroke="#660000" cx="10.5" cy="11.5" r="9.5"/>
    <ellipse transform="matrix(0.8843 0.4669 -0.4669 0.8843 4.475 -1.6621)" fill="#FFCCCC" cx="6.591" cy="8.199" rx="1.538" ry="1.891"/>
</svg>

谢谢!

最佳答案

这是一个简单的变换和过滤器来旋转它。如果你也想做倾斜,你需要用一些矩阵的东西替换旋转线。

<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1">
    <defs>
        <radialGradient id="SVGID_1_" cx="29.3623" cy="31.1719" r="11.6241" gradientTransform="matrix(1.1875 0 0 1.1875 -30.8438 -30.2812)" gradientUnits="userSpaceOnUse">
            <stop  offset="0.2637" style="stop-color:#FF0000"/>
            <stop  offset="1" style="stop-color:#6D0000"/>
        </radialGradient>
        <filter id="drop-shadow">
          <feGaussianBlur in="SourceAlpha" result="blur-out" stdDeviation="1" />

        </filter>
    </defs>
    <g id="pin">
        <rect x="9.251" y="13.844" fill="#CCCCCC" stroke="#7C7C7C" width="2" height="24.83"/>
        <circle fill="url(#SVGID_1_)" stroke="#660000" cx="10.5" cy="11.5" r="9.5"/>
        <ellipse transform="matrix(0.8843 0.4669 -0.4669 0.8843 4.475 -1.6621)" fill="#FFCCCC" cx="6.591" cy="8.199" rx="1.538" ry="1.891"/>
    </g>

     <use xlink:href="#pin" transform="rotate(60 10.251 38.674)" filter="url(#drop-shadow)"/>
</svg>

关于svg - 是否可以将变换矩阵应用于 SVG 滤镜效果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7843074/

相关文章:

css - 为什么这个 svg 不受滤镜影响?

javascript - 带渐变的 Highcharts 饼图 donut

css - 仅将投影应用于边框顶部?

JavaFX 对背景的影响

image - svg过滤器中的边缘检测

javascript - Highlight.js svg 标签

vue.js - 在 Vue 组件中将样式元素添加到 SVG

delphi - 向 TBitmap 添加阴影

svg - PhantomJS 不尊重 SVG 颜色插值过滤器

html - 我可以制作一个具有多种效果的 SVG 滤镜吗?