来源:自学PHP网 时间:2015-04-14 14:51 作者: 阅读:次
[导读] 主要是利用了css3的 rolate(旋转) 和 skew (倾斜)样式先上代码:html 很简单+ 这里的i标签 用了一个...
主要是利用了css3的 rolate(旋转) 和 skew (倾斜)样式 先上代码: html 很简单
这里的i标签 用了一个第三方库 http://fortawesome.github.io/Font-Awesome/icons/
接下来是css 先来个半圆形button
.cn-button { outline: none; border: none; color: #f06060; text-align: center; font-size: 1.8em; padding-bottom: 1em; height: 3.5em; width: 3.5em; background-color: #fff; position: fixed; left: 50%; margin-left: -1.75em; bottom: -1.75em; border-radius: 50%; cursor: pointer; z-index: 11; } 主要起作用的是 border-radius: 50%;可以试一下,如果想把一个div变成圆形,就用这行代码,那半圆呢? 你把剩下半个挡住不就OK了! 我们把 cn-warpper也变成半圆的
.cn-wrapper { width: 26em; height: 26em; position: fixed; z-index: 10; bottom: 0; left: 50%; margin-left: -200px; border: 1px solid #7C5089; -webkit-transition: all .3s ease; transition: all .3s ease; border-radius: 50%; overflow: hidden; bottom: -13em; -webkit-transform: scale(0); } -webkit-transform: scale(0);是为了让它一开始不显示 接下来是重头戏了,如何把半圆分成5个li 首先给li加基本样式,宽高,让他们重叠 .cn-wrapper li { position: absolute; font-size: 1.5em; width: 10em; height: 10em; overflow: hidden; -webkit-transform-origin: 100% 100%; transform-origin: 100% 100%; background-color: #eee; -webkit-transition: all 1s ease; transition: all 1s ease; color: #aaa; } overflow: hidden;这个必须有,后面说明!
然后 让li变斜,为什么变斜?如果都是正方形,要不然怎么够分呢?? .cn-wrapper li:first-child { left: 50%; top: 50%; margin-top: -1.3em; margin-left: -10em; overflow: hidden; -webkit-transform: rotate(0deg) skew(50deg); } 变斜的关键 -webkit-transform: rotate(0deg) skew(50deg); skew(50deg)就是在水平方向倾斜50度(姑且称之为度),rotate围绕自己旋转0度 也就是不转,第一个li不用转,只用倾斜就可以,后面的li要依次旋转36度,为什么36度? 180/5
然后就是li下的a了
.cn-wrapper li a { display: block; font-size: 1.2em; height: 14.5em; width: 13.5em; position: absolute; bottom: -6.75em; right: -6.75em; text-decoration: none; color: white; -webkit-transition: background-color .3s ease, -webkit-transform .8s ease; transition: background-color .3s ease, -webkit-transform .8s ease; transition: background-color .3s ease, transform .8s ease; text-align: center; padding-top: 2em; padding-right: 20px; -webkit-transform: skew(-50deg) rotate(-70deg); } text-align: center; padding-top: 2em; padding-right: 20px; 这些都是为了设置icon的位置,没什么要说的
-webkit-transform: skew(-50deg) rotate(-70deg); 为了迎合父节点li的变斜,所以skew为负50度,rotate负70 (这样也是为了icon能在div中间显示text-align:center)
接下来你可以把上边的overflow::hidden去掉试试看,是不是全乱了?这段代码就是为了抱住其子节点的样式,即使子节点的样式是乱的,只要不让它显示出来就可以了。 OK,接下来就是一些基本的样式了 全部代码:
|
自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习
京ICP备14009008号-1@版权所有www.zixuephp.com
网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com