CSS网格透视图/变换

时间:2019-06-20 14:32:22

标签: html css css-transforms

是否可以使用CSS对元素进行自由变换-类似于网格变换?

enter image description here

与之最接近的是使用带有三个元素的transform: perspective(400px) rotateY(45deg);之类的东西,但我希望它是一个连续的img元素。

1 个答案:

答案 0 :(得分:1)

您可以考虑3个元素和background-image。诀窍是调整背景大小/背景位置,以产生一张连续图像的错觉。

将鼠标悬停以查看结果:

.box {
  margin: 50px auto;
  width: 200px;
  height: 200px;;
  background-size: 300% auto;
  background-position: center;
  position: relative;
}

.box:before,
.box:after {
  content: "";
  position: absolute;
  width: 100%;
  top: 0;
  bottom: 0;
  background-image: inherit;
  background-size: 300% auto;
  transform: perspective(800px);
  transition: 0.5s all;
}

.box:before {
  right: 100%;
  background-position: left;
  transform-origin: right;
}

.box:after {
  left: 100%;
  background-position: right;
  transform-origin: left;
}

.box:hover::before {
  transform: perspective(800px) rotateY(50deg);
  filter: brightness(0.8);
}

.box:hover::after {
  transform: perspective(800px) rotateY(-50deg);
  filter: brightness(0.8);
}
<div class="box" style="background-image: url(https://picsum.photos/id/1/1000/800)">
</div>