- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试根据 Google's Material Theme Builder 3 在 SASS/JS 中生成调色板这需要根据相对亮度而不是亮度/亮度函数生成色调调色板。
我可以在 SCSS 中使用以下函数获取亮度值:
@function get-luminance($color) {
$colors: (
'red': red($color),
'green': green($color),
'blue': blue($color),
);
@each $name, $value in $colors {
$adjusted: 0;
$value: $value / 255;
@if $value < 0.03928 {
$value: $value / 12.92;
} @else {
$value: ($value + 0.055) / 1.055;
$value: math.pow($value, 2.4);
}
$colors: map-merge($colors, ($name: $value));
}
@return (map-get($colors, 'red') * 0.2126) + (map-get($colors, 'green') * 0.7152) + (map-get($colors, 'blue') * 0.0722);
}
但我正在寻找的是创建一个可以调整特定颜色亮度的函数,例如
@function adjust-luminance($color, $luminance-value) {
// Calculations required to adjust luminance here
@return $adjusted-luminance-color;
}
$seed-color: #6750A4;
.color-tone-99 {
background: adjust-luminance($seed-color, 97.4); // Output: #FFFBFE
}
上面的计算部分我还没弄明白。我也遇到过这个 Color Luminance Figma plugin在 Figma 中可以做到,但问题是它是如何做到的。
非常感谢任何帮助!
谢谢
最佳答案
事实证明,James O'Leary,Google 平台与生态系统色彩科学家开发了一种全新的、感知准确的颜色系统,称为 HCT,代表色调、色度、色调。
他写了一篇很棒的文章,解释了为什么以及如何在此处创建它: The Science of Color & Design .
Material Foundation 也在这里发布了他们的 TypeScript 代码库: Material Color Utilities GitHub Repo .
<强>1。通过 NPM 安装 Material Color Utilities:
npm i @material/material-color-utilities
<强>2。导入实用程序:
从“@material/material-color-utilities”导入 { argbFromHex, hexFromArgb, themeFromSourceColor, TonalPalette };
<强>3。获取主题 JSON:
const m3ThemeColorsJSON = themeFromSourceColor(argbFromHex('#6750A4'), []);
<强>4。这将返回 ARGB 颜色的 JSON 映射,要将它们转换为 HEX 颜色,请使用 hexFromArgb() 函数。示例:
const primary = hexFromArgb(theme.schemes.light.primary);
<强>5。如果您想从 Tonal Palette 中获取颜色,请使用以下命令:
const primary98 = TonalPalette.fromInt(primary).tone(98);
Material Foundation 打算在未来发布一个 SCSS 版本,但同时任何人都可以在 JavaScript 中使用它来生成 SCSS 文件。
关于javascript - 如何在 JS/SCSS 中生成 Material 3 调色板?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/70323955/
是否可以更改 Matplotlib 在为图形线条生成自己的颜色时循环使用的颜色?我正在使用 pylab 模块。 from pylab import * import matplotlib.cm as
R中是否有可以处理许多数据类的调色板的好包?我有 16 个连续数据类。我试过 RColorBrewer 但它最多有 9 个数据类,我也试过 Rainbow() 但它对顺序数据没有吸引力。谢谢 最佳答案
一些与 previous question 相关的内容 我想采用 gnuplot 的默认(pm3d 默认)调色板,并在 X 处放置一个白色值,并将任何 >=X 的内容设置为白色,但其余部分( 例如,我
我正在尝试使用调用 Web 服务的结果(这是一个分段列表)来填充 Tapestry 5 中的调色板组件。 Segment 是一个普通的类,具有一些属性,如标题...我想将标题显示为可用、选定的调色板列
我最近在 Eclipse 4.3 (Kepler) 上安装了 windowBuilder 工具。当我尝试在布局设计器上进行一些工作时,我的调色板窗口上不会出现任何组件。只有一些组件,如“布局 ->布局
我计划从我的 RecyclerView 中的每个 bitmap 中获取每一种鲜艳的颜色,并将其设置为我的文本的背景。所以我尝试了以下: Picasso.with(ctx)
如何使用D3 Palettes在 Bokeh ?我尝试以这种方式导入,但收到未解析的引用错误消息 from bokeh.palettes import Category20 Bokeh 版本: pri
Seaborn 允许定义包含多种颜色的调色板,这对具有多行的图表很有用。但是,当将调色板设置为具有多种颜色的调色板时,仅使用前六种颜色,之后颜色会循环使用,因此很难区分线条。这可以通过显式调用调色板来
实际上我正在开发一个包含 Material 设计抽屉导航的 android 应用程序,我想每 5 分钟动态更改状态栏、操作栏、文本颜色的颜色。实际上我正在使用支持库主题来支持所有 android手机。
我为一个项目编写了一些自定义的复合小部件,并将它们编译成一个单独的 jar 文件。我将这个 jar 文件添加到 GWT 项目的构建路径中。当我尝试将小部件添加到调色板时(通过按“选择组件”按钮),我可
我在缓冲区(类型 - 长型)中有一个来自 32 位扫描仪的图像数据。 例如buffer[0]对应的像素值为952即[184, 3, 0, 0] <-[R,G,B,A]; 我想在屏幕上显示/绘画/绘图;
我的公司有一个正式的调色板,所以我需要在我的 seaborn 图表中使用这些颜色。因此,我想设置默认的 seaborn 调色板,并为这些颜色提供易于使用的名称,例如“p”代表紫色,“g”代表绿色。 这
我试图通过一个主要是数字的因素为 ggplot 着色,如下所示: iris %>% ggplot(aes(Sepal.Length, Sepal.Width, color = cut(Petal.
我在 Kubuntu 12.04 上使用 Netbeans 7。我这样启动 Netbeans: netbeans --cp:a /usr/share/java/xercesImpl.jar & Net
我已经用我选择的颜色制作了颜色图,但是我想将其转换为可用于“调色”seaborn 绘图的调色板。这可能吗?如果可能的话,怎么可能? 我用过... cmap = pl.colors.LinearSegm
我需要动态生成自定义调色板来为我的 Angular 应用配置主题。 可用的默认 Material 调色板:https://material.io/guidelines/style/color.html
首先,我从未使用过 Palette,当我想开始使用它时,我看到所有教程和博客都在谈论 v21 而不是 v22。 我的问题是我有一个 Swatch(在 swatch 数组 [palette.getSwa
我如何使用此工具中没有的颜色构建自定义 MDL:https://getmdl.io/customize/index.html 我想要那些颜色: 原色:红色 400 (#EF5350) 二次色:琥珀色
如何知道调色板png是否带有alpha?我获取有关图像 png_get_IHDR 的信息 之后我查看color_type - PNG_COLOR_TYPE_PALETTE 但是我找不到如何知道这个 p
有没有一种简单的方法可以将真彩色图像(在本例中为 24 位,位图)转换为 1Bpp 图像(调色板,转换为位图)。 我知道 imagemagick convert 可以进行转换,但出于某种原因,当我尝试
我是一名优秀的程序员,十分优秀!