Html CSS3 变换偏斜一侧

声明:本页面是StackOverFlow热门问题的中英对照翻译,遵循CC BY-SA 4.0协议,如果您需要使用它,必须同样遵循CC BY-SA许可,注明原文地址和作者信息,同时你必须将它归于原作者(不是我):StackOverFlow 原文地址: http://stackoverflow.com/questions/19761202/
Warning: these are provided under cc-by-sa 4.0 license. You are free to use/share it, But you must attribute it to the original authors (not me): StackOverFlow

提示:将鼠标放在中文语句上可以显示对应的英文。显示中英文
时间:2020-08-29 15:00:56  来源:igfitidea点击:

CSS3 Transform Skew One Side

htmlcsscss-shapes

提问by Syed

Is it possible to create "CSS3 Transform Skew One Side"

是否可以创建“CSS3 Transform Skew One Side”

I found one solution, but it's not useful to me, because I need to use a image for background (not color)

我找到了一个解决方案,但它对我没有用,因为我需要使用图像作为背景(不是颜色)

#skewOneSide {
    border-bottom: 40px solid #FF0000;
    border-left: 50px solid rgba(0, 0, 0, 0);
    height: 0;
    line-height: 40px;
    width: 100px;
}

Even this JsFiddleis not useful as well (skewed area should be transparent)

甚至这个JsFiddle也没有用(倾斜区域应该是透明的)

采纳答案by Diego

Try this:

尝试这个:

To unskewthe image use a nested div for the image and give it the opposite skew value. So if you had 20deg on the parent then you can give the nested (image) div a skew value of -20deg.

取消倾斜图像,为图像使用嵌套的 div 并为其赋予相反的倾斜值。因此,如果您在父级上有 20deg,那么您可以为嵌套(图像)div 提供 -20deg 的偏斜值。

.container {
  overflow: hidden;
}

#parallelogram {
  width: 150px;
  height: 100px;
  margin: 0 0 0 -20px;
  -webkit-transform: skew(20deg);
  -moz-transform: skew(20deg);
  -o-transform: skew(20deg);
  background: red;
  overflow: hidden;
  position: relative;
}

.image {
  background: url(http://placekitten.com/301/301);
  position: absolute;
  top: -30px;
  left: -30px;
  right: -30px;
  bottom: -30px;
  -webkit-transform: skew(-20deg);
  -moz-transform: skew(-20deg);
  -o-transform: skew(-20deg);
}
<div class="container">
  <div id="parallelogram">
    <div class="image"></div>
  </div>
</div>

The example:

这个例子:

http://jsfiddle.net/diegoh/mXLgF/1154/

http://jsfiddle.net/diegoh/mXLgF/1154/

回答by Jake

I know this is old, but I would like to suggest using a linear-gradient to achieve the same effect instead of margin offset. This is will maintain any content at its original place.

我知道这是旧的,但我想建议使用线性渐变来实现相同的效果而不是边距偏移。这将在其原始位置保留任何内容。

http://jsfiddle.net/zwXaf/2/

http://jsfiddle.net/zwXaf/2/

HTML

HTML

<ul>
    <li><a href="#">One</a></li>
    <li><a href="#">Two</a></li>
    <li><a href="#">Three</a></li>
</ul>

CSS

CSS

/* reset */
ul, li, a {
    margin: 0; padding: 0;
}
/* nav stuff */
ul, li, a {
    display: inline-block;
    text-align: center;
}
/* appearance styling */
ul {
    /* hacks to make one side slant only */
    overflow: hidden;
    background: linear-gradient(to right, red, white, white, red);
}
li {
    background-color: red;
     transform:skewX(-20deg);
    -ms-transform:skewX(-20deg);
    -webkit-transform:skewX(-20deg);
}
li a {
    padding: 3px 6px 3px 6px;
    color: #ffffff;
    text-decoration: none;
    width: 80px;
     transform:skewX(20deg);
    -ms-transform:skewX(20deg);
    -webkit-transform:skewX(20deg);
}

回答by Max Payne

you can make that using transform and transform origins.

您可以使用变换和变换原点来实现。

Combining various transfroms gives similar result. I hope you find it helpful. :) See these examples for simpler transforms. this has left point :

