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

标签 flutter gradient blur

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

有没有人有任何想法。谢谢

最佳答案

现在似乎有可能,使用新的 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),
               )
     ),
   ])

关于flutter - 如何在 Flutter 中使用线性渐变创建模糊,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60311065/

相关文章:

Flutter Null安全迁移说 `Package doesn'不存在`

dart - flutter 文本异常 - 表达式不是有效的编译时常量

css - 如何根据 Angular 指定 svg 线性渐变

ios - 无法模糊 ios 中的输入

flutter - Flutter 中未定义的类 'AuthResult'

flutter - 在提供者初始化时调用将来的方法

javascript - 在 JS 中定位 SCSS 变量

javascript - 为什么我不能放线性渐变?

html - 如果鼠标在图片上,如何在图片上获取文字?

jquery - 内联编辑: onBlur prevents onClick from being triggered (jQuery)