clip-path 相关问题

一个CSS属性,可以指定要显示的对象的特定区域。

Masking-仅在特定div顶部显示div?

我正在尝试使用HTML和CSS创建“眨眼”动画。我想要的是,当眨眼时,眼球没有显示出来。从代码中可以看到,眼睛由4个组成。

回答 1 投票 1

如何从左侧开始按百分比填充颜色到甜甜圈SVG路径?

我有一个甜甜圈SVG路径。它必须从左侧开始填充颜色,并且必须在右侧结束并且必须按百分比填充。看到这个:我试图像这样实现旋转的clipPath:&...

回答 1 投票 0

clipPathUnits =“ objectBoundingBox”在SVG中的Chrome中错误的单位

[当我使用clipPathUnits =“ objectBoundingBox”时,我正在处理Chrome浏览器中的SVG中的单元数奇怪的问题。这是我可以想到的最窄的版本,可以在Firefox中正常使用:

回答 1 投票 0

SVG圆角三角形梯度叠加和背景图像

我有下面的代码被创建一个简单的圆角三角形形状,其具有紫色梯度。我试图插入背景图片,将填补形状渐变下面创建一个...

回答 2 投票 2

我将如何动画与jQuery夹路径

我试图在创建鼠标动画按钮,但我有一些问题动画。我尝试了好几种办法让它做,不幸的是,我不能。动作应该是这样的......

回答 1 投票 2

夹路径动态转换来填充容器

我正在一个反应 组分,我想能够与它的尺寸,从一个x,y宽度,和高度的矩形区域计算出的夹路径沿着传递任何图像上。这部分我有...

回答 1 投票 0

如果我使用,clipPath无法正常工作 在clipPath中,但它适用于

我正在尝试使用svg创建一个clipPath图像。我正在尝试使用SVG的原生clipPath方法。我的问题是,如果我使用图像里面的路径将不会显示。但如果我用...

回答 1 投票 2

循环中的clip-path在safari中无法正常工作

我有一个剪辑元素列表。我正在使用CSS3剪辑路径方法将图像剪辑到SVG路径。裁剪工作完美,但在safari(V 12.1.4)中裁剪的位置......

回答 1 投票 0

剪切路径更改时的悬停过渡

使用此代码,悬停效果有效,右下角消失但没有过渡,这有什么问题吗? .mydiv:hover {background-color:blue;剪切路径:多边形(...

回答 2 投票 1

最简单的方法将多边形剪辑路径转换为Microsoft Edge支持的“clippath”svg?

例如,我有一个css类,其中应用了多边形剪辑路径,如下所示:.services-image-left {-webkit-clip-path:polygon(0 0,97%0,83%100%,0% 100%); clip-path:polygon(0 0,...

回答 1 投票 1

在悬停已翻译的剪辑路径多边形时,将阴影放在错误的位置

我有一个包含3个三角形的列表,当我将鼠标悬停在其上时,我想要应用一个阴影。翻译最后2个三角形,使它们并排放置。当我将鼠标悬停在...的盒子上时

回答 1 投票 0

js变量到css [clip-path img gallery]

每当有人点击按钮时,我都会尝试在每张图片中创建一个随机剪辑路径。由于某种原因,仅切割第一张图像。其他人保持不变。我在codepen中发送代码并剪切。 ...

回答 1 投票 2

如何将Clip-Path用于倾斜边缘?

目前使用此CSS从左到右向上倾斜:clip-path:polygon(0 0,100%0,100%calc(100% - 3vw),0 100%);它对于响应式解决方案非常有效......

回答 1 投票 2

如何为CustomClipper创建的窗口小部件制作合适的边框和阴影

我在ClipPath中有一个使用CustomClipper的Container小部件。一切正常,我有所需的小部件形状。但是,我找不到为这个自定义制作阴影的方法......

回答 2 投票 0

CSS旋转表但保持单元格方向

我有一个有角度的页脚:.angled {background-color:red;身高:120px;宽度:100%; -webkit-clip-path:polygon(0 40%,100%0,100%100%,0 100%); clip-path:polygon(0 40%,100%0,100%......

回答 1 投票 0

在剪辑路径中生成平滑曲线:多边形

我有一个 div 元素,我想在其中使用剪辑路径添加内部曲线:多边形 css ... 我已经达到了基本形状,但无法平滑曲线。 HTML: <... 我有一个 div 元素,我想在其中使用剪辑路径添加内部曲线:多边形 css ... 我已经达到了基本形状,但无法平滑曲线。 HTML: <div id="clip_element"> </div> CSS: #clip_element { background-image: -webkit-linear-gradient(bottom, #c0c0c0, #adadad, #9a9a9a, #888888, #767676); background-image: -o-linear-gradient(bottom, #c0c0c0, #adadad, #9a9a9a, #888888, #767676); background-image: linear-gradient(to top, #c0c0c0, #adadad, #9a9a9a, #888888, #767676); -webkit-border-radius: 15px; -moz-border-radius: 15px; -webkit-clip-path: polygon(0% 0%,100% 0%,100% 70%,90% 80%,80% 90%,70% 100%,0% 100%); clip-path: polygon(0% 0%,100% 0%,100% 70%,90% 80%,80% 90%,70% 100%,0% 100%); } 如何使用 clip-path:polygon 使曲线平滑? 你可以通过使用伪元素:after来拥有它。这是使用它的答案。希望对您有所帮助。 #clip_element { width:200px; height:75px; background-image: -webkit-linear-gradient(bottom, #c0c0c0, #adadad, #9a9a9a, #888888, #767676); background-image: -o-linear-gradient(bottom, #c0c0c0, #adadad, #9a9a9a, #888888, #767676); background-image: linear-gradient(to top, #c0c0c0, #adadad, #9a9a9a, #888888, #767676); -webkit-border-radius: 15px; -moz-border-radius: 15px; position:relative; } div#clip_element:after { content: ""; position: absolute; width: 60px; height: 60px; background: #fff; right: -10px; bottom: -30px; border-radius: 50%; } <div id="clip_element"> </div> 或者,您可以使用 svg 剪辑路径或将 svg 转换为 css 剪辑路径。所以,多边形采用 svg 格式。 <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" viewBox="0 0 200.1 100.1" xml:space="preserve"> <style type="text/css"> .smooth_polygon{fill:#ababab;} </style> <path class="smooth_polygon" d="M200.1,15.7v40.9c-13.8-4.5-29.5-3-42.7,5.6c-13.4,8.8-21.1,23-22.2,37.9H15.6C7,100.1,0,93.1,0,84.5V15.6 C0,7,7,0,15.6,0h168.9C193.1,0.1,200.1,7.1,200.1,15.7z"/> </svg> 创建并导出 svg 后,您可以直接在我们的 css 样式中使用带有“clip-path”属性和值路径(“d 属性值”)的路径标记 d 属性值。下面给出的例子, .smooth_curve_box { width:210.1px; height: 100.1px; clip-path: path("M200.1,15.7v40.9c-13.8-4.5-29.5-3-42.7,5.6c-13.4,8.8-21.1,23-22.2,37.9H15.6C7,100.1,0,93.1,0,84.5V15.6 C0,7,7,0,15.6,0h168.9C193.1,0.1,200.1,7.1,200.1,15.7z"); background-image: linear-gradient(to top, #c0c0c0, #adadad, #9a9a9a, #888888, #767676); } <div class="smooth_curve_box"> </div> 但是那个被剪裁的路径没有响应,这意味着 svg 的宽度和高度只有那个宽度和高度只剪裁在元素上。上面的示例显示 svg 的宽度为 200.1px,但元素“smooth_curve_box”的宽度为 210.1px。所以,只有 200.1px 宽度的区域只被裁剪,剩下的都是空的。 如果我们想要响应式裁剪区域,那么我们需要将 svg 路径 d 属性值从绝对路径转换为相对路径。 转换后可以得到路径d属性值如“M1,0.157 v0.409 c-0.069,-0.045,-0.147,-0.03,-0.213,0.056 c-0.067,0.088,-0.105,0.23,-0.111, 0.379 H0.078 C0.035,1,0,0.93,0,0.844 V0.156 C0,0.07,0.035,0,0.078,0 h0.844 C0.965,0.001,1,0.071,1,0.157”。 但是不能直接用到css中。因此,我们需要在下面给出的 html 示例中添加一些代码。 .clip_svg { position: absolute; pointer-events: none; } .smooth_curve_box_2 { width: 100%; height: 100.1px; background-image: linear-gradient(to top, #c0c0c0, #adadad, #9a9a9a, #888888, #767676); clip-path: url(#clip-path-id); margin-bottom: 2rem; } .smooth_curve_box_3 { width: 200.1px; height: 100.1px; background-image: linear-gradient(to top, #c0c0c0, #adadad, #9a9a9a, #888888, #767676); clip-path: url(#clip-path-id); } <svg class="clip_svg"> <clipPath id="clip-path-id" clipPathUnits="objectBoundingBox"><path d="M1,0.157 v0.409 c-0.069,-0.045,-0.147,-0.03,-0.213,0.056 c-0.067,0.088,-0.105,0.23,-0.111,0.379 H0.078 C0.035,1,0,0.93,0,0.844 V0.156 C0,0.07,0.035,0,0.078,0 h0.844 C0.965,0.001,1,0.071,1,0.157"></path></clipPath> </svg> <div class="smooth_curve_box_2"></div> <div class="smooth_curve_box_3"></div> 以上示例,第二个元素看起来不错,但第一个元素不是。这里发生了什么?因为响应式剪辑路径仅基于宽高比工作。 如果我们只想在部分区域响应,那么我们需要另一个 svg 路径到 css 剪辑路径转换器here. 这里是使用上述在线 svg 路径转换器将 svg 路径转换为 css 剪辑路径的示例,其中部分区域仅响应。 .smooth_curve_box_4 { width:100%; height: 300px; clip-path: polygon(calc(100% - 0px) 15.7px, calc(100% - 0px) calc(100% - 43.5px), calc(100% - 0px) calc(100% - 43.5px), calc(100% - 4.1926px) calc(100% - 44.6689px), calc(100% - 8.4727999999999px) calc(100% - 45.4712px), calc(100% - 12.8142px) calc(100% - 45.9003px), calc(100% - 17.1904px) calc(100% - 45.9496px), calc(100% - 21.575px) calc(100% - 45.6125px), calc(100% - 25.9416px) calc(100% - 44.8824px), calc(100% - 30.2638px) calc(100% - 43.7527px), calc(100% - 34.5152px) calc(100% - 42.2168px), calc(100% - 38.6694px) calc(100% - 40.2681px), calc(100% - 42.7px) calc(100% - 37.9px), calc(100% - 42.7px) calc(100% - 37.9px), calc(100% - 46.5481px) calc(100% - 35.1027px), calc(100% - 50.0488px) calc(100% - 32.0096px), calc(100% - 53.1967px) calc(100% - 28.6489px), calc(100% - 55.9864px) calc(100% - 25.0488px), calc(100% - 58.4125px) calc(100% - 21.2375px), calc(100% - 60.4696px) calc(100% - 17.2432px), calc(100% - 62.1523px) calc(100% - 13.0941px), calc(100% - 63.4552px) calc(100% - 8.8184px), calc(100% - 64.3729px) calc(100% - 4.4443px), calc(100% - 64.9px) calc(100% - 1.4210854715202E-14px), 15.6px calc(100% - 0px), 15.6px calc(100% - 0px), 13.0734px calc(100% - 0.20459999999999px), 10.6752px calc(100% - 0.79679999999998px), 8.4378px calc(100% - 1.7442px), 6.3936px calc(100% - 3.0144px), 4.575px calc(100% - 4.575px), 3.0144px calc(100% - 6.3936px), 1.7442px calc(100% - 8.4378px), 0.7968px calc(100% - 10.6752px), 0.2046px calc(100% - 13.0734px), 2.5884498452564E-31px calc(100% - 15.6px), 0px 15.6px, 0px 15.6px, 0.2046px 13.0734px, 0.7968px 10.6752px, 1.7442px 8.4378px, 3.0144px 6.3936px, 4.575px 4.575px, 6.3936px 3.0144px, 8.4378px 1.7442px, 10.6752px 0.7968px, 13.0734px 0.2046px, 15.6px 2.5884498452564E-31px, calc(100% - 15.6px) 0px, calc(100% - 15.6px) 0px, calc(100% - 13.0734px) 0.2317px, calc(100% - 10.6752px) 0.8456px, calc(100% - 8.4378px) 1.8099px, calc(100% - 6.3936px) 3.0928px, calc(100% - 4.575px) 4.6625px, calc(100% - 3.0144px) 6.4872px, calc(100% - 1.7442px) 8.5351px, calc(100% - 0.79680000000002px) 10.7744px, calc(100% - 0.2046px) 13.1733px, calc(100% - 2.8421709430404E-14px) 15.7px); background-image: linear-gradient(to top, #c0c0c0, #adadad, #9a9a9a, #888888, #767676); } <div class="smooth_curve_box_4"></div> 对于这个形状,我们也可以使用 svg mask – 使用 primitives <rect> 和 <circle>. 由于这些基元支持相对单位——我们可以创建一个流体宽度的掩码。 首先,我们需要创建一个具有响应式/流体布局的<svg>: svg 不会在调整大小时挤压/扭曲圆角或圆圈。 body{ background:#333; color:#fff; } *{ box-sizing:border-box; } .resize{ resize:both; overflow:auto; border: 1px solid #ccc; width:50%; padding:1em; } <p>Resize me</p> <div class="resize"> <svg xmlns="http://www.w3.org/2000/svg" width="100%" height="100%"> <rect x="0" y="0" rx='20' ry='20' width="100%" height="100%" fill="white" /> <circle cx="100%" cy="100%" r="50" transform="translate(-30 0)" /> </svg> </div> 然后我们需要将元素转换为<mask>元素: <svg xmlns="http://www.w3.org/2000/svg" width="100%" height="100%"> <mask id="mask"> <rect x="0" y="0" width="100%" height="100%" fill="white" /> <circle cx="100%" cy="100%" r="50" transform="translate(-30 0)" /> </mask> <rect mask="url(#mask)" x="0" y="0" width="100%" height="100%" rx='20' ry='20' fill="white" /> </svg> 现在我们可以将此 svg 转换为数据 URI,例如使用 Yoksel 的转换器. 与基于多边形的 css 剪辑路径相比,我们得到了一个非常紧凑的 css 规则,因为我们不需要通过很多多边形顶点来近似曲线。: mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100%25' height='100%25'%3E%3Cmask id='mask' %3E%3Crect x='0' y='0' width='100%25' height='100%25' fill='white'/%3E%3Ccircle cx='100%25' cy='100%25' r='50' transform='translate(-30 0)' /%3E%3C/mask%3E%3Crect mask='url(%23mask)' x='0' y='0' width='100%25' height='100%25' rx='20' ry='20' fill='white'/%3E%3C/svg%3E"); 示例:作为数据 URI 的 svg 掩码 body { background: #333; color: #fff; } * { box-sizing: border-box; } .resize { resize: both; overflow: auto; border: 1px solid #ccc; width: 50%; padding: 1em; } svg { display: block; } .clip_element { display: block; width: 100%; height: 10em; min-height: 100%; background-image: linear-gradient(to top, #c0c0c0, #adadad, #9a9a9a, #888888, #767676); -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100%25' height='100%25'%3E%3Cmask id='mask' %3E%3Crect x='0' y='0' width='100%25' height='100%25' fill='white'/%3E%3Ccircle cx='100%25' cy='100%25' r='50' transform='translate(-30 0)' /%3E%3C/mask%3E%3Crect mask='url(%23mask)' x='0' y='0' width='100%25' height='100%25' rx='20' ry='20' fill='white'/%3E%3C/svg%3E"); -webkit-mask-size: 100%; mask-type: luminance; margin-bottom: 1em; } .w200x150 { width: 200px; height: 150px; } .w500x100 { width: 500px; height: 100px; } <p>Mask svg</p> <div style="width:1000px"> <svg xmlns="http://www.w3.org/2000/svg" width="100%" height="100%"> <mask id="mask"> <rect x="0" y="0" width="100%" height="100%" fill="white" /> <circle cx="100%" cy="100%" r="50" transform="translate(-30 0)" /> </mask> <rect mask="url(#mask)" x="0" y="0" width="100%" height="100%" rx='20' ry='20' fill="white" /> </svg> </div> <p>Mask applied by data-uri</p> <div class="resize"> <div class="clip_element"> </div> </div> <div class="clip_element w200x150"> </div> <div class="clip_element w500x100"> </div>

回答 3 投票 0

创建一个反向剪辑路径 - CSS或SVG

我试图创建一个实质上与CSS剪辑路径相反的东西。使用剪辑路径时,会剪切图像或div,以便只保留指定的形状,背景的其余部分为......

回答 2 投票 3

这个角度在任何宽度都可以相同吗?

无论视口宽度如何,我都试图使具有倾斜底边的div具有相同的角度。使用clip-path产生了最平滑的边缘,但我无法弄清楚是否有一个calc()我可以使用...

回答 1 投票 3

clip-path和shape-outside属性之间的差异

我知道clip-path用于在元素上创建一个mask,但是我不确定clip-path和shape-outside属性之间的区别以及它们是否可以一起使用

回答 2 投票 0

如何使用CSS制作修剪的半圆(D形)?

我需要帮助理解剪辑路径CSS属性,以便在下面制作我的修剪圆圈的版本......更像是设计版本:如果你能在灰色背景上看到,我的圆圈出现了很多......

回答 2 投票 0

© www.soinside.com 2019 - 2024. All rights reserved.