css3組件實戰--絢麗效果篇


代碼地址如下:
http://www.demodashi.com/demo/11656.html

一.3D風景動態骰子

.3D風景動態骰子

在線演示

1、css3D、動畫基礎知識預備

2、創建一個3D場景
先放置一個.box的div父容器,在box里放置一個.dice的div,然后在其里面放置6個div,分別表示骰子的6個面。

<div class="box">
 <div class="dice">
   <div class="surface front ">anyway style(text or img)</div>
     <div class="surface left">anyway style(text or img)</div>
     <div class="surface right">anyway style(text or img)</div>
     <div class="surface bottom">anyway style(text or img)</div>
     <div class="surface top">anyway style(text or img)</div>
     <div class="surface back">anyway style(text or img)</div>		
   </div>
</div>

2、設置CSS樣式

.dice {
	width:200px;
	height:200px;
	position:relative;
	margin:100px auto;
	transform-style:preserve-3d;
	-webkit-transform-style:preserve-3d;
}

transform-style 屬性規定如何在 3D 空間中呈現被嵌套的元素,默認是其子元素不呈現3D效果,所以我們需要添加preserve-3d值,讓其子元素保留其 3D 效果。
接下來,我們制作立方體的每一個面:

.face {
    position: absolute;
    top: 0;
    left: 0;
    width: 300px;
    height: 300px;
    background: #666;
    opacity: 0.8;
    font-size: 60px;
    text-align: center;
    line-height: 200px;
    font-weight: bold;
    color: #fff;
    border: 1px solid #fff;
    -webkit-transition: all .3s;
    transition: all .3s;
}

.face img {
    width: 100%;
    height: 100%;
}

.front {
    transform: rotateY(0) translateZ(100px);
}

.back {
    transform: translateZ(-100px) rotateY(180deg);
}

.left {
    transform: rotateY(-90deg) translateZ(100px);
}

.right {
    transform: rotateY(90deg) translateZ(100px);
}

.top {
    transform: rotateX(90deg) translateZ(100px);
}

.bottom {
    transform: rotateX(90deg) translateZ(-100px);
}

在上面的代碼中,我們使用transform的rotate()和translateZ()來轉換每一面,平移都是寬度的一半。
要注意rotate()和translateZ()的順序,順序不同,轉換的結果也會不一樣,比如左側.left這一面,在這里,我們是先繞着Y軸順時針旋轉90,然后再在Z軸的正方向平移150,如果你先平移后旋轉,結果就不一樣了,你可以試試。
最后,我們還給div.cude加上動畫:

@-webkit-keyframes rotate {
    from {
        transform: rotateX(0deg) rotateY(0deg);
    }
    to {
        transform: rotateX(360deg) rotateY(360deg);
    }
}

二.圖片倒影效果

1、box-reflect(方法一)

(1)使用box-reflect屬性最容易實現圖片倒影效果。

box-reflect屬性介紹:
box-reflect:<direction> <offset>? <mask-box-image>?

參數說明:

:表示倒影的方向,可能值:above、below、left、right(上下左右);
:表示倒影與元素之間的間隔;
:表示遮罩圖像,可為url地址、漸變

(2) 具體代碼

只需簡單的放置一張圖片:

<img src="images/example.jpg" alt="" />

(3)設置樣式

直接使用box-reflect方法:

img {
   -webkit-box-reflect: below 0 -webkit-linear-gradient(top, rgba(250, 250, 250, 0), rgba(250, 250, 250, .0) 20%, rgba(250, 250, 250, .3));
}

在這個方法中,使用漸變來充當遮罩圖像,效果如下圖所示:

運行效果圖

給box-reflec設置url屬性可以用另一張圖片來自定義倒影效果:

img {
   -webkit-box-reflect: below 0 url(images/star.png);
}

自定義倒影效果

注意:由於box-reflect方法目前只有webkit引擎的瀏覽器才支持,所以考慮兼容性可以使用下面介紹的第二種方法

2、偽元素方法(方法二)

(1) 偽元素方法本質上是復制圖片,結合 transform的用法然后翻轉,最后一樣是使用漸變來充當遮罩層,覆蓋在翻轉的圖片之上。

