日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當(dāng)前位置:首頁(yè) > 科技  > 軟件

CSS單標(biāo)簽實(shí)現(xiàn)轉(zhuǎn)轉(zhuǎn)logo

來(lái)源: 責(zé)編: 時(shí)間:2023-08-05 11:44:38 4972觀看
導(dǎo)讀轉(zhuǎn)轉(zhuǎn)品牌升級(jí)后更新了全新的Logo,今天我們用純CSS來(lái)實(shí)現(xiàn)轉(zhuǎn)轉(zhuǎn)的新Logo,為了有一定的挑戰(zhàn)性,這里我們只使用一個(gè)標(biāo)簽實(shí)現(xiàn),將最大化的使用CSS能力完成Logo的繪制與動(dòng)畫效果。新logo保留了原本logo里轉(zhuǎn)轉(zhuǎn)熊的輪廓,兩個(gè)熊耳是兩

轉(zhuǎn)轉(zhuǎn)品牌升級(jí)后更新了全新的Logo,今天我們用純CSS來(lái)實(shí)現(xiàn)轉(zhuǎn)轉(zhuǎn)的新Logo,為了有一定的挑戰(zhàn)性,這里我們只使用一個(gè)標(biāo)簽實(shí)現(xiàn),將最大化的使用CSS能力完成Logo的繪制與動(dòng)畫效果。hgq28資訊網(wǎng)——每日最新資訊28at.com

新logo保留了原本logo里轉(zhuǎn)轉(zhuǎn)熊的輪廓,兩個(gè)熊耳是兩個(gè)衛(wèi)星圍繞熊頭旋轉(zhuǎn),是“循環(huán)”的意思。中間傾斜的轉(zhuǎn)轉(zhuǎn)首字母“Z”,既像二手質(zhì)檢的印章,又像N——NEW的首字母,代表著全新的二手生活方式。hgq28資訊網(wǎng)——每日最新資訊28at.com

以上是我們要還原的Logo效果動(dòng)圖,現(xiàn)階段使用方式主要是gif和lottie SVG兩種方式。因?yàn)槲覀兊哪康氖鞘褂脝螛?biāo)簽實(shí)現(xiàn)所有的功能點(diǎn),對(duì)于一些細(xì)節(jié)部分有所取舍,并不是百分百還原,也并不代表使用CSS的成本和效果是最好的,僅表達(dá)CSS的強(qiáng)大能力。接下來(lái)分析我們要核心實(shí)現(xiàn)的功能點(diǎn):hgq28資訊網(wǎng)——每日最新資訊28at.com

  • 開(kāi)始動(dòng)畫時(shí)中心的大圓以及2個(gè)圍繞的小圓都有放大的效果
  • 動(dòng)畫開(kāi)始后2個(gè)小圓圍繞中心的橢圓旋轉(zhuǎn)
  • 字母 Z 由大變小覆蓋在中心的橢圓
  • 字母 Z 出現(xiàn)時(shí)中心的橢圓由紅色邊框圓變成實(shí)心紅色圓
  • 仔細(xì)觀察這個(gè)字母 Z 并不是普通的字符

基于上述分析接下來(lái)開(kāi)始核心的代碼拆解實(shí)現(xiàn),在開(kāi)始前先定義一些變量方便后續(xù)使用:hgq28資訊網(wǎng)——每日最新資訊28at.com

