搜尋
首頁web前端css教學Css3新特性應用之形狀

一、自適應橢圓

 border-radius特性:

  • 可以單獨指定水平和垂直半徑,且值可以是百分比,用/(斜線)分隔這兩個值即可(可以實現自適應寬度橢圓)。

  • 也可以單獨指定四個角度不同的水平和垂直半徑(可以實現半橢圓)

  •  四分之一橢圓,主要是調整水平和垂直的半徑

範例程式碼:

#
.wrap{
            border-radius: 50% / 30%;
            width: 60px;
            height: 80px;
            background: yellow;
        }
        .wrap02{
            width: 60px;
            height: 80px;
            background: yellow;
            border-radius: 50% / 100% 100% 0 0;
        }
        .wrap03{
            width: 60px;
            height: 80px;
            background: yellow;
            border-radius: 100% 0 0 0;
        }

Css3新特性應用之形狀

二、平形四邊形

  • 需要應用到transform的skewX進行扭曲

  • 主要解決容器成為平形四邊形,而內部的文字和元素且垂直顯示

  • 嵌套元素,內部元素以skew反向扭曲即可。巢狀的內部元素必須為block,因為transform不能應用在inline元素上。

  • 利用偽元素進行扭曲(:before)

.wrap{
            width: 80px;
            height: 40px;
            transform: skewX(-45deg);
            background: yellow;
        }
        .wrap>p{
            transform: skewX(45deg); 
        }
        .btn{
            position: relative;
            padding: 10px;
        }
        .btn:before{
            content: '';
            position: absolute;
            top: 0px;
            left: 0px;
            right: 0px;
            bottom: 0px;
            z-index: -1;
            background: #85a;
            transform: skewX(-45deg);
        }

Css3新特性應用之形狀

三、菱形

  • #應用元素的嵌套,外層與內層元素相互roate旋轉,實現八角形;

  • 設計內部元素max-width的寬度為100%,讓整個圖片最大隻能充滿整個外層的p;

  • scale屬性控制其圖片的放大倍率,預設為中心點為放大原點(會用到勾股定理,不要額外指定transform-origin)。

.wrap{
            width: 200px;
            transform: rotate(-45deg);
            overflow: hidden;
        }
        .wrap > img{
            transform: rotate(45deg) scale(1.42); 
            max-width: 100%;
        }

Css3新特性應用之形狀

#四、切角效果

