主頁 > 企業開發 > 突破限制,CSS font-variation 可變字體的魅力

突破限制,CSS font-variation 可變字體的魅力

2022-03-01 06:29:28 企業開發

今天,在 CodePen 上看到一個很有意思的效果 -- GSAP 3 ETC Variable Font Wave,借助了 JS 影片庫 GSAP 實作,一起來看看:

我尋思著能否使用 CSS 復刻一版,鼓搗了一會,利用純 CSS 成功實作了原效果,

上述效果,最核心的就是文字的影片,文字從較細貼著較緊,到較粗隔著較遠不斷變化,有人會認為這里是 transform: scale(),實則不然,

scale 是等比例放大縮小一個物體,而仔細觀察上述效果,明顯是有字體的粗細、字體的字寬的變化,這里,其實用到了 CSS 比較新的特性 -- 可變字體,也就是 font-variation

本文,將借助這個效果,介紹一下什么是 CSS font-variation,

什么是 CSS font-variation,可變字體?

根據 MDN -- Variable fonts,可變字體(Variable fonts)是 OpenType 字體規范上的演進,它允許將同一字體的多個變體統合進單獨的字體檔案中,從而無需再將不同字寬、字重或不同樣式的字體分割成不同的字體檔案,我們只需通過CSS與一行 @font-face 參考,即可獲取包含在這個單一檔案中的各種字體變體,

emm,概念有點難理解,簡單解釋一下,

與可變字體對應的,是標準(靜態)字體,

標準(靜態)字體就是只代表字體的某一特定的寬度/字重/樣式的組合的字體檔案,通常我們在頁面引入的字體檔案都是這種,只代表這個字體的某一特定的寬度/字重/樣式的組合,

而如果我們想引入一個字體家族(譬如 Roboto 字體族),它可能包含了 “Roboto Regular”(常規字重)、“Roboto Bold”(粗體),或是 “Roboto Bold Italic”(粗體+斜體) 等一系列字體檔案,這意味著我們可能需要 20 或 30 個不同的字體檔案才能算是有了一整個字體家族(對于有著不同寬度的大型字體來說,這個數量還要翻上幾倍),

而可變字體 -- font-variation,可以將它理解為 all in one,通過使用可變字體,所有字重、字寬、斜體等情況的排列組合都可以被裝進一個檔案中,當然,這個檔案可能比常規的單個字體檔案大一些,

靜態字體的局限性

舉個例子,在 Google Font,我隨便選取一個標準靜態字體,實作一個字體 font-weight 的變化影片:

<p>CSS font-variation</p>
<p>CSS font-variation</p>
<p>CSS font-variation</p>
<p>CSS font-variation</p>
<p>CSS font-variation</p>
<p>CSS font-variation</p>
@import url('https://fonts.googleapis.com/css2?family=Lato:wght@300&display=swap');
p {
    font-family: 'Lato', sans-serif;
    font-size: 48px;
}
p:nth-child(1) {
    font-weight: 100;
}
p:nth-child(2) {
    font-weight: 200;
}
p:nth-child(3) {
    font-weight: 300;
}
p:nth-child(4) {
    font-weight: 400;
}
p:nth-child(5) {
    font-weight: 500;
}
p:nth-child(6) {
    font-weight: 600;
}

看看結果:

并沒有我們想象中的,因為字體粗細從 100 到 600,所以字體依次變粗的情況,一共只有兩種字重:

  1. font-weight: 處于 100 - 500 的時候,其實都是 font-weight: normal;
  2. font-weight: 600 的時候,其實是命中了 font-weight: bold

這個也就是傳統靜態字體的局限性,單一字體檔案中,其實是不會有該字體的所有粗細、字寬的型別的,

可變字體的多樣性

接下來,我們換上可變字體,

加載可變字體的語法與其他 web 字體非常相似,但有一些顯著的差異,這些差異是通過對現代瀏覽器中可用的傳統 @font-face 語法的升級提供的,

基本語法是相同的,但是字體技術是不一樣的,并且可變字體可以提供像對 font-weightfont-stretch 等描述符的允許范圍,而不是根據加載的字體檔案來命名,

