clip-path
Экспериментальная возможность: Это экспериментальная технология
Так как спецификация этой технологии ещё не стабилизировалась, смотрите таблицу совместимости по поводу использования в различных браузерах. Также заметьте, что синтаксис и поведение экспериментальной технологии может измениться в будущих версиях браузеров, вслед за изменениями спецификации.
CSS свойство clip-path
создаёт ограниченную область, которая определяет какая часть элемента должна быть видимой. Те части, которые находятся внутри области, видимы, в то время как части вне области, скрыты. Обрезанная область - это траектория, определяемая либо как внутренняя ссылка, либо как внешний SVG , либо как фигура, такая как круг (circle()
).
Примечание: Свойство clip-path заменило устаревшее свойство clip
(en-US) .
/* Keyword values */
clip-path: none;
/* Image values */
clip-path: url(resources.svg#c1);
/* Box values */
clip-path: fill-box;
clip-path: stroke-box;
clip-path: view-box;
clip-path: margin-box;
clip-path: border-box;
clip-path: padding-box;
clip-path: content-box;
/* Geometry values */
clip-path: inset(100px 50px);
clip-path: circle(50px at 0 100px);
clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
/* Box and geometry values combined */
clip-path: padding-box circle(50px at 0 100px);
/* Global values */
clip-path: inherit;
clip-path: initial;
clip-path: unset;
html,body {
height: 100%;
box-sizing: border-box;
background: #EEE;
}
.grid {
width: 100%;
height: 100%;
display: flex;
font: 1em monospace;
}
.row {
display: flex;
flex: 1 auto;
flex-direction: row;
flex-wrap: wrap;
}
.col {
flex: 1 auto;
}
.cell {
margin: .5em;
padding: .5em;
background-color: #FFF;
overflow: hidden;
text-align: center;
flex: 1;
}
.note {
background: #fff3d4;
padding: 1em;
margin: .5em .5em 0;
font: .8em sans-serif;
text-align: left;
white-space: nowrap;
}
.note + .row .cell {
margin-top: 0;
}
.container {
display: inline-block;
border: 1px dotted grey;
position:relative;
}
.container:before {
content: 'margin';
position: absolute;
top: 2px;
left: 2px;
font: italic .6em sans-serif;
}
.viewbox {
box-shadow: 1rem 1rem 0 #EFEFEF inset, -1rem -1rem 0 #EFEFEF inset;
}
.container.viewbox:after {
content: 'viewbox';
position: absolute;
left: 1.1rem;
top: 1.1rem;
font: italic .6em sans-serif;
}
.cell span {
display: block;
margin-bottom: .5em;
}
p {
font-family: sans-serif;
background: #000;
color: pink;
margin: 2em;
padding: 3em 1em;
border: 1em solid pink;
width: 6em;
}
.none { clip-path: none; }
.svg { clip-path: url(#myPath); }
.svg2 { clip-path: path('M15,45 A30,30,0,0,1,75,45 A30,30,0,0,1,135,45 Q135,90,75,130 Q15,90,15,45 Z');}
.shape1 { clip-path: circle(25%); }
.shape2 { clip-path: circle(25% at 25% 25%); }
.shape3 { clip-path: fill-box circle(25% at 25% 25%); }
.shape4 { clip-path: stroke-box circle(25% at 25% 25%); }
.shape5 { clip-path: view-box circle(25% at 25% 25%); }
.shape6 { clip-path: margin-box circle(25% at 25% 25%); }
.shape7 { clip-path: border-box circle(25% at 25% 25%); }
.shape8 { clip-path: padding-box circle(25% at 25% 25%); }
.shape9 { clip-path: content-box circle(25% at 25% 25%); }
.defs {
width: 0;
height: 0;
margin: 0;
}
pre { margin-bottom: 0; }
svg {
margin: 1em;
font-family: sans-serif;
width: 192px;
height: 192px;
}
svg rect {
stroke: pink;
stroke-width: 16px;
}
svg text {
fill: pink;
text-anchor: middle;
}
svg text.em {
font-style: italic;
}
Начальное значение | none |
---|---|
Применяется к | все элементы; в SVG, это применяется к контейнерам, исключая элемент defs и все графические элементы |
Наследуется | нет |
Проценты | refer to reference box when specified, otherwise border-box |
Обработка значения | как указано, но с абсолютными значениями url |
Animation type | да, как указано для basic-shape (en-US), иначе нет |
Синтаксис
Свойство clip-path
определяется как одно или комбинация значений перечисленных ниже.
Значения
url()
-
Представляет URL ссылку на траекторию, ограничивающую элемент.
inset()
,circle()
,ellipse()
,polygon()
-
Функция
<basic-shape>
(en-US). Размер и положение области определяется значением<geometry-box>
. Если геометрия не определена,border-box
будет использоваться в качестве блока. <geometry-box>
-
Если определён в комбинации с
<basic-shape>
, это значение определяет блок для базовой области. Если задан самостоятельно, определяет границы блока, включая формирование углов (такое какborder-radius
). Геометрия может быть определена с помощью одного из следующих значений:fill-box
-
Использует границы объекта в качестве базовой области.
stroke-box
-
Использует stroke bounding box в качестве базовой области.
view-box
-
Использует ближайший SVG viewport в качестве базового блока. Если атрибут
viewBox
определён для элемента, создающего SVG viewport, базовый блок позиционируется в оригинальной системе координат, установленной атрибутомviewBox
и ширина и высота базового блока устанавливаются равными значениям атрибутаviewBox
. margin-box
-
Использует margin box в качестве базового блока.
border-box
-
Использует border box в качестве базового блока.
padding-box
-
Использует padding box в качестве базового блока.
content-box
-
Использует content box в качестве базового блока.
none
-
Обрезанная область не создается.
Формальный синтаксис.
clip-path =
<clip-source> | (en-US)
[ (en-US) <basic-shape> (en-US) || (en-US) <geometry-box> ] (en-US) | (en-US)
none
<clip-source> =
<url>
<geometry-box> =
<shape-box> | (en-US)
fill-box | (en-US)
stroke-box | (en-US)
view-box
<url> =
url( <string> (en-US) <url-modifier>* (en-US) ) | (en-US)
src( <string> (en-US) <url-modifier>* (en-US) )
<shape-box> =
<box> | (en-US)
margin-box
<box> =
border-box | (en-US)
padding-box | (en-US)
content-box
Примеры
/* Inline SVG */
.target {
clip-path: url(#c1);
}
/* External SVG */
.anothertarget {
clip-path: url(resources.svg#c1);
}
/* Circle shape */
.circleClass {
clip-path: circle(15px at 20px 20px);
}
Живой пример
HTML
<img id="clipped" src="mdn.svg"
alt="MDN logo">
<svg height="0" width="0">
<defs>
<clipPath id="cross">
<rect y="110" x="137" width="90" height="90"/>
<rect x="0" y="110" width="90" height="90"/>
<rect x="137" y="0" width="90" height="90"/>
<rect x="0" y="0" width="90" height="90"/>
</clipPath>
</defs>
</svg>
<select id="clipPath">
<option value="none">none</option>
<option value="circle(100px at 110px 100px)">circle</option>
<option value="url(#cross)" selected>cross</option>
<option value="inset(20px round 20px)">inset</option>
</select>
CSS
#clipped {
margin-bottom: 20px;
clip-path: url(#cross);
}
Результат
Спецификации
Спецификация | Статус | Комментарий |
---|---|---|
CSS Masking Module Level 1 Определение 'clip-path' в этой спецификации. |
Кандидат в рекомендации | Extends its application to HTML elements. |
Scalable Vector Graphics (SVG) 1.1 (Second Edition) Определение 'clip-path' в этой спецификации. |
Рекомендация | Initial definition (applies to SVG elements only). |
Совместимость
BCD tables only load in the browser