Css3新特性應用之形狀

  • #利用linear-gradient可以設定角度,多值和漸層透明來實現。

  • 也需要注意background-size和background-repeat屬性的設置,防止背景的重疊導致效果不生效

  • ##

    .wrap{
                width: 200px;
                height: 100px;
                background: #58a;
                background: linear-gradient(-135deg, transparent 15px, #58a 0px) top right,
                linear-gradient(135deg,transparent 15px, #655 0px) top left,
                linear-gradient(-45deg, transparent 15px, #58a 0px) bottom right, 
                linear-gradient(45deg, transparent 15px, #655 0px) bottom left;
                background-size: 50% 50%;
                background-repeat: no-repeat;
            }

可以利用border-image實作切角,設定border-image-slice(圖片邊框向內偏移)的值;

  • border-image用svg來做圖片

  • border設定寬度+透明,再加上border-image-slice向內偏移就造就了邊框切角邊框;

background-clip:要設定為padding-box,不然背景會延伸到邊框上。

.wrapSvg{
            border:15px solid transparent;
            border-image: 1 url(&#39;data:image/svg+xml, <svg xmlns="http://www.w3.org/2000/svg" width="3" height="3" fill="%2358a"><polygon points="0,1 1,0 2,0 3,1 3,2 2,3 1,3 0,2"/></svg>&#39;);
            margin-top: 50px;
            width: 200px;
            height: 100px; 
            background: #58a;
            background-clip: padding-box;
        }

Css3新特性應用之形狀

其他方案

  • 利用clip-path屬性,但不完全受支持

  • css4會直接給出corner-path屬性來支援切角

  • 五、梯形圖案

  • 了解transform的基本原理

a和d表示縮放且不能為0;c和b控制傾斜;e和f控制位移

    translate(位移):matrix(1,0,0,1,x,y)
  • #scale(縮放):matrix(x,0,0, y,0,0);
  • skew(傾斜):matrix(1,tany,tanx,1,0,0),由於輸入的是deg(角度),需要將角度轉換為弧度值
  • rotate(旋轉):matrix(cosN,sinN,-sinN,cosN,0,0),角度轉換為弧度
  • #上述值的應用都與transform-origin的值有關係,他是定位元素旋轉的原點,可以是top,bottom,center等,可以指定x,y,z三種座標系

perpective:透視,不可以負數,0或百分比,只能是數值;Css3新特性應用之形狀

#######表示觀察者到被觀察物體的一段距離######## ###透視距離與物體越遠,物體就會顯得越小############透視只能設定在變形元素的父級或祖先級,因為瀏覽器會為其子級的變形產生透視效果############在3d變換上沒有傾斜(skew)這個屬性。 ##################

六、简单的饼图

动画饼图,效果如下:

Css3新特性應用之形狀

实现步骤如下:

画出一个yellowgreen的圆,并利用linear-gradient设置background-image的值,实现两种颜色各显示一半的功能:

然后加入一个伪元素,继承父级(真实元素)的背景色,然后用rotate旋转即可

  • 要利用margin-left让其靠左

  • 利用transform-origin设置其旋转定位点

动画展示代码如下:

@keyframes spin{
            to{ transform: rotate(.5turn); }
        }
        @keyframes bg{
            50%{ background-color: #655; }
        }
        .wrap{
            width: 100px; height: 100px;
            border-radius: 50%;
            background: yellowgreen;
            background-image: linear-gradient(to right, transparent 50%, #655 0); 
        } 
        .wrap::before{
            content: &#39;&#39;;
            display: block;
            margin-left: 50%;
            background-color: inherit;
            height: 100%; 
            border-radius: 0 100% 100% 0 / 50%;
            transform-origin: left;
            animation:spin 3s linear infinite,
                bg 6s step-end infinite;
        }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持PHP中文网。

更多Css3新特性應用之形狀相关文章请关注PHP中文网!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
模擬鼠標運動模擬鼠標運動Apr 22, 2025 am 11:45 AM

如果您曾經在現場演講或課程中必須顯示一個互動動畫,那麼您可能知道它並不總是那麼容易與您的幻燈片進行互動

通過Astro Action和Fuse.js為搜索提供動力通過Astro Action和Fuse.js為搜索提供動力Apr 22, 2025 am 11:41 AM

對於Astro,我們可以在構建過程中生成大部分網站,但是有一小部分服務器端代碼可以使用Fuse.js之類的搜索功能來處理搜索功能。在此演示中,我們將使用保險絲搜索一組個人“書籤”

未定義:第三個布爾值未定義:第三個布爾值Apr 22, 2025 am 11:38 AM

我想在我的一個項目中實現一條通知消息,類似於您在保存文檔時在Google文檔中看到的信息。換句話說,一個

捍衛三元聲明捍衛三元聲明Apr 22, 2025 am 11:25 AM

幾個月前,我正在使用黑客新聞(就像一個人一樣),並且遇到了一篇(現已刪除的)文章,內容涉及不使用if語句。如果您是這個想法的新手(就像我

使用網絡語音API進行多語言翻譯使用網絡語音API進行多語言翻譯Apr 22, 2025 am 11:23 AM

自科幻小說以來,我們就幻想著與我們交談的機器。今天這很普遍。即便如此,製造的技術

JetPack Gutenberg塊JetPack Gutenberg塊Apr 22, 2025 am 11:20 AM

我記得當古騰堡被釋放到核心時,因為那天我在WordCamp我們。現在已經過去了幾個月,所以我想我們越來越多的人

在VUE中創建可重複使用的分頁組件在VUE中創建可重複使用的分頁組件Apr 22, 2025 am 11:17 AM

大多數Web應用程序背後的想法是從數據庫中獲取數據,並以最佳方式將其呈現給用戶。當我們處理數據時

使用'盒子陰影”和剪輯路徑一起使用'盒子陰影”和剪輯路徑一起Apr 22, 2025 am 11:13 AM

讓我們在一個情況下做一些似乎有意義的事情的情況下逐步進行一些逐步,但是您仍然可以用CSS欺騙來完成它。在這個

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

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

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中