如何在不使用任何插件的情况下添加2个音调图标?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何在不使用任何插件的情况下添加2个音调图标?相关的知识,希望对你有一定的参考价值。

我不想在我的应用程序中为一个图标添加任何插件,但我需要两个音调,因为背景颜色会有所不同,我不知道什么时候它会变暗,什么时候会变亮。

我的意思是像这样的图标 - https://material.io/tools/icons/?style=twotone图标有不同颜色的边框。

答案

如果我正确理解你的问题,这里有两个色调IconText的例子。

您可以使用颜色,半径和其他参数来满足您的需求。

body: Center(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: <Widget>[
            ShaderMask(
              blendMode: BlendMode.srcATop,
              shaderCallback: (Rect bounds) {
                return RadialGradient(
                  center: Alignment.topLeft,
                  radius: 1.0,
                  colors: <Color>[Colors.red, Colors.cyanAccent],
                  tileMode: TileMode.mirror,
                ).createShader(bounds);
              },
              child: Text(
                'Two Tone Color Icon & Text!',
                style: TextStyle(fontSize: 22.0),
              ),
            ),
            SizedBox(
              height: 10.0,
            ),
            ShaderMask(
              blendMode: BlendMode.srcATop,
              shaderCallback: (Rect bounds) {
                return RadialGradient(
                  center: Alignment.center,
                  radius: 1.0,
                  colors: <Color>[
                    Colors.greenAccent[200],
                    Colors.blueAccent[200]
                  ],
                  tileMode: TileMode.repeated,
                ).createShader(bounds);
              },
              child: Icon(
                Icons.dashboard,
                size: 32.0,
              ),
            ),
          ],
        ),
      ),

输出:enter image description here

以上是关于如何在不使用任何插件的情况下添加2个音调图标?的主要内容,如果未能解决你的问题,请参考以下文章

如何在不使用命令 npm 的情况下将插件添加到 cordova/phonegap 应用程序?

如何在不创建通知的情况下将图标添加到 Android 状态栏?

如何在不更新chrome的情况下更新flash插件

如何在不使用扩展的情况下在 Autodesk forge 查看器上显示图标

如何在不使用任何插件的情况下将非 maven 依赖项安装到您的 maven 项目中? [复制]

如何在不使用插件的情况下将 jQuery 1.5.1 升级到 3.0