亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

目錄
CSS 漸變鋸齒消失術(shù)
何為漸層鋸齒?
簡單的解決方法
更高階的鋸齒消除法
最后
首頁 web前端 css教學(xué) 實(shí)例詳解CSS漸變鋸齒問題如何解決!

實(shí)例詳解CSS漸變鋸齒問題如何解決!

Nov 25, 2022 pm 04:43 PM
css 漸變 鋸齒

這篇文章跟大家介紹一下如何解決在使用漸變圖形產(chǎn)生的鋸齒問題,所謂CSS漸變鋸齒消失術(shù),你會(huì)了就能搞定,下面就帶大家一起來看看怎麼實(shí)現(xiàn)吧~希望對大家有所幫助!

CSS 漸變鋸齒消失術(shù)

#

在 CSS 中,漸層(Gradient)可謂是最為強(qiáng)大的一個(gè)屬性之一。

但是,常有同學(xué)在使用漸層的過程中會(huì)遇到漸層圖形所產(chǎn)生的鋸齒問題。 【推薦學(xué)習(xí):css影片教學(xué)

何為漸層鋸齒?

那麼,什麼是漸層圖形產(chǎn)生的鋸齒呢?

簡單的一個(gè)DEMO:

<div></div>
div {
    width: 500px;
    height: 100px;
    background: linear-gradient(37deg), #000 50%, #f00 50%, #f00 0);
}

效果如下:

實(shí)例詳解CSS漸變鋸齒問題如何解決!

#其實(shí),鋸齒感已經(jīng)非常明顯了,我們再放大了看,其內(nèi)部其實(shí)是這樣的:

實(shí)例詳解CSS漸變鋸齒問題如何解決!

又或者是這樣:

實(shí)例詳解CSS漸變鋸齒問題如何解決!

有趣的是,鋸齒現(xiàn)像在DPR 為1 的螢?zāi)幌绿貏e明顯,而在一些高清螢?zāi)唬╠pr > 1)的螢?zāi)幌?,感受不?huì)那麼明顯。

DPR(Device Pixel Ratio)為設(shè)備像素比,DPR = 物理像素 / 設(shè)備獨(dú)立像素,設(shè)備像素比描述的是未縮放狀態(tài)下,物理像素和設(shè)備獨(dú)立像素的初始比例關(guān)係。

那麼為啥會(huì)產(chǎn)生鋸齒感呢?

傳統(tǒng)網(wǎng)頁的呈現(xiàn)是基於像素單位的,對於這種一種顏色直接過渡另外一種顏色狀態(tài)的圖片,容易導(dǎo)致可視質(zhì)量下降(信息失真)。因而對於普通的漸變元素,像是上述寫法,產(chǎn)生了鋸齒,這是非常常見的在使用漸變過程中的一個(gè)棘手問題。

簡單的解決方法

解決失真的問題很多。這裡最簡單的方式就是不要直接過渡,保留一個(gè)極小的漸層過渡空間。

上述的程式碼,我們可以簡單改造一下:

div {
    width: 500px;
    height: 100px;
  - background: linear-gradient(37deg), #000 50%, #f00 50%, #f00);
  + background: linear-gradient(37deg), #000 49.5%, #f00 50.5%, #f00);
}

仔細(xì)看其中的變化,我們從50% --> 50% 的直接過渡,變化成預(yù)留了1%的漸變過渡空間,效果如下:

實(shí)例詳解CSS漸變鋸齒問題如何解決!

可以看到,效果立刻有了大幅提升!

當(dāng)然,如果不想修改原程式碼,也可以透過疊加一層偽元素實(shí)現(xiàn),這裡給出3 種方式的對比圖:

<div></div>
<div class="gradient"></div>
<div class="pesudo"></div>
:root {
    --deg: 37deg;
    --c1: #000;
    --c2: #f00;
    --line-width: 0.5px;
}
div {
    margin: auto;
    width: 500px;
    height: 100px;
    background: linear-gradient(
        var(--deg),
        var(--c1) 50%,
        var(--c2) 50%,
        var(--c2) 0
    );
}
// 方法一:
.gradient {
    background: linear-gradient(
        var(--deg),
        var(--c1),
        var(--c1) calc(50% - var(--line-width)),
        var(--c2) calc(50% + var(--line-width)),
        var(--c2) 0
    );
}
// 方法二:
.pesudo {
    position: relative;

    &::before {
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background: linear-gradient(
            var(--deg),
            transparent,
            transparent calc(50% - var(--line-width)),
            var(--c1) calc(50% - var(--line-width)),
            var(--c2) calc(50% + var(--line-width)),
            transparent calc(50% + var(--line-width)),
            transparent
        );
    }
}

透過偽元素疊加的意思是,在產(chǎn)生鋸齒的地方,實(shí)作一個(gè)平滑過渡進(jìn)行覆寫:

