百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

CSS小技巧使用 font-variation 让文字起飞

myzbx 2025-02-13 13:14 16 浏览

今天逛codepen的时候发现了一个不错的文字动画效果,如此丝滑飘逸的效果必须得研究研究,可以看到字体粗细切换过渡效果很均匀,不像我们平常使用字体时设置 font-weight 的效果,日常设置字重的时候并不是每个值都会生效,只会有几个区间的值是可用的,以下代码给6个p标签设置font-weight 从 100 到 600:

@for $i from 1 through 6 {
  p:nth-child(#{$i}) {
    font-weight: 100 + 100 * ($i - 1);
  }
}

可以看到并不是每个阶段字重都有变化的,当然这和不同的字体和是否中英文有一定的关系,但是设置字重的效果都是不够理想的状态。

这里就要引出今天文章所讲的可变字体了,基于可变字体(font-variation)将不再有这种困扰,当然也会有一定的弊端。

什么是可变字体

可变字体(Variable Fonts),也称为多轴字体、自由度字体或超级字体,是一种新兴的字体技术,它是一种可以在多个自由度上进行动态调整的字体格式。与传统字体不同的是,「可变字体能够在单个字体文件中包含多种字重、宽度、倾斜和其他轴的变体,而不需要使用多个不同的字体文件」

简单理解可变字体就是通过使用可变字体,所有字重、字宽、斜体等情况的组合都可以被装在一个文件中。相应的弊端就是这个文件可能比常规的单个字体文件更大了。

可变字体支持使用font-variation-settings属性来控制字体的各种轴,通过调整这些轴的值,可以实现自定义字体样式的效果。

以下设置一个可变字体的粗细从 100 到 600,

font-variation-settings: "wght" 100, "ital" 0;

可以看到这次的字体是均匀的变化粗细,就如同设置 font-weight: 100font-weight: 600 的逐渐变化。

可变字体浏览器兼容情况,可以看到基本的浏览器都已经支持。

如何使用

这个是根据字体的设计者来决定,字体的设计提供了各种各种可以被修改的轴,比如粗细,长短以及任何合理范畴之内的。下面提供几个常用的保留轴:

  • wdth: 用于修改字的宽窄
  • wght: 用于修改字的粗细
  • ital: 是否倾斜,0为非倾斜,1为斜体
  • slnt: 用于修改字的倾斜程度
  • opsz: 对于字形的修改

找到可用的可变字体

如果你想要使用它,你首先要找到相关字体资源。在这个网站 v-fonts.com 你能找到很多可变字体,很多都是在github开源,并且可以直接下载的。

在CSS中使用

通过@font-face引入到页面内:

@font-face {
    font-family: 'VennVF';
    src: url('VennVF_W.woff2') format('woff2-variations'),
        url('VennVF_W.woff2') format('woff2');
}

每个可变字体都有不同的轴和不同的范围,如果你不知道可变字体能做什么改变,你可以使用这个(wakamaifondue.com)在线工具,可以帮你生成现成的css使用。

目前可以通过font-variation-settings属性,我们可以方便地控制自定义字体的不同轴,比如设置如下代码:

p {
 font-family: "VennVF";
 font-variation-settings: "wght" 550, "wdth" 125;
}

这段代码改变字体粗细为550,还有宽窄为125。在未来可能可以使用以下属性来得到同样的效果:

p {
 font-family: "VennVF";
 font-weight: 550;
 font-stretch: 125%;
}

如下所示是一个例子:

h1 {
  font-family: 'Inter Variable', sans-serif;
  font-variation-settings: 
    "wght" 700, 
    "ital" 1, 
    "opsz" 48;
}

在这个例子中,我们将可变字体‘Inter’设置为700字重、1倾斜度和48像素字号的标题字体。可以看到,通过font-variation-settings属性,我们可以方便地控制自定义字体的不同轴,实现更加细腻、灵活的排版效果。

首图实现代码

首图的字体有如同呼吸,飘逸的感觉,核心是基于可变字体改变字体的粗细,并给不同的字符增加不同的延迟动画效果即可达到最终的效果。

  • 改变字体粗细animation动画
@keyframes change {
  0% {
    font-variation-settings: "wght" 900, "ital" 1;
  }

  50% {
    font-variation-settings: "wght" 100, "ital" 0;
  }

  100% {
    font-variation-settings: "wght" 900, "ital" 1;
  }
}
  • animation动画执行相关参数
  animation-duration: 3s;
  animation-iteration-count: infinite;
  animation-name: change;
  transition-timing-function: ease-in-out;
  • 这里实现的每一个文字都是一个标签,所以给每一个文字都增加了不同的延迟执行动画时间
  @for $line from 1 through 4 {
    @for $letter from 1 through 10 {
      &:nth-child(#{$line}) span:nth-child(#{$letter}) {
        animation-delay: #{$letter * 0.1s + $line * 0.2s};
      }
    }
  }

代码并不多,但实现的效果很不错,基于可变字体设计,我们可以实现更加智能、美观、易读的排版效果,让文字内容更加生动、丰富。

在线效果预览:https://code.juejin.cn/pen/7234826432050888765

使用案例

以下是一些看到的案例效果,供大家参考。

国内常用的中文字体思源黑体也支持可变字体。

这个Google动画和本文头图的效果类似,给不同的字符加了不同的延迟加粗字体动画。

这个效果通过改变不同单词的可变字体的字重和宽窄呈现出一种不一样的效果。

