使用css转换和3d旋转的圆形鼠标悬停效果【2例】
今天给大家介绍一个关于如何用css转换和3d旋转在圆上创建不同有趣的悬停效果的教程。
圆形鼠标悬停效果
demo
在今天的教程中,我们将在圆上实现悬停效果。因为我们有边界半径属性,所以我们可以创建圆形,并且它们在网站中经常作为设计元素出现。我特别喜欢看到的一个用途是圆形缩略图,它看起来比通常的矩形要有趣得多。因为这个圆是一个特殊的形状,我们将为它创建一些特殊的悬停效果!
所以,我们开始吧!
HTML
对于大多数示例,我们将使用以下结构:
<ul class=”ch-grid”>
<li>
<div class=”ch-item ch-img-1″>
<div class=”ch-info”>
<h3>Use what you have</h3>
<p>by Angela Duncan <a href=”#”>View on Dribbble</a></p>
</div>
</div>
</li>
<li>
<div class=”ch-item ch-img-2″>
<div class=”ch-info”>
<h3>Common Causes of Stains</h3>
<p>by Antonio F. Mondragon <a href=”#”>View on Dribbble</a></p>
</div>
</div>
</li>
<li>
<div class=”ch-item ch-img-3″>
<div class=”ch-info”>
<h3>Pink Lightning</h3>
<p>by Charlie Wagers <a href=”#”>View on Dribbble</a></p>
</div>
</div>
</li>
</ul>
虽然我们可以在这里使用图像,但我们将通过使用背景图像以便维护更加方便。我们将在以“ch img-
”开头的类中定义它们。另外,我们将有一个带有标题的项目描述分区。
现在,让我们做一些悬停效果!
CSS
我们为列表和列表项定义一些公共样式:
.ch-grid {
margin: 20px 0 0 0;
padding: 0;
list-style: none;
display: block;
text-align: center;
width: 100%;
}
.ch-grid:after,
.ch-item:before {
content: ”;
display: table;
}
.ch-grid:after {
clear: both;
}
.ch-grid li {
width: 220px;
height: 220px;
display: inline-block;
margin: 20px;
}
我们可以使用display: inline-block;
并将其父级的文本对齐属性设置为居中,从而使列表项居中。
一些示例将有不同的结构,我们将详细地研究它们。
实例一
实例一:圆形悬停效果
第一个示例将通过放大描述来显示,还把框阴影做成动画。因此,让我们要定位项目,并设置一个漂亮的框阴影和一个过渡(transition):
.ch-item {
width: 100%;
height: 100%;
border-radius: 50%;
overflow: hidden;
position: relative;
cursor: default;
box-shadow:
inset 0 0 0 16px rgba(255,255,255,0.6),
0 1px 2px rgba(0,0,0,0.1);
transition: all 0.4s ease-in-out;
}
如您之前所注意到的,我们为该项提供了两个类(不是列表项,而是其子分区):一个是ct-item
,另一个用于定义特定的背景图像:
.ch-img-1 {
background-image: url(../images/1.jpg);
}
.ch-img-2 {
background-image: url(../images/2.jpg);
}
.ch-img-3 {
background-image: url(../images/3.jpg);
}
描述元素将被绝对定位,我们将通过设置RGBA值为其提供半透明背景。它的不透明度将为0,我们也将其缩小到0:
.ch-info {
position: absolute;
background: rgba(63,147,147, 0.8);
width: inherit;
height: inherit;
border-radius: 50%;
overflow: hidden;
opacity: 0;
transition: all 0.4s ease-in-out;
transform: scale(0);
}
项目标题将有一些合适的填充和边距以及平滑的文本阴影:
.ch-info h3 {
color: #fff;
text-transform: uppercase;
letter-spacing: 2px;
font-size: 22px;
margin: 0 30px;
padding: 45px 0 0 0;
height: 140px;
font-family: ‘Open Sans’, Arial, sans-serif;
text-shadow:
0 0 1px #fff,
0 1px 2px rgba(0,0,0,0.3);
}
段落元素有0不透明度和一个转换(我们希望在悬停时淡入,但有延迟):
.ch-info p {
color: #fff;
padding: 10px 5px;
font-style: italic;
margin: 0 30px;
font-size: 12px;
border-top: 1px solid rgba(255,255,255,0.5);
opacity: 0;
transition: all 1s ease-in-out 0.4s;
}
链接将以大写字母显示,我们将使悬停颜色变为黄色:
.ch-info p a {
display: block;
color: rgba(255,255,255,0.7);
font-style: normal;
font-weight: 700;
text-transform: uppercase;
font-size: 9px;
letter-spacing: 1px;
padding-top: 4px;
font-family: ‘Open Sans’, Arial, sans-serif;
}
.ch-info p a:hover {
color: rgba(255,242,34, 0.8);
}
现在,是有趣的悬停动作!
该项目将把其框阴影做成动画,半径从16px到1px扩散:
.ch-item:hover {
box-shadow:
inset 0 0 0 1px rgba(255,255,255,0.1),
0 1px 2px rgba(0,0,0,0.1);
}
描述将淡入并缩放到1:
.ch-item:hover .ch-info {
transform: scale(1);
opacity: 1;
}
描述的那一段会慢慢消失(延迟):
.ch-item:hover .ch-info p {
opacity: 1;
}
这就是第一个实例了。
execcodegetcode
实例二
实例二:圆形悬停效果
本例中的html结构与第一个相同。
在本例中,我们将使用项的框阴影填充圆,并用作描述的背景。
.ch-item {
width: 100%;
height: 100%;
border-radius: 50%;
position: relative;
cursor: default;
box-shadow:
inset 0 0 0 0 rgba(200,95,66, 0.4),
inset 0 0 0 16px rgba(255,255,255,0.6),
0 1px 2px rgba(0,0,0,0.1);
transition: all 0.4s ease-in-out;
}
背景图片:
.ch-img-1 {
background-image: url(../images/4.jpg);
}
.ch-img-2 {
background-image: url(../images/5.jpg);
}
.ch-img-3 {
background-image: url(../images/6.jpg);
}
描述将缩小:
.ch-info {
position: absolute;
width: 100%;
height: 100%;
border-radius: 50%;
overflow: hidden;
opacity: 0;
transition: all 0.4s ease-in-out;
transform: scale(0);
backface-visibility: hidden;
}
设计排版元素的样式:
.ch-info h3 {
color: #fff;
text-transform: uppercase;
position: relative;
letter-spacing: 2px;
font-size: 22px;
margin: 0 30px;
padding: 65px 0 0 0;
height: 110px;
font-family: ‘Open Sans’, Arial, sans-serif;
text-shadow:
0 0 1px #fff,
0 1px 2px rgba(0,0,0,0.3);
}
.ch-info p {
color: #fff;
padding: 10px 5px;
font-style: italic;
margin: 0 30px;
font-size: 12px;
border-top: 1px solid rgba(255,255,255,0.5);
}
.ch-info p a {
display: block;
color: rgba(255,255,255,0.7);
font-style: normal;
font-weight: 700;
text-transform: uppercase;
font-size: 9px;
letter-spacing: 1px;
padding-top: 4px;
font-family: ‘Open Sans’, Arial, sans-serif;
}
.ch-info p a:hover {
color: rgba(255,242,34, 0.8);
}
悬停时,我们将框阴影(略带红色的一个)扩散半径:
.ch-item:hover {
box-shadow:
inset 0 0 0 110px rgba(200,95,66, 0.4),
inset 0 0 0 16px rgba(255,255,255,0.8),
0 1px 2px rgba(0,0,0,0.1);
}
我们将放大描述并将其淡入:
.ch-item:hover .ch-info {
opacity: 1;
transform: scale(1);
}
execcodegetcode