:root {  /* 主題色 */  --mainColor: #ff483c;  /* 字體顏色 */  --fontColor: #fff;  /* 字體寬度 */  --zWidth: 260px;  /* 中心橢圓寬高比 */  --parentScaleY: 0.9;  /* 子元素抵消比例 */  --childScaleY: calc(1 / var(--parentScaleY))}

2個(gè)小圓旋轉(zhuǎn)動(dòng)畫

如果是圍繞一個(gè)正圓的旋轉(zhuǎn)那么實(shí)現(xiàn)就簡(jiǎn)單很多了,但是這里是一個(gè)橢圓,純CSS應(yīng)該怎么做呢?根據(jù)小編目前的了解大概有以下幾種方式都可以實(shí)現(xiàn),但是對(duì)應(yīng)的效果有所區(qū)別:hgq28資訊網(wǎng)——每日最新資訊28at.com

  • 使用 transform-style: preserve-3d;開(kāi)啟3D模式,但是對(duì)應(yīng)的小圓在旋轉(zhuǎn)角度存在視角消失的情況,需要額外處理
  • 使用 cubic-bezier 貝塞爾曲線執(zhí)行動(dòng)畫可以達(dá)到橢圓曲線的效果,但是存在動(dòng)畫開(kāi)始停止不可控的情況
  • 使用 rotate 0-360deg旋轉(zhuǎn),對(duì)應(yīng)子元素需要設(shè)置反向旋轉(zhuǎn)來(lái)抵消父級(jí)的旋轉(zhuǎn)帶來(lái)的影響

對(duì)比各種情況最終使用第三個(gè)方案即可滿足條件且實(shí)現(xiàn)成本較低,首先畫出一個(gè)橢圓的邊框效果,設(shè)置scaleY和border-radius將一個(gè)正方形變成橢圓形,核心代碼如下:hgq28資訊網(wǎng)——每日最新資訊28at.com

width: 570px;  aspect-ratio: 1;  border-radius: 50%;  border: 10px solid var(--mainColor);  transform: scaleY(var(--parentScaleY));

圖片圖片hgq28資訊網(wǎng)——每日最新資訊28at.com

然后給這個(gè)大圓添加旋轉(zhuǎn)的動(dòng)畫,將整體旋轉(zhuǎn)360度,這時(shí)還沒(méi)有添加其他的元素,所以界面沒(méi)有變化。hgq28資訊網(wǎng)——每日最新資訊28at.com

@keyframes circle {  0% {    transform: scaleY(var(--parentScaleY)) rotate(0);  }  100% {    transform: scaleY(var(--parentScaleY)) rotate(360deg);  }}

設(shè)置大圓的動(dòng)畫執(zhí)行相關(guān)參數(shù)。hgq28資訊網(wǎng)——每日最新資訊28at.com

animation: circle 1s 1 cubic-bezier(.5,.08,.52,.93) forwards;

邊框上面的兩個(gè)圈基于偽元素實(shí)現(xiàn),繪制一個(gè)圓并使用定位將小圓定位于大圓的頂部?jī)啥恕H缓笤O(shè)置動(dòng)畫,這里需要注意的是需要設(shè)置反向旋轉(zhuǎn)來(lái)抵消父級(jí)的旋轉(zhuǎn)。hgq28資訊網(wǎng)——每日最新資訊28at.com

@keyframes mini-circle {  0%{    transform: rotate(0deg) scaleY(var(--childScaleY));  } 100%{    transform: rotate(-360deg) scaleY(var(--childScaleY));  }}

這里為了方便查看將橢圓的參數(shù)調(diào)大進(jìn)行對(duì)比,可以看到設(shè)置抵消后的區(qū)別一個(gè)圓被壓縮了另一個(gè)保持了正常的圓形:hgq28資訊網(wǎng)——每日最新資訊28at.com

未設(shè)置抵消hgq28資訊網(wǎng)——每日最新資訊28at.com

已設(shè)置抵消已設(shè)置抵消hgq28資訊網(wǎng)——每日最新資訊28at.com

這里為了更好的利用元素的使用,這里將兩個(gè)圓的繪制進(jìn)一步優(yōu)化到一個(gè)偽元素中,核心使用徑向漸變背景實(shí)現(xiàn),在同一個(gè) background 中繪制兩個(gè)純色圓形,兩個(gè)圓除了繪制的位置不同其他都是一樣。代碼如下:hgq28資訊網(wǎng)——每日最新資訊28at.com

background:   radial-gradient(circle 65px at 31% 24.5%,var(--mainColor) 0% 100%, transparent),  radial-gradient(circle 65px at 72% 24.5%, var(--mainColor) 0% 100%, transparent);

到此這部分的內(nèi)容基本功能完成,實(shí)際效果如下:hgq28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片hgq28資訊網(wǎng)——每日最新資訊28at.com