實(shí)例詳解CSS漸變鋸齒問題如何解決!

#效果如下:

實(shí)例詳解CSS漸變鋸齒問題如何解決!

CodePen Demo -- 消除Gradient 鋸齒

劃重點(diǎn)! 此方法適用於線性漸變、徑向漸層、角向漸層,是最簡單的消除 CSS 鋸齒的方式。

更高階的鋸齒消除法

當(dāng)然,也還有其他更高階的鋸齒消除法。

仿生獅子的這篇文章中 -- CSS 幻術(shù) | 抗鋸齒,也介紹了另一個(gè)有趣的消除鋸齒的方式。以下內(nèi)容,部分摘錄至該文章。

我們可以建立一種邊緣鋸齒邊緣->重建鋸齒邊緣的鋸齒消除方法。

我們需要做的,就是在鋸齒處,疊加上另外一層內(nèi)容,讓鋸齒感不那麼強(qiáng)烈。稱為像素偏移抗鋸齒(Pixel-Offset Anti-Aliasing,POAA)。

Implementing FXAA這篇博客中,解釋了 FXAA 具體是如何運(yùn)作的。對于一個(gè)已經(jīng)被找到的圖形邊緣,經(jīng)過 FXAA 處理后會(huì)變成這樣,見下兩幅圖:

實(shí)例詳解CSS漸變鋸齒問題如何解決!

實(shí)例詳解CSS漸變鋸齒問題如何解決!

FXAA(Fast Approximate Anti-Aliasing),快速近似抗鋸齒,它找到畫面中所有圖形的邊緣并進(jìn)行平滑處理。

我們可以輕易找到找到漸變的邊緣地方,就是那些漸變的顏色改變的地方。有了邊緣信息后,接著就要重建邊緣。重建邊緣也許可以再拆分,分為以下幾個(gè)步驟:

  • 需要通過某種方法得到透明度的點(diǎn)
  • 這些點(diǎn)需要能夠組成線段
  • 線段完全吻合我們的 Gradient
  • 使線段覆蓋在 Gradient 的上一層以應(yīng)用我們的修改

這就是大體思路,我們并沒有參與瀏覽器的渲染,而是通過像 FXAA 一樣的后處理的方法。在已渲染的圖像上做文章。

比如說,我們有這樣一張圖:

.circle-con {
    $c1: #cd3f4f;
    $c2: #e6a964;
    position: relative;
    height: 300px;
    background-image: repeating-radial-gradient(
        circle at 0% 50%, 
        $c1 0, 
        $c2 50px
    );
}

實(shí)例詳解CSS漸變鋸齒問題如何解決!

邊緣信息如下:

實(shí)例詳解CSS漸變鋸齒問題如何解決!

我們要做的,就是在它的邊緣處,利用漸變再生成一段漸變,通過準(zhǔn)確疊加,消除漸變!原理圖如下:

實(shí)例詳解CSS漸變鋸齒問題如何解決!

原理可行,但是實(shí)操起來非常之復(fù)雜,計(jì)算量會(huì)比較大。感興趣的可以拿這段代碼嘗試一下:

.repeat-con {
    --c1: #cd3f4f;
    --c2: #e6a964;
    --c3: #5996cc;
    position: relative;
    height: 300px;
    background-image: repeating-linear-gradient(
        var(--deg),
        var(--c1),
        var(--c1) 10px,
        var(--c2) 10px,
        var(--c2) 40px,
        var(--c1) 40px,
        var(--c1) 50px,
        var(--c3) 50px,
        var(--c3) 80px
    );

    &.antialiasing {
        &:after {
            --offsetX: 0.4px;
            --offsetY: -0.1px;
            --dark-alpha: 0.3;
            --light-alpha: 0.6;
            --line-width: 0.6px;
            content: &#39;&#39;;
            position: absolute;
            top: var(--offsetY);
            left: var(--offsetX);
            width: 100%;
            height: 100%;
            opacity: 0.5;
            background-image: repeating-linear-gradient(
                var(--deg),
                var(--c3),
                transparent calc(0px + var(--line-width)),
                transparent calc(10px - var(--line-width)),
                var(--c2) 10px,
                var(--c1) 10px,
                transparent calc(10px + var(--line-width)),
                transparent calc(40px - var(--line-width)),
                var(--c1) 40px,
                var(--c2) 40px,
                transparent calc(40px + var(--line-width)),
                transparent calc(50px - var(--line-width)),
                var(--c3) 50px,
                var(--c1) 50px,
                transparent calc(50px + var(--line-width)),
                transparent calc(80px - var(--line-width)),
                var(--c1) 80px
            );
        }
    }
}

最后

簡單總結(jié)一下,本文介紹了幾種 CSS 中可行的消除漸變鋸齒的方法。

好了,本文到此結(jié)束,希望本文對你有所幫助 :)

