如何设置SVG过滤器的alpha值?

时间:2016-03-12 16:41:10

标签: html css svg svg-filters

我想从SVG径向模糊滤镜中更改alpha?有没有办法将alpha更改为100%?

谢谢你的时间!

干杯

亚历

.effet{
  width: 400px; height: 300px;
  margin: 0 auto 50px auto;
  background-color: #9c27b0;
}
.filtre--r{
  -webkit-mask: -webkit-radial-gradient( center, closest-side, transparent 30%, black 80%);
  -webkit-mask: radial-gradient( closest-side at center, transparent 50%, black 110%);
  -webkit-filter: blur(5px);
  mask: url('#mask-radial');
  filter: url('#filtre1');
}
<div class="effet">
<img class="filtre filtre--r" src="http://css3create.com/squelettes/images/articles/flou-localise-1.jpg" alt="" />
<svg height="0">
<defs>
  <mask id="mask-radial">
    <rect width="400" height="300" fill="url(#g1)"></rect>
    <radialGradient id="g1" cx="50%" cy="50%" r="50%">
      <stop stop-color="black" offset="50%"/>
      <stop stop-color="white" offset="110%"/>
    </radialGradient>
  </mask>
  <filter id="filtre1">
    <feGaussianBlur in="SourceGraphic" stdDeviation="5"/>
  </filter>
</defs>
</svg>

1 个答案:

答案 0 :(得分:0)

这会将alpha乘以100 - 这几乎可以给你一个alpha = 1但是有一点边缘抗锯齿。 (您可以直接将alpha设置为1,但也会将背景设置为黑色/不透明。)

  <filter id="filtre1">
    <feGaussianBlur in="SourceGraphic" stdDeviation="5"/>
    <feColorMatrix type="matrix" values="1 0 0 0 0  0 1 0 0 0  0 0 1 0 0  0 0 0 100 0"/>
  </filter>