基于當(dāng)前的樣式我們可以用3段矩形拼接完成效果,上下各一段,中間一段增加旋轉(zhuǎn)角度,但是只用一個(gè)偽元素如何繪制三個(gè)矩形呢,還是用到CSS漸變,這次需要用到linear-gradient線性漸變,頂部和底部正常從上往下繪制,中間的部分需要繪制線條的旋轉(zhuǎn)角度,除開(kāi)需要顯示的顏色其他部分用#0000透明色,為了方便看效果對(duì)三個(gè)矩形更換了不同的顏色,代碼如下:hgq28資訊網(wǎng)——每日最新資訊28at.com

background:   linear-gradient(#f00 25%, #0000 25%),  linear-gradient(#0000 75%, #29eb9a 25%),  linear-gradient(124deg, #0000 40%, #000 40% 60%, #0000 60%);

繪制的效果如下:hgq28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片hgq28資訊網(wǎng)——每日最新資訊28at.com

可以看到目前的效果還不能滿足需求,兩端都出現(xiàn)了多余的部分,需要進(jìn)一步優(yōu)化將其隱藏。這時(shí)候需要用到background-size與background-position,通過(guò)background-size設(shè)置繪制內(nèi)容的大小,通過(guò)設(shè)置background-position設(shè)置繪制內(nèi)容的起點(diǎn)位置,因?yàn)樵O(shè)置了一定的空隙部分需要增加no-repeat不重復(fù),增加以下代碼:hgq28資訊網(wǎng)——每日最新資訊28at.com

background-size: 80% var(--w), 80% var(--w), 100% 100%;background-position: 0 0, 100% 0;background-repeat: no-repeat;

圖片圖片hgq28資訊網(wǎng)——每日最新資訊28at.com

此時(shí)基本符合預(yù)期的效果,但實(shí)際設(shè)計(jì)圖左下角的銳角部分有超出正常矩形一部分。hgq28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片hgq28資訊網(wǎng)——每日最新資訊28at.com

所以需要對(duì)剛剛設(shè)置的size和position部分改進(jìn),將第一個(gè)矩形左側(cè)空出16px:hgq28資訊網(wǎng)——每日最新資訊28at.com

background-size: 74% var(--w), 80% var(--w), 100% 100%;background-position: 16px 0, 100% 0;

因?yàn)榭粘隽俗髠?cè)一部分距離,導(dǎo)致整個(gè)內(nèi)容不再是一個(gè)正方形,所以需要設(shè)置 scaleX 還原寬度將圖像還原到正方形。hgq28資訊網(wǎng)——每日最新資訊28at.com

對(duì)于剛剛設(shè)置的background相關(guān)屬性可以在代碼層進(jìn)一步優(yōu)化,使用簡(jiǎn)寫將代碼合并到一行:hgq28資訊網(wǎng)——每日最新資訊28at.com

background:  linear-gradient(var(--fontColor) 25%, #0000 25%) 16px 0 / 74% var(--zWidth) no-repeat,  linear-gradient(#0000 75%, var(--fontColor) 25%) 100% 0 / 80% var(--zWidth) no-repeat,  linear-gradient(124deg, #0000 40%, var(--fontColor) 40% 60%, #0000 60%) 0 0 / 100% 100% no-repeat;

然后繼續(xù)給這個(gè) Z 添加動(dòng)畫效果,默認(rèn)設(shè)置 opacity: 0 隱藏,因?yàn)?Z 是小圓動(dòng)畫執(zhí)行結(jié)束才出現(xiàn)的,所以還需增加動(dòng)畫的延遲執(zhí)行時(shí)間,增加動(dòng)畫相關(guān)代碼:hgq28資訊網(wǎng)——每日最新資訊28at.com

animation: z 0.3s 1s 1 ease-in-out forwards;opacity: 0;

設(shè)置動(dòng)畫將內(nèi)容從1.5倍縮小到正常并設(shè)置旋轉(zhuǎn)角度,返抵消以及平移到Logo正中心。這里因?yàn)槌跏荚黾恿?.5的放大所以設(shè)置返抵消相關(guān)參數(shù)有所不同,在設(shè)置scaleY的同時(shí)還設(shè)置了skew進(jìn)一步還原尺寸。hgq28資訊網(wǎng)——每日最新資訊28at.com