下面,我們將加載一個支持字體粗細從 100900,字體伸縮變形支持從 10%400%AnyBody 可變字體,

@font-face {
	font-family: 'Anybody';
	src: url('https://s3-us-west-2.amazonaws.com/s.cdpn.io/61488/ETCAnybodyPB.woff2') format('woff2-variations');
	font-display: block;
	font-style: normal italic;
	font-weight: 100 900;
	font-stretch: 10% 400%;
}
p {
    font-family: 'Anybody', sans-serif;
    font-size: 48px;
}
p:nth-child(1) {
    font-weight: 100;
}
// ...
p:nth-child(6) {
    font-weight: 600;
}

同樣是設定字體粗細從 100 - 600,效果如下:

這一次,可以看到,字體有明顯的均勻變化,支持 font-weight: 100font-weight: 600 的逐漸變化,這兒就是可變字體的魅力,

理解 font-variation-settings

除了直接通過 font-weight 去控制可變字體的粗細,CSS 還提供了一個新的屬性 font-variation-settings 去同時控制可變字體的多個屬性,

可變字體新格式的核心是可變軸的概念,其描述了字體設計中某一特性的允許變化范圍,

所有可變字體都有至少有 5 個可以通過 font-variation-settings 控制的屬性軸,它們屬于注冊軸(registered),能夠映射現有的 CSS 屬性或者值,

它們是:

  • 字重軸 "wght":對應 font-weight,控制字體的粗細
  • 寬度軸 "wdth":對應 font-stretch,控制字體的伸縮
  • 斜度軸 "slnt" (slant):對應字體的 font-style: oblique + angle,控制字體的傾斜
  • 斜體軸 "ital":對應字體的 font-style: italic,控制字體的傾斜(注意,和 font-style: oblique 是不一樣的傾斜)
  • 光學尺寸軸 "opsz":對應字體的 font-optical-sizing,控制字體的光學尺寸

好吧,可能會有一點點懵,沒事,通過一個例子馬上就能理解什么意思,

還是利用上述的可變字體,我們利用 font-variation-settings 實作一個字體粗細的變化的影片:

<p>Anybody</p>
@font-face {
	font-family: 'Anybody';
	src: url('https://s3-us-west-2.amazonaws.com/s.cdpn.io/61488/ETCAnybodyPB.woff2') format('woff2-variations');
	font-display: block;
	font-style: normal italic;
	font-weight: 100 900;
	font-stretch: 10% 400%;
}
p {
    font-family: 'Anybody';
    font-size: 48px;
    animation: fontWeightChange 2s infinite alternate linear;
}
@keyframes fontWeightChange {
    0% {
        font-variation-settings: 'wght' 100;
    }
    100% {
        font-variation-settings: "wght" 600;
    }
}

效果如下:

其中,其實可以理解為,利用了 font-variation-settings: "wght" 的變化的影片,等同于 font-weight 變化影片:

利用 font-variation-settings 進行字體的多個特征同時變化

OK,那么如果既然是一樣的效果,為什么還要多此一舉搞個 font-variation-settings 呢?

那是因為 font-variation-settings 除了支持字體的粗細變化外,還支持上述說的注冊軸設定的多個樣式屬性變化,以及自定義軸的一些字體樣式屬性變化,

這次,除了字體粗細外,我們再添加上 "wdth" 的變化,也就是字體的伸縮,

<p>Anybody</p>
@font-face {
	font-family: 'Anybody';
	src: url('https://s3-us-west-2.amazonaws.com/s.cdpn.io/61488/ETCAnybodyPB.woff2') format('woff2-variations');
	font-display: block;
	font-style: normal italic;
	font-weight: 100 900;
	font-stretch: 10% 400%;
}
p {
    font-family: 'Anybody';
    font-size: 48px;
    animation: fontWeightChange 2s infinite alternate linear;
}
@keyframes fontWeightChange {
    0% {
        font-variation-settings: 'wght' 100, 'wdth' 60;
    }
    100% {
        font-variation-settings: "wght" 600, 'wdth' 400;
    }
}

