首页 > 解决方案 > 倾斜图像而不扭曲它

问题描述

我可以在不扭曲图像的情况下对图像进行此效果吗?我尝试了使用css的倾斜效果,但它以某种方式旋转图像并裁剪了一半,我希望它保持原样,大小相同,一切都保持原样,但边缘像附加的图像,这是我的代码:

div.skewed {
  position: relative;
  height: 140px;
  transform: skew(-2deg) rotate(2deg);
  -webkit-transform: skew(-2deg) rotate(2deg);
  -moz-transform: skew(-2deg) rotate(2deg);
  overflow: hidden;
}

div.skewed > * {
  width: 110%;
  position: absolute;
  top: 50%;
  transform: skew(2deg) rotate(-2deg) translateY(-50%);
  -webkit-transform: skew(2deg) rotate(-2deg) translateY(-50%);
  -moz-transform: skew(2deg) rotate(-2deg) translateY(-50%);
}
<div class="skewed">
  <img src="https://www.todaysparent.com/wp-content/uploads/2013/04/sleeping-baby-article.jpg">
</div>

歪斜的图像

标签: htmlcsscss-transformsskew

解决方案


您可以使用clip-path它来裁剪图像而不扭曲它。使用该polygon函数,您可以通过提供单个角的 x,y 坐标列表来指定自定义形状。如果您使用相对单位(如%.

img {
  width: 25%; /* for demonstration purposes */
  clip-path: polygon(0 0, 60% 0, 100% 30%, 100% 100%, 0 70%);
}
<img src="https://www.todaysparent.com/wp-content/uploads/2013/04/sleeping-baby-article.jpg">

好的

  • 需要最少的代码(只有 1 条简单的 CSS 规则)
  • 保持透明度(您可以设置任何背景)
  • 响应式(您可以轻松缩放图像)

不太好


推荐阅读