I have an SVG image map embedded on an HTML page.
It contains a collection of PNG
s each wrapped in a link.
Some of these images overlap, however w
The SVG spec explicitly states that fully transparent pixels in a raster image should not cause a click event if pointer-events="visiblePainted"
(the default) or pointer-events="painted
.
Unfortunately, however, Chrome, Firefox, and Edge all seem to treat bitmap images as completely opaque.
If you want to encourage this to be fixed, you could star the following bug tickets:
https://bugzilla.mozilla.org/show_bug.cgi?id=311942 https://bugs.chromium.org/p/chromium/issues/detail?id=806468
AFAIK, the only solution to this right now is to use a clip path.
function click(evt) {
console.log("Clicked on " + evt.target.parentElement.id);
}
document.getElementById("blue").addEventListener("click", click);
document.getElementById("red").addEventListener("click", click);
<svg width="400" height="400">
<defs>
<clipPath id="red-clip">
<path d="M 100,100, 300,100, 300,300, 100,300 Z M 150,150, 150,250, 250,250, 250,150 Z"/>
</clipPath>
</defs>
<a id="blue">
<rect x="0" y="0" width="200" height="400" fill="skyblue"/>
</a>
<a id="red">
<image x="100" y="100" width="200" height="200"
image-rendering="pixelated" clip-path="url(#red-clip)"
xlink:href=""/>
</a>
</svg>
If I correctly understood you, then the click event should pass through the upper semi-transparent image to the bottom one and trigger on it.
For these purposes, the attribute pointer-events ="none"
Assigning this attribute <image id ="semi" style="pointer-events:none;"
we make the picture transparent for clicks on the red and black rectangles that are located under this picture.
<svg xmlns:svg="http://www.w3.org/2000/svg" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="100%" height="100%" viewBox="0 0 400 400" >
<rect x="50" y="50" width="100" height="100" fill="black" >
<animate attributeName="x" from="50" to="250" dur="2s" begin="click" fill="freeze" />
</rect>
<rect x="150" y="150" width="100" height="100" fill="red" >
<animate attributeName="x" from="150" to="350" dur="2s" begin="click" fill="freeze" />
</rect>
<image id="semi" xlink:href="http://i68.tinypic.com/2wnnriv.jpg" width="300px" height="300px" opacity="0.9" y="0" x="0" style="pointer-events:none;"/>
</svg>
Browser support: https://caniuse.com/#feat=pointer-events
Theory: https://developer.mozilla.org/en-US/docs/Web/CSS/pointer-events