以上是實(shí)例詳解CSS漸變鋸齒問題如何解決!的詳細(xì)內(nèi)容。更多資訊請關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願(yuàn)投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動(dòng)的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強(qiáng)大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Laravel 教程
1597
29
PHP教程
1488
72
描述'垂直align”屬性及其典型用例 描述'垂直align”屬性及其典型用例 Jul 26, 2025 am 07:35 AM

1.ItAdjustSelementsLikeImagesRikeImagesOrformInputswithIntExtLineSustLineSlineSlineSlineSlikeLikeLikeBaseline,中間,Super,Super,Super和Sub.2.intablebecells,ItControlScontentalStalteNtalmscontentalMedwithThtop,Middle,Middle,Midder,Midder,經(jīng)常

什麼是口音色的物業(yè)? 什麼是口音色的物業(yè)? Jul 26, 2025 am 09:25 AM

accent-color是CSS中用於自定義復(fù)選框、單選按鈕和滑塊等表單元素高亮顏色的屬性;1.它直接改變表單控件選中狀態(tài)的默認(rèn)顏色,如將復(fù)選框的藍(lán)色勾選標(biāo)記改為紅色;2.支持的元素包括type="checkbox"、type="radio"和type="range"的輸入框;3.使用accent-color可避免複雜的自定義樣式和額外DOM結(jié)構(gòu),保持原生可訪問性;4.現(xiàn)代瀏覽器普遍支持,舊瀏覽器需降級處理;5.設(shè)置accent-col

如何將SCSS編譯到CSS? 如何將SCSS編譯到CSS? Jul 27, 2025 am 01:58 AM

installdartsassvianpmafterinstallingnode.jsusingnpminstall-gsass.2.compilescsstocssssusingthecommandSassInput.scsssoutput.css.3。 useass - watchinput.scssoutput.csstoauto-compileonsave.4.watchentirefolderswithsass-watchscss:css.5.usepartialswith_prefixfo

如何更改CSS中的文本顏色? 如何更改CSS中的文本顏色? Jul 27, 2025 am 04:25 AM

要改變CSS中文本顏色,需使用color屬性;1.使用color屬性可設(shè)置文本前景色,支持顏色名稱(如red)、十六進(jìn)制碼(如#ff0000)、RGB值(如rgb(255,0,0))、HSL值(如hsl(0,100%,50%))以及帶透明度的RGBA或HSLA(如rgba(255,0,0,0.5));2.可將顏色應(yīng)用於包含文本的任何元素,如h1至h6標(biāo)題、段落p、鏈接a(需注意a:link、a:visited、a:hover、a:active不同狀態(tài)的顏色設(shè)置)、按鈕、div、span等;3.最

CSS過渡教程 CSS過渡教程 Jul 26, 2025 am 09:30 AM

csStransitionSenablesMoothPropertyChangesWithMinimalCode,ifealforHoverForpectSandInteractiveFeedback.1.usethesyntaxtransition:propertyDurationTimingTiming-functionDelayDelay; TodefineTrysitions; TodefinEtrys;

如何清除未使用的CSS? 如何清除未使用的CSS? Jul 27, 2025 am 02:47 AM

UseAutomatedToolSlikePurgecsSoruncsStoscanAndRemoveUnusedcss; 2. integratePuratePurgingIntoyourBuildProcessviawebpack,vite,vite,ortailwind ’scontentConfiguration; 3.AuditcsSusageWithChroMedEvtoolScoverAgeTabBeforgeForgingToavoidRemovingNeedEdedStyles; 4.safelistdynamic

html'樣式”標(biāo)籤:內(nèi)聯(lián)與內(nèi)部CSS html'樣式”標(biāo)籤:內(nèi)聯(lián)與內(nèi)部CSS Jul 26, 2025 am 07:23 AM

樣式放置方式需根據(jù)場景選擇。 1.Inline適合單元素臨時(shí)修改或JS動(dòng)態(tài)控制,如按鈕顏色隨操作變化;2.內(nèi)部CSS適合頁面少、結(jié)構(gòu)簡單項(xiàng)目,便於集中管理樣式,如登錄頁基礎(chǔ)樣式設(shè)置;3.優(yōu)先考慮復(fù)用性、維護(hù)性及性能,大項(xiàng)目拆分外鏈CSS文件更優(yōu)。

什麼是堆疊上下文? 什麼是堆疊上下文? Jul 27, 2025 am 03:55 AM

astackingcontextisaself-containeerrincssthatconthatconthatconthatconthatconthatconthatconthatconthatconthatconthatconthatconthatconthatconthatconthatconteroverlapplapsplatements,wherenestedContextSrextSrextSratcrets-IndexInteractions; itiscreatedByDybyPropertiesLikeLikeZ-IndexonPositionsedElements,Epacity,opacity

See all articles