marker-mid

marker-mid CSS 属性指向一个标记,该标记将在元素路径的中点顶点绘制;也就是说,在它的每个起始顶点和结束顶点之间的顶点。该标记必须使用 SVG <marker> 元素定义,并且只能用 url() 值引用。CSS 属性的值会覆盖 SVG 中 marker-mid 属性的任何值。

每个标记指向的方向定义为前一个路径段结束方向和下一个路径段开始方向之间的中间方向。可以将其视为由两个路径方向定义的向量的叉积。

注意:marker-mid 属性仅对可以使用 SVG 标记的元素有效。请参见 marker-mid 以获取列表。

语法

css
marker-mid: none;
marker-mid: url(markers.svg#arrow);

/* Global values */
marker-mid: inherit;
marker-mid: initial;
marker-mid: revert;
marker-mid: revert-layer;
marker-mid: unset;

none

这意味着元素路径的每个中点顶点都不会绘制标记。

<marker-ref>

一个 <url>,它引用由 SVG <marker> 元素定义的标记,将在元素路径的每个中点顶点绘制。如果 URL 引用无效,则路径的中点顶点不会绘制任何标记。

正式定义

在数据库中找不到值!

正式语法

marker-mid = 
none |
<marker-ref>

<marker-ref> =
<url>

<url> =
<url()> |
<src()>

<url()> =
url( <string> <url-modifier>* ) |
<url-token>

<src()> =
src( <string> <url-modifier>* )

示例

html
<svg viewBox="0 0 240 120" xmlns="http://www.w3.org/2000/svg">
  <defs>
    <marker
      id="triangle"
      viewBox="0 0 10 10"
      markerWidth="10"
      markerHeight="10"
      refX="1"
      refY="5"
      markerUnits="strokeWidth"
      orient="auto">
      <path d="M 0 0 L 10 5 L 0 10 z" fill="#f00" />
    </marker>
  </defs>
  <polyline
    id="test"
    fill="none"
    stroke="black"
    points="20,100 40,60 70,80 100,20 130,10 150,10 170,20 170,100 120,100" />
</svg>
css
polyline#test {
  marker-mid: url(#triangle);
}

规范

规范
可缩放矢量图形 (SVG) 2
# VertexMarkerProperties

浏览器兼容性

BCD 表格仅在浏览器中加载

另请参阅