真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

如何使用純CSS實現(xiàn)單一div的正多邊形變換

這篇文章給大家分享的是有關如何使用純CSS實現(xiàn)單一div的正多邊形變換的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

成都創(chuàng)新互聯(lián)主要為客戶提供服務項目涵蓋了網(wǎng)頁視覺設計、VI標志設計、成都營銷網(wǎng)站建設、網(wǎng)站程序開發(fā)、HTML5響應式網(wǎng)站建設公司、手機網(wǎng)站制作設計、微商城、網(wǎng)站托管及成都網(wǎng)站維護、WEB系統(tǒng)開發(fā)、域名注冊、國內外服務器租用、視頻、平面設計、SEO優(yōu)化排名。設計、前端、后端三個建站步驟的完善服務體系。一人跟蹤測試的建站服務標準。已經(jīng)為建筑動畫行業(yè)客戶提供了網(wǎng)站設計服務。

純粹利用CSS,讓“單一個”div,從正三角形變換為正八邊形(單一div最多只能做到正八邊形),最后再搭配動畫的效果,變成正多邊形的變換動畫,也由于正多邊形需要用到不少的三角函數(shù)計算,為了方便起見,這里將正多邊形的邊統(tǒng)一都設為100px。

正三角形

正三角形不需要用到偽元素,只需要設定div本身的邊框寬度即可產(chǎn)生,先來看一下正三角形的邊長與中線,若邊長為100px,則中線四舍五入就是87px(100 x sin(60)= 87)。

因此我們要將div的長寬都設為0,接著把底部border的寬度設為87px,左右的border寬度設為50px(顏色設為透明transparent),就可以做出一個漂亮的三角形。

width:0;

height:0;

border-width:0 50px 87px ;

border-style:solid;

border-color:transparent transparent #095;

正方形

正方形應該是最簡單的,只要設定長寬設定為同樣數(shù)值就可以了,不過其實還有另外兩種方法,第一種你可以把長寬設為0,把上下左右的border設為50px也可以,第二種則是高度設為0,寬度設為100px,然后某個邊寬也設為100,都是可以的。

.a{

width:100px;

height:100px;

background:#c00;

}

.b{

width:0;

height:0;

border-width:50px;

border-style:solid;

border-color:#095;

}

.c{

width:100px;

height:0;

border-width:0 0 100px;

border-style:solid;

border-color:#069;

}

正五邊形

正五邊形就需要進入基本的三角函數(shù)領域了,讓我們先把正五邊形分解,用原本的div作為上方的三角形,然后用一個偽元素制作下方的梯形,因為正五邊形每邊的夾角為108度,所以可以藉由三角函數(shù)計算出上方三角形的高度為59px(100 x cos(54)),寬度為192px(100x sin(54)x 2),下方梯形的高度為95px(100 x sin(72)),長邊的寬度跟上面的三角形一樣都是192px。

了解原理之后,就可以利用偽元素來搭配制作啰!

.a{

position:relative;

width:0;

height:0;

border-width:0 81px 59px;

border-style:solid;

border-color:transparent transparent #069;

}

.a:before{

position:absolute;

content:"";

top:59px;

left:-81px;

width:100px;

height:0;

background:none;

border-width:95px 31px 0;

border-style:solid;

border-color:#069 transparent transparent;

}

正六邊形

正六邊形的每個夾角是120度,如果以純CSS的方向來看的話,就是把正五邊形上面的三角形改變一下,就可以做出正六邊形,也就是變成上下兩個梯形的組合而已,梯形的長邊為200px(100 x cos(60)x 2 + 100),梯形的高度為87px(100 x sin(60))。

所以只要把正五邊形的CSS稍作修改就可以做出正六邊形了。

.a{

position:relative;

width:100px;

height:0;

border-width:0 50px 87px;

border-style:solid;

border-color:transparent transparent #f80;

}

.a:before{

position:absolute;

content:"";

top:87px;

left:-50px;

width:100px;

height:0;

background:none;

border-width:87px 50px 0;

border-style:solid;

border-color:#f80 transparent transparent;

}

正七邊形

正七邊形開始就必須再使用after這個偽元素了,因為正七邊形必須要拆解為三個內存塊,分別是用原本的div作為上面的三角形,一個偽元素作為中間的梯形,然后另一個偽元素作為底部的梯形,正七邊形的夾角比較特別不是整數(shù),而是128又4/7度,大概取到小數(shù)第二位是128.57,所以計算起來結果就如下圖所示,重點就是必須要清楚地知道長寬是多少。

有了長寬之后,就開始用CSS來寫啰!

.a{

position:relative;

width:0;

height:0;

border-width:0 90px 43px;

border-style:solid;

border-color:transparent transparent #09c;

}

.a:before{

position:absolute;

content:"";

top:140px;

left:-112px;

width:100px;

height:0;

border-width:78px 62px 0;

border-style:solid;

border-color:#09c transparent transparent;

}

.a:after{

position:absolute;

content:"";

top:43px;

left:-112px;

width:180px;

height:0;

border-width:0 22px 97px;

background:none;

border-style:solid;

border-color:transparent transparent #09c;

}

正八邊形

正八邊形其實就是把正七邊形上面的三角形變成梯形,然后中間的梯形變成矩形就搞定了,正八邊形的夾角為135度,計算出來的各個區(qū)域長寬如下圖。

同樣的了解原理,CSS做起來就簡單多啰!

.a{

position:relative;

width:100px;

height:0;

border-width:0 71px 71px;

border-style:solid;

border-color:transparent transparent  #f69;

}

.a:before{

position:absolute;

content:"";

top:171px;

left:-71px;

width:100px;

height:0;

border-width:71px 71px 0;

border-style:solid;

border-color: #f69 transparent transparent;

}

.a:after{

position:absolute;

content:"";

top:71px;

left:-71px;

width:242px;

height:0;

border-width:0 0 100px;

background:none;

border-style:solid;

border-color:transparent transparent #f69;

}

感謝各位的閱讀!關于“如何使用純CSS實現(xiàn)單一div的正多邊形變換”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!


新聞名稱:如何使用純CSS實現(xiàn)單一div的正多邊形變換
文章地址:http://weahome.cn/article/jsdejd.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部