使用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