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

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

CSS進(jìn)行單一div正多邊形變換的方法-創(chuàng)新互聯(lián)

這篇文章將為大家詳細(xì)講解有關(guān)CSS進(jìn)行單一div正多邊形變換的方法,小編覺得挺實(shí)用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

網(wǎng)站建設(shè)公司,為您提供網(wǎng)站建設(shè),網(wǎng)站制作,網(wǎng)頁設(shè)計(jì)及定制網(wǎng)站建設(shè)服務(wù),專注于成都企業(yè)網(wǎng)站建設(shè),高端網(wǎng)頁制作,對成都玻璃隔斷等多個行業(yè)擁有豐富的網(wǎng)站建設(shè)經(jīng)驗(yàn)的網(wǎng)站建設(shè)公司。專業(yè)網(wǎng)站設(shè)計(jì),網(wǎng)站優(yōu)化推廣哪家好,專業(yè)seo優(yōu)化優(yōu)化,H5建站,響應(yīng)式網(wǎng)站。

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


正三角形

正三角形不需要用到偽元素,只需要設(shè)定p本身的邊框?qū)挾燃纯僧a(chǎn)生,先來看一下正三角形的邊長與中線,若邊長為100px,則中線四舍五入就是87px(100 x sin(60)= 87)。


CSS進(jìn)行單一div正多邊形變換的方法

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

width:0;
height:0;
border-width:0 50px 87px ;
border-style:solid;
border-color:transparent transparent #095;

CSS進(jìn)行單一div正多邊形變換的方法

正方形

正方形應(yīng)該是最簡單的,只要設(shè)定長寬設(shè)定為同樣數(shù)值就可以了,不過其實(shí)還有另外兩種方法,第一種你可以把長寬設(shè)為0,把上下左右的border設(shè)為50px也可以,第二種則是高度設(shè)為0,寬度設(shè)為100px,然后某個邊寬也設(shè)為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;
}

CSS進(jìn)行單一div正多邊形變換的方法

正五邊形

正五邊形就需要進(jìn)入基本的三角函數(shù)領(lǐng)域了,讓我們先把正五邊形分解,用原本的p作為上方的三角形,然后用一個偽元素制作下方的梯形,因?yàn)檎暹呅蚊窟叺膴A角為108度,所以可以藉由三角函數(shù)計(jì)算出上方三角形的高度為59px(100 x cos(54)),寬度為192px(100x sin(54)x 2),下方梯形的高度為95px(100 x sin(72)),長邊的寬度跟上面的三角形一樣都是192px。


CSS進(jìn)行單一div正多邊形變換的方法

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

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

CSS進(jìn)行單一div正多邊形變換的方法

正六邊形

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


CSS進(jìn)行單一div正多邊形變換的方法

所以只要把正五邊形的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;
    }

CSS進(jìn)行單一div正多邊形變換的方法

正七邊形

正七邊形開始就必須再使用after這個偽元素了,因?yàn)檎哌呅伪仨氁鸾鉃槿齻€內(nèi)存塊,分別是用原本的p作為上面的三角形,一個偽元素作為中間的梯形,然后另一個偽元素作為底部的梯形,正七邊形的夾角比較特別不是整數(shù),而是128又4/7度,大概取到小數(shù)第二位是128.57,所以計(jì)算起來結(jié)果就如下圖所示,重點(diǎn)就是必須要清楚地知道長寬是多少。


CSS進(jìn)行單一div正多邊形變換的方法

有了長寬之后,就開始用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;
  }

CSS進(jìn)行單一div正多邊形變換的方法

正八邊形

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


CSS進(jìn)行單一div正多邊形變換的方法

同樣的了解原理,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進(jìn)行單一div正多邊形變換的方法

小結(jié)

以上就是純粹利用CSS做出來的單一div的正多邊形變換,如果熟練的話,其實(shí)加上動畫效果,就可以做出像下面示例這個樣子的變換動畫啰!

CSS進(jìn)行單一div正多邊形變換的方法

關(guān)于CSS進(jìn)行單一div正多邊形變換的方法就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。


網(wǎng)站名稱:CSS進(jìn)行單一div正多邊形變換的方法-創(chuàng)新互聯(lián)
URL標(biāo)題:http://weahome.cn/article/eiiei.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部