(2) 具體代碼

與第一種方式略有不同,這里用一個div包裹住圖片:

<div class="box-reflect">
	![](images/example.jpg)
</div>

(3)設置樣式

先將圖片克隆一份,然后翻轉過來:

.box-reflect {
    position: relative;
  width: 150px;
    float: left;
    margin-right: 40px;
}
.box-reflect img {
    width: 100%;
    height: 100%;
}
.box-reflect:before {
    background: url(images/example.jpg) no-repeat;
    background-size: 100% 100%;
    transform: scaleY(-1);
    /*設置半透明增強倒影效果*/
    opacity: 0.5;
    /*IE下設置透明*/。
    filter: alpha(opacity='50');
}
.box-reflect:before, .box-reflect:after {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 100%;
    left: 0;
    content: "";
}

注意:這里的transform:scaleY(-1)的作用與transform:rotateX(-180deg)等同,可聯想一下transform:scaleX(-1)的效果

然后,添加一層漸變,讓其覆蓋在倒影的上面,漸變的值可根據實際效果調整:

.box-reflect:after {
    background-image: -moz-linear-gradient(bottom, rgb(0,0,0) 20%, rgba(0,0,0,0) 90%);
    background-image: -o-linear-gradient(rgba(0,0,0,0) 10%, rgb(0,0,0) 30%);
    background-image: -webkit-linear-gradient(bottom,rgb(0,0,0) 20%,rgba(0,0,0,0) 90%);
    filter: progid:DXImageTransform.Microsoft.Gradient(gradientType=0,startColor=0, EndColorStr=#000000);
}

運行結果圖

三.心跳效果

1.首先用css畫出一個靜態的紅心

#heart {
   position: relative;
   width: 100px;
   height: 90px;
}
#heart:before,
#heart:after {
   position: absolute;
   content: "";
   left: 50px;
   top: 0;
   width: 50px;
   height: 80px;
   background: red;
   -moz-border-radius: 50px 50px 0 0;
   border-radius: 50px 50px 0 0;
   -webkit-transform: rotate(-45deg);
      -moz-transform: rotate(-45deg);
       -ms-transform: rotate(-45deg);
        -o-transform: rotate(-45deg);
           transform: rotate(-45deg);
   -webkit-transform-origin: 0 100%;
      -moz-transform-origin: 0 100%;
       -ms-transform-origin: 0 100%;
        -o-transform-origin: 0 100%;
           transform-origin: 0 100%;
}
#heart:after {
   left: 0;
   -webkit-transform: rotate(45deg);
      -moz-transform: rotate(45deg);
       -ms-transform: rotate(45deg);
        -o-transform: rotate(45deg);
           transform: rotate(45deg);
   -webkit-transform-origin: 100% 100%;
      -moz-transform-origin: 100% 100%;
       -ms-transform-origin: 100% 100%;
        -o-transform-origin: 100% 100%;
           transform-origin :100% 100%;
}

最后給這個紅心增加動畫即可
心跳效果

.heartbeat {
    -webkit-animation-name: heartbeat;
	-webkit-animation-duration: 0.83s;
	-webkit-animation-timing-function: ease-in-out;
	-webkit-animation-iteration-count: infinite;
}
@keyframes heartbeat {
	from {
	    opacity:0.1;
    }
    50% {
	    opacity:1;
    }
    to {
	    opacity:0.1;
    }
}

四.3D按鈕

1.創建div

放置一個要設置成3D按鈕的元素,這里使用a標簽:

<a href="#" class="3dButton">3dButton</a>

  1. 設置CSS樣式

3D效果主要是依靠陰影(box-shadow)和新的顏色屬性HSL來實現。
(1)box-shadow: h-shadow v-shadow blur spread color inset

h-shadow:必需。水平陰影的位置。允許負值。
v-shadow:必需。垂直陰影的位置。允許負值。
blur:可選。模糊距離。
spread:可選。陰影的尺寸。
color:可選。陰影的顏色。請參閱 CSS 顏色值。
inset:可選。將外部陰影 (outset) 改為內部陰影。