這次,進行的是字體粗細從 100 到 600,字體伸縮從 60% 到 400% 的影片效果,效果如下:


也就是說,font-variation-settings 是同時支持多個字體樣式一起變化的,這一點非常重要,

到這里,其實我們已經可以利用這個實作題圖所示的效果了,我們簡單改造下,添加多行,再給每行設定一個負的影片延遲即可:

<div >
    <ul>
        <li>ANYBODY</li>
        <li>ANYBODY</li>
        <li>ANYBODY</li>
        <li>ANYBODY</li>
        <li>ANYBODY</li>
        <li>ANYBODY</li>
        <li>ANYBODY</li>
        <li>ANYBODY</li>
    </ul>
</div>

借助 SCSS 簡化下代碼,下述代碼核心就是給每個 li,添加一個相同的影片 font-variation-settings 影片,并且依次設定了等差的 animation-delay

li {
    animation: change 0.8s infinite linear alternate;
}
@for $i from 1 to 9 {
    li:nth-child(#{$i}) {
        animation-delay: #{($i - 1) * -0.125}s;
    }
}
@keyframes change {
    0% {
        font-variation-settings: 'wdth' 60, 'wght' 100;
        opacity: .5;
    }
    100% {
        font-variation-settings: 'wdth' 400, 'wght' 900;
        opacity: 1;
    }
}

效果如下:

好,接下來,利用 CSS 3D 簡單構造一下 3D 場景即可,完整的 CSS 代碼如下:

