纯css圆形网格图片鼠标hover动画特效

当前位置:主页 > CSS3库 > CSS3动画 > 纯css圆形网格图片鼠标hover动画特效
纯css圆形网格图片鼠标hover动画特效
分享:

    插件介绍

    这是一款纯css圆形网格图片鼠标hover动画特效。该特效将四张图片组成一个圆形,当鼠标悬停在某张图片上面时,这张图片就显示未完整的圆形,非常炫酷。

    浏览器兼容性

    浏览器兼容性
    时间:12-27
    阅读:
简要教程

这是一款纯css圆形网格图片鼠标hover动画特效。该特效将四张图片组成一个圆形,当鼠标悬停在某张图片上面时,这张图片就显示未完整的圆形,非常炫酷。

使用方法

HTML代码
<div class="gallery">
  <img src="img/1.jpg" alt="a hot air balloon">
  <img src="img/2.jpg" alt="a sky photo of an old city">
  <img src="img/3.jpg" alt="a small boat">
  <img src="img/4.jpg" alt="a forest">
</div>
		

CSS代码

.container {
  margin: 0;
  min-height: 70vh;
  display: grid;
  place-content: center;
  background: #f2f2f2;
}

.gallery {
  --g: 8px;   /* the gap */
  --s: 400px; /* the size */
  
  display: grid;
  border-radius: 50%;
}
.gallery > img {
  grid-area: 1/1;
  width: 400px;
  aspect-ratio: 1;
  object-fit: cover;
  border-radius: 50%;
  transform: translate(var(--_x,0),var(--_y,0));
  cursor: pointer;
  z-index: 0;
  transition: .3s, z-index 0s .3s;
}
.gallery img:hover {
  --_i: 1;
  z-index: 1;
  transition: transform .2s, clip-path .3s .2s, z-index 0s;
}
.gallery:hover img {
  transform: translate(0,0);
}
.gallery > img:nth-child(1) {
  clip-path: polygon(50% 50%,calc(50%*var(--_i,0)) calc(120%*var(--_i,0)),0 calc(100%*var(--_i,0)),0 0,100% 0,100% calc(100%*var(--_i,0)),calc(100% - 50%*var(--_i,0)) calc(120%*var(--_i,0)));
  --_y: calc(-1*var(--g))
}
.gallery > img:nth-child(2) {
  clip-path: polygon(50% 50%,calc(100% - 120%*var(--_i,0)) calc(50%*var(--_i,0)),calc(100% - 100%*var(--_i,0)) 0,100% 0,100% 100%,calc(100% - 100%*var(--_i,0)) 100%,calc(100% - 120%*var(--_i,0)) calc(100% - 50%*var(--_i,0)));
  --_x: var(--g)
}
.gallery > img:nth-child(3) {
  clip-path: polygon(50% 50%,calc(100% - 50%*var(--_i,0)) calc(100% - 120%*var(--_i,0)),100% calc(100% - 120%*var(--_i,0)),100% 100%,0 100%,0 calc(100% - 100%*var(--_i,0)),calc(50%*var(--_i,0)) calc(100% - 120%*var(--_i,0)));
  --_y: var(--g)
}
.gallery > img:nth-child(4) {
  clip-path: polygon(50% 50%,calc(120%*var(--_i,0)) calc(50%*var(--_i,0)),calc(100%*var(--_i,0)) 0,0 0,0 100%,calc(100%*var(--_i,0)) 100%,calc(120%*var(--_i,0)) calc(100% - 50%*var(--_i,0)));
  --_x: calc(-1*var(--g))
}


		

codepen网址:https://codepen.io/t_afif/pen/ZEoJbvx