Повторение шаблона SVG в качестве пути клипа для границы с использованием псевдоэлемента ::after

Я пытаюсь создать асимметричный пилообразный узор в нижней части заголовка сайта, который выглядит следующим образом (за исключением того, что пилообразный рисунок будет асимметричным):

пример пилообразной границы

Я пробовал некоторые чистые подходы CSS, используя (линейный градиент), но безрезультатно.

Я могу создать повторяющийся шаблон, но не могу также сделать его путем обрезки, чтобы он вырезал цвет фона заголовка (розовый), чтобы показать фон тела под ним.

https://codepen.io/rasterisk/pen/rZrKNO

body {
  background-color: tomato;
  margin: 0;
}
.header {
  position:relative;
  height: 100px;
  background-color: pink;
  overflow: hidden;
  margin: 0;
}

.header svg {
  position: absolute;
  bottom: 0;
}

div::after { /*this doesn't work*/
  content:'';
  height:12px;
  width: 100%;
  position: absolute;
  background-color: green;
  -webkit-clip-path: url(#svgPath);
  clip-path: url(#svgPath);
  bottom: 0;
  margin: 0;
}
<body>
  <div class="header">
    <svg width="3000" height="11" xmlns="http://www.w3.org/2000/svg">
      <defs>
      <clipPath id="svgPath">
        <pattern id="Pattern" x="0" y="0" width="20" height="12" patternUnits="userSpaceOnUse">
          <path fill="" d="M-131-167l-144.42-104.93s-6.87-4.59-9.07 3.17c-2.11 7.48-13.93 83.86-16.69 101.76H-131zM-354-50l-.14 111s15.54-94.28 17.65-101.76c2.19-7.77 9.07-3.17 9.07-3.17L-183 61V-50h-171zM0 0v11.61S2.08 1.73 2.33.92C2.6.07 3.04.5 3.04.5L20 11.61V0H0z"/>
        </pattern>
      </clipPath>
    </defs>
    <rect fill="url(#Pattern)" width="2400" height="12"/>
   </svg>
 </div>
</body>

Любая помощь будет оценена по достоинству. Эта степень контроля SVG — новая для меня территория.


person rasterisk    schedule 15.09.2018    source источник
comment
Если вы собираетесь использовать шаблон, вам понадобится маска, а шаблон не может быть потомком ни маски, ни clipPath, поэтому маска имеет прямоугольник, заполненный шаблоном.   -  person Robert Longson    schedule 15.09.2018
comment
@RobertLongson спасибо за эту информацию. Я много узнал об ограничениях SVG Pattern и clipPath за последние 24 часа. Я также пытался ориентироваться на заливки шаблонов с помощью CSS, но безрезультатно. Мне нравится то, на что способен SVG, но изучение всех тонкостей — это серьезное исследование.   -  person rasterisk    schedule 16.09.2018


Ответы (1)


Вы можете попробовать это решение только для css: линейные градиенты css

body {
  background-color: tomato;
  margin: 0;
}
.header {
  position:relative;
  height: 100px;
  background-color: pink;
  overflow: hidden;
  margin: 0;
}

.header svg {
  position: absolute;
  bottom: 0;
}

div::after{
  content:"";
  display:block;
  position:absolute; 
  bottom:0;
  width:100%;
  height:1.2em;
  background-image:-webkit-linear-gradient(45deg, pink 25%, transparent 26%, transparent 75%, pink 75%),
				  -webkit-linear-gradient(135deg, pink 25%, tomato 26%,tomato 75%, pink 75%);
background-image: linear-gradient(45deg, pink 25%, transparent 26%, transparent 75%, pink 75%),
                  linear-gradient(135deg, pink 25%, tomato 26%, tomato 75%, pink 75%);
background-size:36px 36px;}
}
<body>
  <div class="header">
 </div>
</body>

ОБНОВИТЬ

асимметричный пилообразный узор:

body {
  background-color: tomato;
  margin: 0;
}
.header {
  position:relative;
  height: 100px;
  background-color: pink;
  overflow: hidden;
  margin: 0;
}

.header svg {
  position: absolute;
  bottom: 0;
}

div::after{
  content:"";
  display:block;
  position:absolute; 
  bottom:0;
  width:100%;
  height:25px;
background-image: linear-gradient(45deg,  tomato 50%, pink 50% , pink 100%),
                  linear-gradient(135deg,  tomato 50%, pink 50% , pink 100%);
background-size:25px 25px;}
}
<body>
  <div class="header">
 </div>
</body>

person enxaneta    schedule 15.09.2018
comment
Спасибо за это решение. Сложность в том, что мне нужно, чтобы пилообразный эффект был асимметричным. Ценю ответ! - person rasterisk; 16.09.2018