@font-face {
	font-family: 'Anybody';
	src: url('https://s3-us-west-2.amazonaws.com/s.cdpn.io/61488/ETCAnybodyPB.woff2') format('woff2-variations');
	font-display: block;
	font-style: normal italic;
	font-weight: 100 900;
	font-stretch: 10% 400%;
}
.g-container {
    position: relative;
    margin: auto;
    display: flex;
    font-size: 48px;
    font-family: 'Anybody';
    color: #fff;
    transform-style: preserve-3d;
    perspective: 200px;
}
ul {
    background: radial-gradient(farthest-side at 110px 0px, rgba(255, 255, 255, 0.2) 0%, #171717 100%);
    padding: 5px;
    transform-style: preserve-3d;
    transform: translateZ(-60px) rotateX(30deg) translateY(-30px);
    animation: move 3s infinite alternate;
    
    &::before {
        content: "";
        position: absolute;
        left: 0;
        bottom: 0;
        right: 0;
        height: 45px;
        background: #141313;
        transform: rotateX(-230deg);
        transform-origin: 50% 100%;
    }
}
li {
    width: 410px;
    animation: change 0.8s infinite linear alternate;
}
@for $i from 1 to 9 {
    li:nth-child(#{$i}) {
        animation-delay: #{($i - 1) * -0.125}s;
    }
}
@keyframes change {
    0% {
        font-variation-settings: 'wdth' 60, 'wght' 100;
        opacity: .5;
    }
    100% {
        font-variation-settings: 'wdth' 400, 'wght' 900;
        opacity: 1;
    }
}
@keyframes move {
    100% {
        transform: translateZ(-60px) rotateX(30deg) translateY(0px);
    }
}

效果如下,我們就基本還原了題圖的效果:

完整的代碼及 DEMO 效果你可以戳這里:CodePen Demo -- Pure CSS Variable Font Wave

font-variation 的可變軸 -- 注冊軸與自定義軸

回歸到可變字體本身,上面提到了可變軸這個概念,它們分為注冊軸自定義軸,英文是:

  • 注冊軸 - registered axes
  • 自定義軸 - custom axes

可變字體新格式的核心是可變軸的概念,其描述了字體設計中某一特性的允許變化范圍,

例如‘字重軸’描述了字體的粗細;“寬度軸”描述了字體的寬窄;“斜體軸”描述是否使用斜體字形并且可相應地開關;等,請注意,軸既可以是范圍選擇又可以是開關選擇,字重可能在1-999之間,而斜體可能只是簡單的0或1(關倍訓打開),

如規范中所定義,存在兩種變形軸,注冊軸和自定義軸:

  • 注冊軸最為常見,常見到制定規范的作者認為有必要進行標準化, 目前注冊的五個軸是字重,寬度,傾斜度,斜體和光學尺寸,

上文其實已經羅列了 5 個注冊軸,并且簡單介紹了它們的使用,再羅列一次:

  1. 字重軸 "wght":對應 font-weight,控制字體的粗細
  2. 寬度軸 "wdth":對應 font-stretch,控制字體的伸縮
  3. 斜度軸 "slnt" (slant):對應字體的 font-style: oblique + angle,控制字體的傾斜
  4. 斜體軸 "ital":對應字體的 font-style: italic,控制字體的傾斜(注意,和 font-style: oblique 是不一樣的傾斜)
  5. 光學尺寸軸 "opsz":對應字體的 font-optical-sizing,控制字體的光學尺寸
  • 自定義軸實際上是無限的:字體設計師可以定義和界定他們喜歡的任何軸,并且只需要給它一個四個字母的標簽以在字體檔案格式本身中識別它,

我們來看一個 自定義軸 的例子:

<p>Grade</p>
p {
    font-family: "Amstelvar VF", serif;
    font-size: 64px;
    font-variation-settings: 'GRAD' 88;
}

上述 font-family: "Amstelvar VF" 是一個可變字體,而 'GRAD' 屬于自定義軸的一個,意為等級軸

  • 等級軸 'GRAD':“等級”一詞指的是字體設計的相對重量或密度,但與傳統的“重量”不同之處在于文本占據的物理空間不會改變,因此改變文本等級并不會改變文本或其周圍元素的整體布局, 這使得等級成為有用的變化軸,因為它可以變化或影片而不會引起文本本身的回流,

MDN 上有關于改變 'GRAD' 的值,對應字體變化的一個 DEMO,效果如下:

值得注意的是,自定義軸可以是字體設計師想象的任何設計變化軸,可能有一些會逐漸變得相當普遍,隨著規范的發展甚至演變成注冊軸,

去哪找可變字體?

OK,如果現在我想在業務中使用一下可變字體,去實作一個效果或者影片,可以上哪里尋找可變字體的資源呢?

這里有一個很不錯的網站 -- Variable Fonts,

上面收集了非常多的 Variable Fonts,并且羅列出了它們在注冊軸上支持的字體屬性的范圍,譬如支持字重從 100 到 700,我們可以自由進行除錯預覽

Can i Use(2022-02-20)

現在能夠開始使用可變字體了嗎?

截止至今天,Can i Use 的截圖:

兼容性已經非常的不錯了,不考慮 IE 系列的話可以上到實際的生產環境中去,

最后

本文到此結束,希望對你有幫助 ??

更多精彩 CSS 技術文章匯總在我的 Github -- iCSS ,持續更新,歡迎點個 star 訂閱收藏,

如果還有什么疑問或者建議,可以多多交流,原創文章,文筆有限,才疏學淺,文中若有不正之處,萬望告知,

轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/434446.html

標籤:其他

上一篇:JS中陣列原型方法總結

下一篇:細聊正則運算式(附demo)

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • IEEE1588PTP在數字化變電站時鐘同步方面的應用

    IEEE1588ptp在數字化變電站時鐘同步方面的應用 京準電子科技官微——ahjzsz 一、電力系統時間同步基本概況 隨著對IEC 61850標準研究的不斷深入,國內外學者提出基于IEC61850通信標準體系建設數字化變電站的發展思路。數字化變電站與常規變電站的顯著區別在于程序層傳統的電流/電壓互 ......

    uj5u.com 2020-09-10 03:51:52 more
  • HTTP request smuggling CL.TE

    CL.TE 簡介 前端通過Content-Length處理請求,通過反向代理或者負載均衡將請求轉發到后端,后端Transfer-Encoding優先級較高,以TE處理請求造成安全問題。 檢測 發送如下資料包 POST / HTTP/1.1 Host: ac391f7e1e9af821806e890 ......

    uj5u.com 2020-09-10 03:52:11 more
  • 網路滲透資料大全單——漏洞庫篇

    網路滲透資料大全單——漏洞庫篇漏洞庫 NVD ——美國國家漏洞庫 →http://nvd.nist.gov/。 CERT ——美國國家應急回應中心 →https://www.us-cert.gov/ OSVDB ——開源漏洞庫 →http://osvdb.org Bugtraq ——賽門鐵克 →ht ......

    uj5u.com 2020-09-10 03:52:15 more
  • 京準講述NTP時鐘服務器應用及原理

    京準講述NTP時鐘服務器應用及原理京準講述NTP時鐘服務器應用及原理 安徽京準電子科技官微——ahjzsz 北斗授時原理 授時是指接識訓通過某種方式獲得本地時間與北斗標準時間的鐘差,然后調整本地時鐘使時差控制在一定的精度范圍內。 衛星導航系統通常由三部分組成:導航授時衛星、地面檢測校正維護系統和用戶 ......

    uj5u.com 2020-09-10 03:52:25 more
  • 利用北斗衛星系統設計NTP網路時間服務器

    利用北斗衛星系統設計NTP網路時間服務器 利用北斗衛星系統設計NTP網路時間服務器 安徽京準電子科技官微——ahjzsz 概述 NTP網路時間服務器是一款支持NTP和SNTP網路時間同步協議,高精度、大容量、高品質的高科技時鐘產品。 NTP網路時間服務器設備采用冗余架構設計,高精度時鐘直接來源于北斗 ......

    uj5u.com 2020-09-10 03:52:35 more
  • 詳細解讀電力系統各種對時方式

    詳細解讀電力系統各種對時方式 詳細解讀電力系統各種對時方式 安徽京準電子科技官微——ahjzsz,更多資料請添加VX 衛星同步時鐘是我京準公司開發研制的應用衛星授時時技術的標準時間顯示和發送的裝置,該裝置以M國全球定位系統(GLOBAL POSITIONING SYSTEM,縮寫為GPS)或者我國北 ......

    uj5u.com 2020-09-10 03:52:45 more
  • 如何保證外包團隊接入企業內網安全

    不管企業規模的大小,只要企業想省錢,那么企業的某些服務就一定會采用外包的形式,然而看似美好又經濟的策略,其實也有不好的一面。下面我通過安全的角度來聊聊使用外包團的安全隱患問題。 先看看什么服務會使用外包的,最常見的就是話務/客服這種需要大量重復性、無技術性的服務,或者是一些銷售外包、特殊的職能外包等 ......

    uj5u.com 2020-09-10 03:52:57 more
  • PHP漏洞之【整型數字型SQL注入】

    0x01 什么是SQL注入 SQL是一種注入攻擊,通過前端帶入后端資料庫進行惡意的SQL陳述句查詢。 0x02 SQL整型注入原理 SQL注入一般發生在動態網站URL地址里,當然也會發生在其它地發,如登錄框等等也會存在注入,只要是和資料庫打交道的地方都有可能存在。 如這里http://192.168. ......

    uj5u.com 2020-09-10 03:55:40 more
  • [GXYCTF2019]禁止套娃

    git泄露獲取原始碼 使用GET傳參,引數為exp 經過三層過濾執行 第一層過濾偽協議,第二層過濾帶引數的函式,第三層過濾一些函式 preg_replace('/[a-z,_]+\((?R)?\)/', NULL, $_GET['exp'] (?R)參考當前正則運算式,相當于匹配函式里的引數 因此傳遞 ......

    uj5u.com 2020-09-10 03:56:07 more
  • 等保2.0實施流程

    流程 結論 ......

    uj5u.com 2020-09-10 03:56:16 more
最新发布
  • 使用Django Rest framework搭建Blog

    在前面的Blog例子中我們使用的是GraphQL, 雖然GraphQL的使用處于上升趨勢,但是Rest API還是使用的更廣泛一些. 所以還是決定回到傳統的rest api framework上來, Django rest framework的官網上給了一個很好用的QuickStart, 我參考Qu ......

    uj5u.com 2023-04-20 08:17:54 more
  • 記錄-new Date() 我忍你很久了!

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 大家平時在開發的時候有沒被new Date()折磨過?就是它的諸多怪異的設定讓你每每用的時候,都可能不小心踩坑。造成程式意外出錯,卻一下子找不到問題出處,那叫一個煩透了…… 下面,我就列舉它的“四宗罪”及應用思考 可惡的四宗罪 1. Sa ......

    uj5u.com 2023-04-20 08:17:47 more
  • 使用Vue.js實作文字跑馬燈效果

    實作文字跑馬燈效果,首先用到 substring()截取 和 setInterval計時器 clearInterval()清除計時器 效果如下: 實作代碼如下: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta ......

    uj5u.com 2023-04-20 08:12:31 more
  • JavaScript 運算子

    JavaScript 運算子/運算子 在 JavaScript 中,有一些運算子可以使代碼更簡潔、易讀和高效。以下是一些常見的運算子: 1、可選鏈運算子(optional chaining operator) ?.是可選鏈運算子(optional chaining operator)。?. 可選鏈操 ......

    uj5u.com 2023-04-20 08:02:25 more
  • CSS—相對單位rem

    一、概述 rem是一個相對長度單位,它的單位長度取決于根標簽html的字體尺寸。rem即root em的意思,中文翻譯為根em。瀏覽器的文本尺寸一般默認為16px,即默認情況下: 1rem = 16px rem布局原理:根據CSS媒體查詢功能,更改根標簽的字體尺寸,實作rem單位隨螢屏尺寸的變化,如 ......

    uj5u.com 2023-04-20 08:02:21 more
  • 我的第一個NPM包:panghu-planebattle-esm(胖虎飛機大戰)使用說明

    好家伙,我的包終于開發完啦 歡迎使用胖虎的飛機大戰包!! 為你的主頁添加色彩 這是一個有趣的網頁小游戲包,使用canvas和js開發 使用ES6模塊化開發 效果圖如下: (覺得圖片太sb的可以自己改) 代碼已開源!! Git: https://gitee.com/tang-and-han-dynas ......

    uj5u.com 2023-04-20 08:01:50 more
  • 如何在 vue3 中使用 jsx/tsx?

    我們都知道,通常情況下我們使用 vue 大多都是用的 SFC(Signle File Component)單檔案組件模式,即一個組件就是一個檔案,但其實 Vue 也是支持使用 JSX 來撰寫組件的。這里不討論 SFC 和 JSX 的好壞,這個仁者見仁智者見智。本篇文章旨在帶領大家快速了解和使用 Vu ......

    uj5u.com 2023-04-20 08:01:37 more
  • 【Vue2.x原始碼系列06】計算屬性computed原理

    本章目標:計算屬性是如何實作的?計算屬性快取原理以及洋蔥模型的應用?在初始化Vue實體時,我們會給每個計算屬性都創建一個對應watcher,我們稱之為計算屬性watcher ......

    uj5u.com 2023-04-20 08:01:31 more
  • http1.1與http2.0

    一、http是什么 通俗來講,http就是計算機通過網路進行通信的規則,是一個基于請求與回應,無狀態的,應用層協議。常用于TCP/IP協議傳輸資料。目前任何終端之間任何一種通信方式都必須按Http協議進行,否則無法連接。tcp(三次握手,四次揮手)。 請求與回應:客戶端請求、服務端回應資料。 無狀態 ......

    uj5u.com 2023-04-20 08:01:10 more
  • http1.1與http2.0

    一、http是什么 通俗來講,http就是計算機通過網路進行通信的規則,是一個基于請求與回應,無狀態的,應用層協議。常用于TCP/IP協議傳輸資料。目前任何終端之間任何一種通信方式都必須按Http協議進行,否則無法連接。tcp(三次握手,四次揮手)。 請求與回應:客戶端請求、服務端回應資料。 無狀態 ......

    uj5u.com 2023-04-20 08:00:32 more