以下的几个效果图都来源于v-fonts.com,诸如此类的效果还有很多,总共可变字体有三百多个,大家有兴趣的可以去找找看。

通过改变animation值可以让小图标动起来,是不是打开了很多新的思路。

这个字体比较有特色,大写字母是在上方有一根长长的线,小写字母是在下方有一根线,通过调整tracking轴的数值可以改变横线的长度。

这个字体就是一条波浪线,通过调整Width轴可以改变波浪的大小和幅度,都可以基于这个可变字体做水波纹效果了。

最后

关于可变字体的详细介绍使用大家可以看这篇文章 「variable fonts - 更小更灵活的字体」。可变字体的设计让文字内容更加生动、丰富,有兴趣的朋友可以试试看~

看完本文如果觉得有用,记得点个赞支持,收藏起来说不定哪天就用上啦~

「专注前端开发,分享前端相关技术干货,公众号:南城大前端(ID: nanchengfe)」

参考

variable fonts - 更小更灵活的字体:github.com/FoxDaxian/memory/issues/4

Variable Font Animation: codepen.io/typeforward/pen/abRpoxV

相关推荐

Nextoffer极客编程挑战#022:使用HTML5画布生成文字淡入淡出效果

给定如下HTML:<divid="container"><canvasid="MyCanvas"width="350"height="200">不支持HTML5画布&l...

AI在线智能问答+Python实现(ai问答机器人)

人生苦短,我用Python!嗨,我是浪仔,你的Python造梦师~今天让我们一起来开发一款AI智能问答小工具!本小工具是一款基于Python编程语言开发的AI在线智能问答平台,采用爬虫采集数据...

OpenAI发布新功能——Canvas,写作+编程能力超级提升

阅读此文前,麻烦您点击一下“关注”,方便您进行讨论和分享。此文仅在今日头条发布,任何平台不得搬运,搬运必究!OpenAI发布新功能——Canvas,写作+编程能力超级提升OpenAI的Canvas...

英伟达最新AI技术可将文字转化为逼真的图像

英伟达的GauGAN技术已经展示了它的能力--将简单的草图变成逼真的图像。从那时起,我们看到它被应用于NVIDIACanvas,但似乎这家GPU巨头正在用其人工智能(AI)瞄准更高的目标,其推出了一...

OpenAI技术直播第四弹!推出ChatGPT内置工具Canvas,有三大核心功能

每经编辑:毕陆名昨天的Sora掀起热潮,今天OpenAI又给我们带来了升级版Canvas。Canvas正式向所有用户开放,并与OpenAI的主要模型深度集成。Canvas内置在ChatGPT中,打开C...

怎样设置EditText内部文字被锁定不可删除和修改

在做项目的时候,我曾经遇到过这样的要求,就是跟百度贴吧客户端上的一样,在回复帖子的时候,在EditText中显示回复人的名字,而且这个名字不可以修改和删除,说白了就是不可操作,只能在后面输入内容。在E...

微信小程序canvas使用(小程序canvas生成图片并保存)

在微信小程序中,你可以通过以下步骤使用canvas:在index.wxml文件中添加canvas元素。例如:。在index.js文件中,通过wx.createSelectorQuery()获取canv...

我尝试了ChatGPT Canvas,让写作和编码变得更简单

#头条精品计划#快速导读ChatGPT画布界面旨在提升写作和编码体验,特别是为ChatGPTPlus和Team订阅者提供的功能。用户可以利用人工智能优化文本和代码,提高工作效率。画布界面...

ChatGPT推出Canvas界面:让编写和编码变得更容易

鞭牛士报道,10月5日消息,据外电报道,OpenAI为ChatGPT推出了全新的“Canvas”界面,允许用户在并排协作中调整聊天机器人生成的文本或代码部分。Canvas在现有的ChatG...

鸿蒙开发之绘制文字(fillText 和 stroke)

在HarmonyOS中,使用TS(TypeScript)语法进行画布(Canvas)开发时,fillText和strokeText是两个常用的方法,分别用于填充文本和绘制文本边框。以下是这两个方法的详...

Canvas编写Python代码也太好用了!

大家知道这个月OpenAI密集发布新产品,连续12天以短视频方式每天公布一个产品功能。这两天,OpenAI公布了新的功能Canvas,顾名思义,Canvas是画布的意思,这是一个使用ChatGPT协作...

五子棋游戏(五子棋游戏网页版)

完整的游戏功能:黑白双方轮流下棋自动判定胜负支持重新开始游戏美观的界面:标准的15×15棋盘棋盘带有网格线和五个星位点棋子使用渐变效果,看起来更立体状态显示清晰用户友好:实时显示当前回合信息有效的落子...

利用Photoshop制作专业展板的详细指南与技巧分享

怎么用PS做展板(HowtoCreateaDisplayBoardUsingPhotoshop)  在现代设计中,AdobePhotoshop(通常简称为PS)是一个强大的工具,广泛...

Android 开发中文引导-动画和图形概述

安卓系统提供了各种强大的API,用来将动画应用于界面元素和自定义2D和3D图形的绘制当中。下面的小节大概的描述了可用的API和系统功能并帮助你决定那个方案最适合你的需要。动画安卓框架提供了两种动画系统...

小白鞋过时了?早着呢!(小白鞋2020)

在巴黎待了好几天了。这次是受爱马仕邀请来看它家2017秋冬女装秀的。昨天看完,本想今天就来跟大家分享我秀场见闻。但今天还要参观爱马仕皮具工坊、新品陈列室,明天再一次性地跟你们分享吧。就先发之前准备好的...