@keyframes z {  0% {    transform: rotate(-45deg) scale(1.5) translate(0, -50%) skew(-13deg, 8deg);    opacity: 1;  }  100% {    transform: rotate(-42deg) scaleY(var(--childScaleY)) translate(-4%, -64%) skew(-13deg, 8deg);    opacity: 1;  }}

完成后的 Z 字母動(dòng)畫效果:hgq28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片hgq28資訊網(wǎng)——每日最新資訊28at.com

其他細(xì)節(jié)

開(kāi)始動(dòng)畫時(shí)中心的橢圓以及2個(gè)圍繞的小圓都有放大的效果,所以需要對(duì)前面動(dòng)畫關(guān)鍵幀的定義繼續(xù)完善。hgq28資訊網(wǎng)——每日最新資訊28at.com

小圓部分執(zhí)行動(dòng)畫的前10%也增加scale(0.5)。hgq28資訊網(wǎng)——每日最新資訊28at.com

@keyframes mini-circle {  0%{    transform: rotate(0) scale(0.5);  }  10%{    transform: rotate(0) scaleY(var(--childScaleY));  }}

大圓執(zhí)行動(dòng)畫的前10%部分增加scale(0.8)。大圓部分還有一個(gè)效果是字母 Z 出現(xiàn)的時(shí)候中心的橢圓由邊框圓變成實(shí)心圓,所以是在動(dòng)畫結(jié)束前增加對(duì)背景色的變化,代碼如下:hgq28資訊網(wǎng)——每日最新資訊28at.com

@keyframes circle {  0% {    transform: scale(0.8) rotate(0);  }  10% {    transform: scaleY(var(--parentScaleY)) rotate(0);  }  80% {    background-color: var(--fontColor);  }  100% {    background-color: var(--mainColor);    transform: scaleY(var(--parentScaleY)) rotate(360deg);  }}

最后

到此我們整個(gè)代碼實(shí)現(xiàn)過(guò)程就結(jié)束了,基于一個(gè)標(biāo)簽實(shí)現(xiàn)了轉(zhuǎn)轉(zhuǎn)的Logo的繪制及動(dòng)畫效果。當(dāng)然這只是對(duì)其主要的功能還原,如需完整還原細(xì)節(jié)還需要進(jìn)一步優(yōu)化。hgq28資訊網(wǎng)——每日最新資訊28at.com

CSS的確是足夠強(qiáng)大且對(duì)很多復(fù)雜的圖形效果都能實(shí)現(xiàn),這里我們主要是使用漸變背景實(shí)現(xiàn)圖案的繪制,除了漸變還可以使用CSS陰影也能達(dá)到類似的效果。使用CSS對(duì)比使用SVG或GIF在資源體積上有很大的提升,本次實(shí)現(xiàn)的Logo使用lottie的json需要100KB左右,使用GIF大約需要27KB左右,但是純CSS實(shí)現(xiàn)僅1KB不到即可完成,但是對(duì)于較為復(fù)雜的場(chǎng)景對(duì)應(yīng)的代碼也提升了不少的復(fù)雜度,大家要根據(jù)實(shí)際的情況使用,hgq28資訊網(wǎng)——每日最新資訊28at.com

本文鏈接:http://www.www897cc.com/showinfo-26-82-0.htmlCSS單標(biāo)簽實(shí)現(xiàn)轉(zhuǎn)轉(zhuǎn)logo

聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問(wèn)題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。郵件:2376512515@qq.com

上一篇: 2023 年的 Node.js 生態(tài)系統(tǒng)

下一篇: Automa-通過(guò)連接塊來(lái)自動(dòng)化你的瀏覽器

