SVGGeometryElement: isPointInFill() Methode

Baseline Widely available *

This feature is well established and works across many devices and browser versions. It’s been available across browsers since January 2020.

* Some parts of this feature may have varying levels of support.

Die SVGGeometryElement.isPointInFill()-Methode ermittelt, ob ein gegebener Punkt innerhalb der Füllfläche eines Elements liegt. Normale Hit-Test-Regeln gelten; der Wert der pointer-events-Eigenschaft des Elements bestimmt, ob ein Punkt als innerhalb der Füllung betrachtet wird. Das point-Argument wird als ein Punkt im lokalen Koordinatensystem des Elements interpretiert.

Syntax

js
isPointInFill(point)

Parameter

point

Ein DOMPointInit-Objekt, das als Punkt im lokalen Koordinatensystem des Elements interpretiert wird.

Rückgabewert

Ein boolescher Wert, der anzeigt, ob der gegebene Punkt innerhalb der Füllung liegt oder nicht.

Beispiele

SVG

html
<svg
  viewBox="0 0 100 100"
  width="150"
  height="150"
  xmlns="http://www.w3.org/2000/svg">
  <circle
    id="circle"
    cx="50"
    cy="50"
    r="45"
    fill="white"
    stroke="black"
    stroke-width="10" />
</svg>

JavaScript

js
const svg = document.getElementsByTagName("svg")[0];
const circle = document.getElementById("circle");
const points = [
  ["10", "10"],
  ["40", "30"],
  ["70", "40"],
  ["15", "75"],
  ["83", "83"],
];

for (const point of points) {
  let isPointInFill;

  try {
    const pointObj = new DOMPoint(point[0], point[1]);
    isPointInFill = circle.isPointInFill(pointObj);
  } catch (e) {
    // Fallback for browsers that don't support DOMPoint as an argument
    const pointObj = svg.createSVGPoint();
    pointObj.x = point[0];
    pointObj.y = point[1];
    isPointInFill = circle.isPointInFill(pointObj);
  }

  console.log(`Point at ${point[0]},${point[1]}: ${isPointInFill}`);

  const pointEl = document.createElementNS(
    "http://www.w3.org/2000/svg",
    "circle",
  );
  pointEl.style.cx = point[0];
  pointEl.style.cy = point[1];
  pointEl.style.r = 5;
  pointEl.style.fill = isPointInFill ? "seagreen" : "rgb(255 0 0 / 50%)";
  svg.appendChild(pointEl);
}

Ergebnis

Spezifikationen

Specification
Scalable Vector Graphics (SVG) 2
# __svg__SVGGeometryElement__isPointInFill

Browser-Kompatibilität