欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

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

小編給大家分享一下純CSS如何實(shí)現(xiàn)單一div的正多邊形變換,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

創(chuàng)新互聯(lián)公司成立于2013年,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目成都做網(wǎng)站、網(wǎng)站制作、成都外貿(mào)網(wǎng)站建設(shè)網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢想脫穎而出為使命,1280元清澗做網(wǎng)站,已為上家服務(wù),為清澗各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話:028-86922220

正三角形

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

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

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

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

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

正方形

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

正五邊形

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

純CSS如何實(shí)現(xià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如何實(shí)現(xiàn)單一div的正多邊形變換

正六邊形

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

純CSS如何實(shí)現(xià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如何實(shí)現(xiàn)單一div的正多邊形變換

正七邊形

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

純CSS如何實(shí)現(xià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如何實(shí)現(xiàn)單一div的正多邊形變換

正八邊形

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

純CSS如何實(shí)現(xià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如何實(shí)現(xiàn)單一div的正多邊形變換

小結(jié)

以上就是純粹利用CSS做出來的單一div的正多邊形變換,如果熟練的話,其實(shí)加上動(dòng)畫效果,就可以做出像下面示例這個(gè)樣子的變換動(dòng)畫啰!不過下面的示例有再另外用一個(gè)div包在外面做大小的變換動(dòng)畫,避免因?yàn)榇笮〉淖儞Q造成銜接處的不密合,大家可以參考看看喔!

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

以上是“純CSS如何實(shí)現(xiàn)單一div的正多邊形變換”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

標(biāo)題名稱:純CSS如何實(shí)現(xiàn)單一div的正多邊形變換
轉(zhuǎn)載來于:http://aaarwkj.com/article44/ihhiee.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供軟件開發(fā)網(wǎng)站建設(shè)、建站公司、域名注冊、用戶體驗(yàn)、移動(dòng)網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站建設(shè)網(wǎng)站維護(hù)公司
午夜av在线毛片免费观看| av中文字幕国产精品| 国产欧美日本综合一区| 黄色高清无遮挡在线观看| av免费在线不卡观看| 日本欧美国产污黄在线观看| 女同毛片一区二区三区| 欧美高清一区二区三区不卡 | 黑人巨大亚洲一区二区久| 欧美日韩亚洲中文综合网| 成熟人妻中文字幕在线看| 97色伦97色伦国产在线| 国产老熟女高潮一区二区| 中文字幕成人资源网站| 密臀av一区二区三区| 日韩最新人妻在线不卡| 传媒视频免费在线观看| 亚洲女人天堂av在线| 亚洲社区一区二区三区四区| 亚洲国产一区二区三区三州| 亚洲成人日韩成人av| 日本在线精品在线观看| 国产一区二区毛多内射| 精品一区二区三区亚洲| 99久久精品人妻少妇一| 不用播放器的av蜜臀| 很黄很刺激的视频中文字幕| 国产黄色片子在线观看| 国产高清在线a视频大全| av男人的天堂在线免费| 亚洲视一区二区三区四区| 永久永久免费黄色一级片| 日韩在线不卡播放视频| 又黄又爽又刺激的性视频| 夜夜春久久天堂亚洲精品| 久久亚洲中文字幕乱码| 欧美午夜一区二区电影| 亚洲一区二区三区久久精品| 欧美一区二区国产精品日韩| 黄色亚洲日本欧美在线观看| 中文字幕乱码人妻一区|