如何使用CSS3创建Reuleaux三角形形状

戈拉克·钱德拉·萨蒂亚(Golak Chandra Satiar)

我需要一个帮助来使用CSS3来制作reuleaux三角形形状,如下图所示。形状周围有白色边框。这怎么可能?

在此处输入图片说明

哈里

即使使用CSS创建形状,CSS也不是正确的工具。它们将需要多个实/伪元素,变换等,并且即使如此,曲线的半径等的维护也非常棘手。当您需要在它们周围加边框或在其中放置图像或渐变时,它会变得更加复杂。

创建此类形状的最佳工具是SVG,因为它们具有以下优点:

  • SVG本质上是可伸缩的,因此非常适合响应式设计
  • SVG形状可以采用图像或渐变作为填充
  • 曲线和半径控制非常理想

以下是使用SVG创建reuleaux三角形形状的示例代码段。它只需要一个带有3个Quadratic Curveto命令的单路径元素。

svg {
  height: 200px;
  width: 200px;
}
path {
  fill: steelblue;
  stroke: white;
  stroke-width: 2;
}
path.image {
  fill: url(#g-image);
}
body {
  background-image: radial-gradient(circle, #3F9CBA 0%, #153346 100%);
}
<svg viewBox="0 0 105 105" preserveAspectRatio="none">
  <path d="M2,15 q50,-25 100,0 q0,50 -50,85 q-50,-30 -50,-85z" />
</svg>
<svg viewBox="0 0 105 105" preserveAspectRatio="none">
  <defs>
    <pattern id="g-image" width="1" height="1" patternUnits="objectBoundingBox">
      <image xlink:href="http://lorempixel.com/200/200/nature/4" width="200" height="200" />
    </pattern>
  </defs>
  <path d="M2,15 q50,-25 100,0 q0,50 -50,85 q-50,-30 -50,-85z" class="image" />
</svg>


通过将CSS Clip-path与内联SVG一起使用也可以实现相同的路径,但是IE中不存在对此的支持,因此不建议这样做。

div {
  position: relative;
  background: white;
  height: 200px;
  width: 200px;
  -webkit-clip-path: url(#clipper);
  clip-path: url(#clipper);
}
div:after {
  position: absolute;
  content: '';
  height: calc(100% - 4px);
  width: calc(100% - 4px);
  top: 2px;
  left: 2px;
  background: steelblue;
  -webkit-clip-path: url(#clipper);
  clip-path: url(#clipper);
}
div.image:after{
  background: url(http://lorempixel.com/200/200);
}
body {
  background-image: radial-gradient(circle, #3F9CBA 0%, #153346 100%);
}

/* Just for demo */

div{
  display: inline-block;
}
<svg width="0" height="0">
  <defs>
    <clipPath id="clipper" clipPathUnits="objectBoundingBox">
      <path d="M0,0.15 q0.5,-0.25 1,0 q0,0.5 -0.5,0.85 q-0.5,-0.3 -0.5,-0.85z" />
    </clipPath>
  </defs>
</svg>
<div></div>
<div class='image'></div>

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章