内容简介:在前段时间写代码的时候,碰到个需求:给这个文字加上渐变色!当时我心里只有一张图:
在前段时间写代码的时候,碰到个需求:给这个文字加上渐变色!
当时我心里只有一张图:
先看一下效果图:
嘿,你别说还挺好看。
话不多说,了解一下是如何实现的吧。
请出今天的主角: ShaderMask
。
官方介绍
按照惯例,我们还是先来看一下官方的介绍:
A widget that applies a mask generated by a Shader [1] to its child.
一个小部件,将由着色器生成的遮罩应用于其子级。
官方示例
知道了 ShaderMask
的作用之后我们就接着来看一下官方的示例:
ShaderMask(
shaderCallback: (Rect bounds) {
return RadialGradient(
center: Alignment.topLeft,
radius: 1.0,
colors: <Color>[Colors.yellow, Colors.deepOrange.shade900],
tileMode: TileMode.mirror,
).createShader(bounds);
},
child: const Text('I’m burning the memories'),
)
然而,当我们把这段代码复制到编辑器,运行后:
什么也没有发生,因为我们的字是黑色的!
改一下,改成白色:
这就是官方demo的例子,也是 ShaderMask
最基础的用法,下面就来说一下进阶的用法。
会动的渐变
先看一下效果:
其实这个和 ShaderMask
本身没有什么关系了,是「着色器」和「动画」的合作后,最后遮罩在一个 Widget 上所达到了现在的效果。
关键代码如下:
shaderCallback: (Rect bounds) {
return LinearGradient(colors: _colors, stops: [
0 + _gradientValue * 0.2,
_gradientValue * 0.8,
1 - _gradientValue * 0.3
]).createShader(bounds);
}
最重要的是 stops
参数, 他规定了渐变的颜色所在区域,值从0到1.
这样再加上动画,就完成了一个会动的渐变色这样的效果。
万物皆可 ShaderMask
前面我只是用了一个文本来演示 ShaderMask
的基础用法,然而 ShaderMask
的 child 可以是任意 Widget。
比如:
结语
ShaderMask
可以很方便的为我们添加颜色,但是我们需要注意其中一点:
shader
是处于下层的, child
处于上层,也就是说,是我们的 child
盖住了 shader
。
我们可以通过 blendMode
来控制他俩重叠部分的效果,如下:
图来自 张风捷特烈 [2]
References
[1]
Shader: https://api.flutter.dev/flutter/dart-ui/Shader-class.html
[2]
张风捷特烈: https://juejin.im/user/5b42c0656fb9a04fe727eb37
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 图像编辑新作:连续色彩迁移
- Android系统色彩模式RGB_565的问题
- 给Elasticsearch加上监控
- 一起来学opencv(二):图片通道及色彩空间转化
- 给树莓派小车控制系统加上装甲
- 如何用捷径给 GIF 加上进度条
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Java 8函数式编程
[英] Richard Warburton / 王群锋 / 人民邮电出版社 / 2015-3 / 39.00元
通过每一章的练习快速掌握Java 8中的Lambda表达式 分析流、高级集合和其他Java 8类库的改进 利用多核CPU提高数据并发的性能 将现有代码库和库代码Lambda化 学习Lambda表达式单元测试和调试的实践解决方案 用Lambda表达式实现面向对象编程的SOLID原则 编写能有效执行消息传送和非阻塞I/O的并发应用一起来看看 《Java 8函数式编程》 这本书的介绍吧!