(2)HSL(H,S,L)。HSL色彩模式是工業界的一種顏色標准,HSL即是代表色調,飽和度,亮度三個通道的顏色,這個標准幾乎包括了人類視力所能感知的所有顏色,是目前運用最廣的顏色系統之一。

H:Hue(色調)。0(或360)表示紅色,120表示綠色,240表示藍色,也可取其他數值來指定顏色。取值為:0 - 360
S:Saturation(飽和度)。取值為:0.0% - 100.0%
L:Lightness(亮度)。取值為:0.0% - 100.0%

了解完基礎知識后,下面就來看看3D按鈕效果怎么實現。

box-shadow: 
    inset rgba(255, 254, 255, 0.6) 0 0.3em .3em, 
    inset rgba(0, 0, 0, 0.15) 0 -0.1em .3em, 
    hsl(0, 0%, 60%) 0 .1em 3px, hsl(0, 0%, 45%) 0 .3em 1px, 
	rgba(0, 0, 0, 0.2) 0 .5em 5px;

如上代碼所示,這里使用了5層陰影,1和2層是內陰影,這是為了實現上下兩邊光滑效果,你也可以去除這兩個;第5層只是普通的陰影;第3層是為了更真實,可有可無;關鍵是第4層,實現類似於border的實投影。

為了更完美來按鈕實現點擊效果,這里主要是想讓實陰影消失:

.button:active {
	box-shadow: inset rgba(255, 255, 255, 0.6) 0 0.3em .3em, inset rgba(0, 0, 0, 0.2) 0 -0.1em .3em, 
	rgba(0, 0, 0, 0.4) 0 .1em 1px, 
	rgba(0, 0, 0, 0.2) 0 .2em 6px;
	transform: translateY(.2em);
}

3D按鈕

最后來個示例中按鈕的風形形狀效果,只有了解下border-radius的高級用法就可以了:
border-radius: 1em 5em/5em 1em;

/的前后分別指的是水平半徑和垂直半徑。

五.漸變炫彩邊框

1、html代碼

<div class="gradient-border gradient-border-more">
  <span></span>
  ![](images/eg.jpg)
</div>

注意這里的span標簽是這個效果的重點和技巧所在。

2、設置CSS樣式

我們通過gradient-border和span的:before和:after偽元素來實現漸變邊框。

.gradient-border {
	position:relative;
	width:200px;
	height:200px;
	background:gray;
}
.gradient-border:before,
.gradient-border:after,
.gradient-border span:first-child:before,
.gradient-border span:first-child:after {
	content:"";
	position:absolute;
	background:red;
	-webkit-transition:all .2s ease;
	transition:all .2s ease;
}
/*上邊邊框*/
.gradient-border:before {
	width:0;  // 初始寬度
	top:-2px;
	right:0;
	height:2px;
}
/*右邊邊框*/
.gradient-border:after {
	width:2px;
	height:0;  // 初始高度
	right:-2px;
	bottom:0;
}
/*下邊邊框*/
.gradient-border span:first-child:before {
	width:0;  // 初始寬度
	height:2px;
	bottom:-2px;
	left:0;
}
/*左邊邊框*/
.gradient-border span:first-child:after {
	width:2px;
	height:0;  // 初始高度
	top:0;
	left:-2px;
}

漸變炫彩邊框

這這個地方使用了.gradient-border里的:before和:after,以及span里的:before和:after制作了邊框。

3、增加鼠標hover動畫

鼠標移動上去的動畫,原理是通過就是改變邊框的寬高。

.gradient-border:hover:before,
.gradient-border:hover span:first-child:before {
	width:calc(100% + 2px);
}
.gradient-border:hover:after,
.gradient-border:hover span:first-child:after {
	height:calc(100% + 2px);
}
/*添加過渡延遲時間*/
.gradient-border-more:hover:before,
.gradient-border-more:hover span:first-child:before {
	-webkit-transition-delay:.2s;
	transition-delay:.2s;
}
項目文件截圖:

css3組件實戰--絢麗效果篇

代碼地址如下:
http://www.demodashi.com/demo/11656.html

注:本文著作權歸作者,由demo大師代發,拒絕轉載,轉載需要作者授權


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM