是否可以使用CSS对元素进行自由变换-类似于网格变换?
与之最接近的是使用带有三个元素的transform: perspective(400px) rotateY(45deg);
之类的东西,但我希望它是一个连续的img
元素。
答案 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>