第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定

Flutter | ShaderMask - 給你的Widget加上色彩

標(biāo)簽:
CSS3

在前段时间写代码的时候,碰到个需求:给这个文字加上渐变色!

当时我心里只有一张图:

先看一下效果图:
图片描述

嘿,你别说还挺好看。

话不多说,了解一下是如何实现的吧。

请出今天的主角:ShaderMask

官方介绍

按照惯例,我们还是先来看一下官方的介绍:

A widget that applies a mask generated by a Shader[1] to its child.

一个小部件,将由着色器生成的遮罩应用于其子级。

官方示例

知道了ShaderMask的作用之后我们就接着来看一下官方的示例:

ShaderMask(

然而,当我们把这段代码复制到编辑器,运行后:

什么也没有发生,因为我们的字是黑色的!

改一下,改成白色:

这就是官方demo的例子,也是 ShaderMask 最基础的用法,下面就来说一下进阶的用法。

会动的渐变

先看一下效果:

其实这个和 ShaderMask 本身没有什么关系了,是「着色器」和「动画」的合作后,最后遮罩在一个 Widget 上所达到了现在的效果。

关键代码如下:

shaderCallback: (Rect bounds) {

最重要的是 stops 参数,他规定了渐变的颜色所在区域,值从0到1.

这样再加上动画,就完成了一个会动的渐变色这样的效果。

万物皆可 ShaderMask

前面我只是用了一个文本来演示 ShaderMask 的基础用法,然而 ShaderMask 的 child 可以是任意 Widget。

比如:

结语

ShaderMask 可以很方便的为我们添加颜色,但是我们需要注意其中一点:

shader 是处于下层的,child 处于上层,也就是说,是我们的 child 盖住了 shader

我们可以通过 blendMode 来控制他俩重叠部分的效果,如下:

點(diǎn)擊查看更多內(nèi)容
TA 點(diǎn)贊

若覺(jué)得本文不錯(cuò),就分享一下吧!

評(píng)論

作者其他優(yōu)質(zhì)文章

正在加載中
  • 推薦
  • 評(píng)論
  • 收藏
  • 共同學(xué)習(xí),寫(xiě)下你的評(píng)論
感謝您的支持,我會(huì)繼續(xù)努力的~
掃碼打賞,你說(shuō)多少就多少
贊賞金額會(huì)直接到老師賬戶(hù)
支付方式
打開(kāi)微信掃一掃,即可進(jìn)行掃碼打賞哦
今天注冊(cè)有機(jī)會(huì)得

100積分直接送

付費(fèi)專(zhuān)欄免費(fèi)學(xué)

大額優(yōu)惠券免費(fèi)領(lǐng)

立即參與 放棄機(jī)會(huì)
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢(xún)優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)

舉報(bào)

0/150
提交
取消