如何在 Flutter 中使用线性渐变创建模糊

问题描述 投票:0回答:2

我正在尝试在 Flutter 内部创建一个小部件,其作用类似于 BackdropFilter 小部件并模糊其后面的任何内容。尽管与 BackdropFilter 不同,这种模糊度不应均匀分布,而应逐渐线性增加模糊度。

有人有什么想法吗?谢谢

flutter gradient blur
2个回答
14
投票

现在似乎可以使用新的

ImageFiltered
小部件。

我通过this GitHub评论找到了代码示例:

Stack(
   alignment: Alignment.bottomCenter,
   fit: StackFit.expand,
   children: <Widget>[
    Image.network(
             image,
             fit: BoxFit.cover,
             alignment: Alignment.bottomCenter),
      ImageFiltered(
               imageFilter: ImageFilter.blur(sigmaX: 10, sigmaY: 10),
               child: ShaderMask(
                 shaderCallback: (rect) {
                   return LinearGradient(
                       begin: Alignment.topCenter,
                       end: Alignment.bottomCenter,
                       colors: [Colors.black, Colors.black.withOpacity(0)],
                       stops: [0.4, 0.75]).createShader(rect);
                 },
                 blendMode: BlendMode.dstOut,
                 child: Image.network(
                     image,
                     fit: BoxFit.cover,
                     alignment: Alignment.bottomCenter),
               )
     ),
   ])

0
投票

使用 LinearGradient 并将不透明度设置为颜色:

Container(
    height: 200,
    decoration: BoxDecoration(
    gradient: LinearGradient(
    colors: [
        const Color(0xFF1A1A1D).withOpacity(0),
        const Color(0xFF1A1A1D).withOpacity(1)
    ],
    begin: Alignment.topCenter,
    end: Alignment.bottomCenter,
    )),
)
© www.soinside.com 2019 - 2024. All rights reserved.