標(biāo)簽:
  • 熱門焦點(diǎn)
  • Redmi Buds 4開(kāi)箱簡(jiǎn)評(píng):才199還有降噪 可以無(wú)腦入

    在上個(gè)月舉辦的Redmi Note11T Pro系列新機(jī)發(fā)布會(huì)上,除了兩款手機(jī)新品之外,Redmi還帶來(lái)了兩款TWS真無(wú)線藍(lán)牙耳機(jī)產(chǎn)品,Redmi Buds 4和Redmi Buds 4 Pro,此前我們?cè)赗edmi Note11T
  • 三言兩語(yǔ)說(shuō)透設(shè)計(jì)模式的藝術(shù)-簡(jiǎn)單工廠模式

    一、寫在前面工廠模式是最常見(jiàn)的一種創(chuàng)建型設(shè)計(jì)模式,通常說(shuō)的工廠模式指的是工廠方法模式,是使用頻率最高的工廠模式。簡(jiǎn)單工廠模式又稱為靜態(tài)工廠方法模式,不屬于GoF 23種設(shè)計(jì)
  • Rust中的高吞吐量流處理

    作者 | Noz編譯 | 王瑞平本篇文章主要介紹了Rust中流處理的概念、方法和優(yōu)化。作者不僅介紹了流處理的基本概念以及Rust中常用的流處理庫(kù),還使用這些庫(kù)實(shí)現(xiàn)了一個(gè)流處理程序
  • 之家push系統(tǒng)迭代之路

    前言在這個(gè)信息爆炸的互聯(lián)網(wǎng)時(shí)代,能夠及時(shí)準(zhǔn)確獲取信息是當(dāng)今社會(huì)要解決的關(guān)鍵問(wèn)題之一。隨著之家用戶體量和內(nèi)容規(guī)模的不斷增大,傳統(tǒng)的靠"主動(dòng)拉"獲取信息的方式已不能滿足用
  • 本地生活這塊肥肉,拼多多也想吃一口

    出品/壹覽商業(yè) 作者/李彥編輯/木魚(yú)拼多多也看上本地生活這塊蛋糕了。近期,拼多多在App首頁(yè)“充值中心”入口上線了本機(jī)生活界面。壹覽商業(yè)發(fā)現(xiàn),該界面目前主要
  • 阿里大調(diào)整

    來(lái)源:產(chǎn)品劉有媒體報(bào)道稱,近期淘寶天貓集團(tuán)啟動(dòng)了近年來(lái)最大的人力制度改革,涉及員工績(jī)效、層級(jí)體系等多個(gè)核心事項(xiàng),目前已形成一個(gè)初步的“征求意見(jiàn)版”:1、取消P序列
  • 三星獲批量產(chǎn)iPhone 15全系屏幕:蘋果史上最驚艷直屏

    按照慣例,蘋果將繼續(xù)在今年9月舉辦一年一度的秋季新品發(fā)布會(huì),有傳言稱發(fā)布會(huì)將于9月12日舉行,屆時(shí)全新的iPhone 15系列將正式與大家見(jiàn)面,不出意外的話
  • onebot M24巧系列一體機(jī)采用輕薄機(jī)身設(shè)計(jì),現(xiàn)已在各平臺(tái)開(kāi)售

    onebot M24 巧系列一體機(jī)目前已在線上線下各平臺(tái)同步開(kāi)售。onebot M24 巧系列采用一體化輕薄機(jī)身設(shè)計(jì),最薄處為 10.15mm,擁有寶石紅、午夜藍(lán)、石墨綠、雅致
  • 中關(guān)村論壇11月25日開(kāi)幕,15位諾獎(jiǎng)級(jí)大咖將發(fā)表演講

    11月18日,記者從2022中關(guān)村論壇新聞發(fā)布會(huì)上獲悉,中關(guān)村論壇將于11月25至30日在京舉行。本屆中關(guān)村論壇由科學(xué)技術(shù)部、國(guó)家發(fā)展改革委、工業(yè)和信息化部、國(guó)務(wù)
Top 主站蜘蛛池模板: 水富县| 邢台县| 赤水市| 阳朔县| 聂荣县| 奉贤区| 平遥县| 胶州市| 沭阳县| 凤山县| 藁城市| 吉安县| 古蔺县| 格尔木市| 启东市| 济阳县| 德格县| 河北省| 精河县| 张北县| 宽城| 临西县| 永寿县| 屯门区| 台东市| 黄大仙区| 深圳市| 长乐市| 图木舒克市| 惠来县| 莒南县| 隆化县| 栾川县| 布尔津县| 西乡县| 三门县| 凌云县| 柯坪县| 东港市| 鹤壁市| 简阳市|