IT博客汇
  • 首页
  • 精华
  • 技术
  • 设计
  • 资讯
  • 扯淡
  • 权利声明
  • 登录 注册

    哇哦,font-palette支持动画和palette-mix()混合函数了

    张 鑫旭发表于 2024-12-04 15:39:06
    love 0

    by zhangxinxu from https://www.zhangxinxu.com/wordpress/?p=11447
    本文可全文转载,独立域名个人网站无需授权,但需要保留原作者、出处以及文中链接,任何网站均可摘要聚合,商用请联系授权。

    封面图

    一、温故而知新

    在学习本文内容之前,大家有必要先了解彩色字体与font-palette属性,见此文:“超酷!CSS font-palette与彩色字体显示”

    不然,本文的这些内容学习起来会比较吃力。

    什么内容呢?

    介绍font-palette属性两个全新的特性,支持animation和palette-mix()函数。

    其兼容性如下:

    font-palette新特性兼容性

    目前Chrome浏览器已经支持,下面花几分钟时间快速了解下这两个特性的作用和样式表现。

    二、palette-mix()混合函数

    palette-mix()函数可以对两个不同的调色板色值进行混合,支持多种颜色模式,语法参考:

    /* 混合字体定义的调色板 */
    font-palette: palette-mix(in lch, normal, dark)
    
    /* 混合开发者定义的调色板 */
    font-palette: palette-mix(in lch, --blues, --yellows)
    
    /* 每种调色板混合的百分比各不相同 */
    font-palette: palette-mix(in lch, --blues 50%, --yellows 50%)
    font-palette: palette-mix(in lch, --blues 70%, --yellows 30%)
    
    /* 变色插值法 */
    font-palette: palette-mix(in srgb, --blues, --yellows)
    font-palette: palette-mix(in hsl, --blues, --yellows)
    font-palette: palette-mix(in hsl longer hue, --blues, --yellows)

    使用更简介的参数表示则为:

    palette-mix(method, palette1 [percent1], palette2 [percent2])

    其中:

    method
    表示颜色混合的方法,全称“颜色插值法”,你可以理解为颜色混合的算法,这个比较复杂,涉及多种颜色空间,如srgb, srgb-linear, display-p3, a98-rgb, prophoto-rgb, rec2020, lab, oklab, xyz, xyz-d50, xyz-d65等,之前我应该介绍过,啊,是这篇文章:“是时候介绍这几个全新的CSS颜色函数了”。

    我们平时开发,使用srgb应该就足够了,学习和使用成本最低。具体语法需要使用单词in,有两种用法:

    in <rectangular-color-space>
    // 或者
    in <polar-color-space>[ <hue-interpolation method>]

    具体用法见上一篇介绍color-mix()函数的文章“CSS好用的color-mix颜色函数也可以使用啦”,这里不展开。

    palette1、palette2
    @font-palette-values定义的调色板,或者内置的调色板(normal, dark)等。
    percent1、percent2
    指对应色板颜色混合的占用百分百,可选。具体规则如下:
    • 如果不设置,各自50%;
    • 只设置一个,另外一个自动100%补全;
    • 都是0%是不合法的;
    • 均设置,但总和不是100%,则最终的百分比值按比例分配。

    OK,下面看使用效果:

    @font-face {
      font-family: 'Rocher';
      src: url(./RocherColorGX.woff2);
    }
    h4 {
      font-family: 'Rocher';
      font-size: 40px;
    }
    @font-palette-values --Purples {
      font-family: Rocher;
      base-palette: 6;
    }
    @font-palette-values --Mint {
      font-family: Rocher;
      base-palette: 7;
    }
    /* 紫色和薄荷色主题颜色 */
    .purples {
      font-palette: --Purples;
    }
    .mint {
      font-palette: --Mint;
    }
    /* 混合上面两种主题 */
    .mixed {
      font-palette: palette-mix(in srgb, --Purples, --Mint)
    }

    于是,下面的HTML代码就会有下图所示的渲染效果:

    <h4 class="purples">Color fonts(紫色系)</h4>
    <h4 class="mint">Color fonts(薄荷色系)</h4>
    
    混合后的效果
    
    <h4 class="mixed">Color fonts(混合色系)</h4>

    颜色混合后的效果

    可以看到混合后的颜色是紫色和薄荷色的混合体。

    眼见为实,如果是Chrome浏览器,您可以狠狠地点击这里:CSS palette-mix()函数彩色字体颜色混合demo

    三、酷酷的调色板动画

    这个好理解,就是font-palette属性可以用在CSS animation属性中了,例如:

    @keyframes animate-palette {
      from {
        font-palette: --themeA;
      }
      to {
        font-palette: --themeB;
      }
    }

    自然,transition属性也不在话下,我们看一个案例,使用和上面案例一样的彩色字体,然后@font-face规则和@font-palette-values规则的代码是一样的,因此,不重复展示:

    h4 {
      font-family: 'Rocher';
      font-size: 40px;
      transition: font-palette 1s;
    }
    .purples2mint {
      font-palette: --Purples;
    }
    .purples2mint:hover,
    .purples2mint:active {
      font-palette: --Mint;
    }

    此时,选择器匹配h4.purples2mint的元素在鼠标悬停或者按下的时候,就会有彩色字体基础色板颜色的过渡动画效果了。

    <h4 class="purples2mint">Color fonts(过渡动画)</h4>

    如下MP4录屏所示(不动点击播放):

    如果您当前访问的Chrome浏览器,您可以狠狠地点击这里:CSS font-palette实现色彩字体transition动画demo

    四、好啦,就说这么多

    这个新特性呢,很有趣。

    但是在中文场景下,要想大规模使用,不太可能。

    最主要的原因是缺少中文的彩色字体。

    更适合用在,缺少HTML标签场景下的,数字或字母的特效效果实现。

    比方说很神奇的代码高亮效果(纯字体实现):

    代码高亮截图示意

    详见xboxyan的这篇文章“太神奇了,仅使用彩色字体实现代码高亮”

    以上就是本文全部内容,感谢阅读,欢迎,让更多的小伙伴知道此特性,万一以后就用到呢?

    感谢

    本文为原创文章,会经常更新知识点以及修正一些错误,因此转载请保留原出处,方便溯源,避免陈旧错误知识的误导,同时有更好的阅读体验。
    本文地址:https://www.zhangxinxu.com/wordpress/?p=11447

    (本篇完)



沪ICP备19023445号-2号
友情链接