微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

点击多边形检查SVG和JavaScript?

我有一张地图,我通过将不同颜色的区域转换为路径,将光栅图形转换为SVG文件.

我知道如何在给定边数组的情况下进行基本的多边形点检查,但svg:path元素表示多个多边形以及蒙版(以解释海洋等),并通过解析d属性提取该信息重手.

一个JS库可以让我简化检查吗?我基本上想要创建随机点,然后检查它们是在陆地上(即在多边形内)还是在水中(即在外面).

由于SVG元素似乎允许鼠标事件处理,我认为这不应该是一个很大的问题(即,如果你可以判断鼠标指针是否在元素的顶部,你已经在解决这个问题了.多边形问题).

编辑:使问题复杂一点,我应该提到svg:path元素似乎是基于曲线而不是线,所以只是解析d属性来创建一个边数组似乎不是一个选项.

由于元素可以采用填充属性,在画布上渲染SVG然后在给定点找到像素的颜色值的贫民窟方法可以起作用,但这似乎是一种非常非常糟糕的方法.

解决方法

Hit-testing SVG shapes?的答案可以帮助您完成此任务.缺少浏览器支持存在问题,但您可以使用svgroot.checkIntersection来测试多边形内的一个小的(可能甚至0宽度/高度可以工作?)矩形.

原文地址:https://www.jb51.cc/js/157078.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