国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

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

實例詳解CSS漸變鋸齒問題如何解決!

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

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

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

在 CSS 中,漸變(Gradient)可謂是最為強大的一個屬性之一。

但是,經(jīng)常有同學(xué)在使用漸變的過程中會遇到漸變圖形產(chǎn)生的鋸齒問題?!就扑]學(xué)習(xí):css視頻教程

何為漸變鋸齒?

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

簡單的一個 DEMO:

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

效果如下:

4740ed101bda3c1d1bfc81b935851ff.jpg

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

2ea57a6fbe8dc9105d8c3bbb7dcb90b.jpg

又或者是這樣:

6cc3dd8cc6ee4feb168d64f1d5ed034.jpg

有意思的是,鋸齒現(xiàn)象在 DPR 為 1 的屏幕下特別明顯,而在一些高清屏(dpr > 1)的屏幕下,感受不會那么明顯。

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

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

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

簡單的解決辦法

解決失真的問題有很多。這里最簡單的方式就是不要直接過渡,保留一個極小的漸變過渡空間。

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

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);
}

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

9bb6cdb8068db5048b56a2b8ae473a1.jpg

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

當然,如果不想修改原代碼,也可以通過疊加一層偽元素實現(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)生鋸齒的地方,實現(xiàn)一個平滑過渡進行覆蓋:

1949031684-38b7e37fe039ffaa.gif

效果如下:

14ed1f4d23c8412f49785081c235cd9.jpg

CodePen Demo -- 消除 Gradient 鋸齒

劃重點!此方法適用于線性漸變、徑向漸變、角向漸變,是最為簡單的消除 CSS 鋸齒的方式。

更為高階的鋸齒消除法

當然,也還有其他更為高階的鋸齒消除法。

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

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

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

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

4f54a7b2d6f82325e80df20cebef61a.jpg

7f79f11c4068c370c6509006949ad2a.jpg

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

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

  • 需要通過某種方法得到透明度的點
  • 這些點需要能夠組成線段
  • 線段完全吻合我們的 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
    );
}

65ae80c26c0f8001108dc0d8d2914a8.jpg

邊緣信息如下:

4cfe40f88d633706685b0ca803d8ce2.jpg

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

1210954142-733ca35103f2c3b6.gif

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

.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é)束,希望本文對你有所幫助 :)

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

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

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣服圖片

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

用于從照片中去除衣服的在線人工智能工具。

Clothoff.io

Clothoff.io

AI脫衣機

Video Face Swap

Video Face Swap

使用我們完全免費的人工智能換臉工具輕松在任何視頻中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的代碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

功能強大的PHP集成開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

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

SublimeText3 Mac版

SublimeText3 Mac版

神級代碼編輯軟件(SublimeText3)

熱門話題

Laravel 教程
1601
29
PHP教程
1502
276
如何更改CSS中的文本顏色? 如何更改CSS中的文本顏色? Jul 27, 2025 am 04:25 AM

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

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

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

描述不同的CSS單元以及何時使用它們 描述不同的CSS單元以及何時使用它們 Jul 27, 2025 am 04:24 AM

在網(wǎng)頁開發(fā)中,CSS單位的選擇取決于設(shè)計需求和響應(yīng)式表現(xiàn)。1.像素(px)用于固定尺寸如邊框和圖標,但不利于響應(yīng)式設(shè)計;2.百分比(%)根據(jù)父容器調(diào)整大小,適合流式布局但需注意上下文依賴;3.em基于當前字體大小,rem基于根元素字體,適合彈性字體和統(tǒng)一主題控制;4.視口單位(vw/vh/vmin/vmax)依據(jù)屏幕尺寸調(diào)整,適合全屏元素和動態(tài)UI;5.auto、inherit、initial等值用于自動計算、繼承或重置樣式,有助于靈活布局與樣式管理。合理使用這些單位能提升頁面靈活性與響應(yīng)性。

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

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

如何使用CSS Backdrop-Filter屬性? 如何使用CSS Backdrop-Filter屬性? Aug 02, 2025 pm 12:11 PM

backdrop-filter用于對元素背后的內(nèi)容應(yīng)用視覺效果,1.使用backdrop-filter:blur(10px)等語法實現(xiàn)毛玻璃效果;2.支持blur、brightness、contrast等多種濾鏡函數(shù)并可疊加;3.常用于玻璃態(tài)卡片設(shè)計,需確保元素與背景重疊;4.現(xiàn)代瀏覽器支持良好,可用@supports提供降級方案;5.避免過大模糊值和頻繁重繪以優(yōu)化性能,該屬性僅在元素背后有內(nèi)容時生效。

如何將文本集中在CSS中? 如何將文本集中在CSS中? Jul 27, 2025 am 03:16 AM

使用text-align:center實現(xiàn)文本水平居中;2.使用Flexbox的align-items:center和justify-content:center實現(xiàn)垂直和水平居中;3.單行文本可通過設(shè)置line-height等于容器高度來垂直居中;4.絕對定位元素可結(jié)合top:50%、left:50%與transform:translate(-50%,-50%)實現(xiàn)居中;5.CSSGrid的place-items:center也可同時實現(xiàn)雙軸居中,現(xiàn)代布局推薦優(yōu)先使用Flexbox或Grid。

如何在CSS中樣式鏈接? 如何在CSS中樣式鏈接? Jul 29, 2025 am 04:25 AM

鏈接的樣式應(yīng)通過偽類區(qū)分不同狀態(tài),1.使用a:link設(shè)置未訪問鏈接樣式,2.a:visited設(shè)置已訪問鏈接,3.a:hover設(shè)置懸停效果,4.a:active設(shè)置點擊時樣式,5.a:focus確保鍵盤可訪問性,始終遵循LVHA順序以避免樣式?jīng)_突,可通過添加padding、cursor:pointer和保留或自定義焦點輪廓來提升可用性和可訪問性,還可使用border-bottom或動畫下劃線等自定義視覺效果,最終確保鏈接在所有狀態(tài)下均有良好用戶體驗和可訪問性。

什么是用戶代理樣式表? 什么是用戶代理樣式表? Jul 31, 2025 am 10:35 AM

用戶代理樣式表是瀏覽器自動應(yīng)用的默認CSS樣式,用于確保未添加自定義樣式的HTML元素仍具基本可讀性。它們影響頁面初始外觀,但不同瀏覽器存在差異,可能導(dǎo)致不一致顯示。開發(fā)者常通過重置或標準化樣式來解決這一問題。使用開發(fā)者工具的“計算”或“樣式”面板可查看默認樣式。常見覆蓋操作包括清除內(nèi)外邊距、修改鏈接下劃線、調(diào)整標題大小及統(tǒng)一按鈕樣式。理解用戶代理樣式有助于提升跨瀏覽器一致性并實現(xiàn)精準布局控制。

See all articles