结合各种转换给出了类似的结果。我希望你觉得这对你有帮助。:) 有关更简单的转换,请参阅这些示例。这已经离开了一点:

div {    
    width: 300px;
    height:200px;
    background-image: url('');
    -webkit-transform: perspective(300px) rotateX(-30deg);
    -o-transform: perspective(300px) rotateX(-30deg);
    -moz-transform: perspective(300px) rotateX(-30deg);
    -webkit-transform-origin: 100% 50%;
    -moz-transform-origin: 100% 50%;
    -o-transform-origin: 100% 50%;
    transform-origin: 100% 50%;
    margin: 10px 90px;
}
<div></div>

This has right skew point :

这有正确的偏斜点:

div {    
    width: 300px;
    height:200px;
    background-image: url('');
    -webkit-transform: perspective(300px) rotateX(-30deg);
    -o-transform: perspective(300px) rotateX(-30deg);
    -moz-transform: perspective(300px) rotateX(-30deg);
    -webkit-transform-origin: 0% 50%;
    -moz-transform-origin: 0% 50%;
    -o-transform-origin: 0% 50%;
    transform-origin: 0% 50%;
    margin: 10px 90px;
}
<div></div>

what transform: 0% 50%;does is it sets the origin to vertical middle and horizontal left of the element. so the perspective is not visible at the left part of the image, so it looks flat. Perspective effect is there at the right part, so it looks slanted.

是什么transform: 0% 50%;做的是它设置原点到元素的中间垂直和水平左。所以透视图在图像的左侧不可见,所以它看起来很平坦。右侧有透视效果,所以看起来是倾斜的。

回答by OzgurG

Maybe you want to use CSS "clip-path" (Works with transparency and background)

也许您想使用 CSS“剪辑路径”(适用于透明度和背景)

"clip-path" reference: https://developer.mozilla.org/en-US/docs/Web/CSS/clip-path

“剪辑路径”参考:https: //developer.mozilla.org/en-US/docs/Web/CSS/clip-path

Generator: http://bennettfeely.com/clippy/

生成器:http: //bennettfeely.com/clippy/

Example:

例子:

/* With percent */
.element-percent {
  background: red;
  width: 150px;
  height: 48px;
  display: inline-block;
  
  clip-path: polygon(0 0, 100% 0%, 75% 100%, 0% 100%);
}

/* With pixel */
.element-pixel {
  background: blue;
  width: 150px;
  height: 48px;
  display: inline-block;
  
  clip-path: polygon(0 0, 100% 0%, calc(100% - 32px) 100%, 0% 100%);
}

/* With background */
.element-background {
  background: url(https://images.pexels.com/photos/170811/pexels-photo-170811.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=750&w=1260) no-repeat center/cover;
  width: 150px;
  height: 48px;
  display: inline-block;
  
  clip-path: polygon(0 0, 100% 0%, calc(100% - 32px) 100%, 0% 100%);
}
<div class="element-percent"></div>

<br />

<div class="element-pixel"></div>

<br />

<div class="element-background"></div>

回答by darthmaim

You try with the :beforewas pretty close, the only thing you had to change was actually using skew instead of the borders: http://jsfiddle.net/Hfkk7/1101/

您尝试使用:before非常接近,您唯一需要更改的实际上是使用倾斜而不是边框​​:http: //jsfiddle.net/Hfkk7/1101/

Edit: Your border approach would work too, the only thing you did wrong was having the before element on top of your div, so the transparent border wasnt showing. If you would have position the pseudo element to the left of your div, everything would have worked too: http://jsfiddle.net/Hfkk7/1102/

编辑:你的边框方法也可以,你做错的唯一一件事是在你的 div 顶部放置了 before 元素,所以没有显示透明边框。如果您将伪元素放置在 div 的左侧,那么一切都会正常工作:http: //jsfiddle.net/Hfkk7/1102/