前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Flutter Widgets 之 ShaderMask

Flutter Widgets 之 ShaderMask

原创
作者头像
老孟Flutter
修改2020-03-02 07:27:47
5400
修改2020-03-02 07:27:47
举报
文章被收录于专栏:Flutter

ShaderMask可以让我们将Shader用于任何一个控件上,比如在Text上使用渐变就可以使用ShaderMask来实现:

代码语言:txt
复制
ShaderMask(

      shaderCallback: (Rect bounds) {

        return RadialGradient(

          center: Alignment.topLeft,

          radius: 1.0,

          colors: <Color>[Colors.yellow, Colors.deepOrange],

          tileMode: TileMode.mirror,

        ).createShader(bounds);

      },

      blendMode: BlendMode.srcATop,

      child: Text('老孟,一枚有态度的程序员',style: TextStyle(fontSize: 30),),

    )

效果:

shaderCallback 需要返回一个Shader对象,可以通过渐变相关类直接生成Shader:

代码语言:txt
复制
RadialGradient(...).createShader(rect)

blendMode属性是融合方式,child是目标图像(dst),Shader是源图像(src),融合方式介绍:

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档