Ala*_*lum 7 javascript svg vector-graphics point-in-polygon
我有一张地图,通过将不同颜色的区域转换为路径,我将光栅图形转换为SVG文件.
我知道如何在给定边缘数组的情况下进行基本的多边形点检查,但svg:path元素代表多个多边形以及蒙版(以解释海洋等),并通过解析d属性来提取该信息看起来相当笨重.
是否有一个JS库允许我简化检查?我基本上想要创建随机点,然后检查它们是在陆地上(即在多边形内)还是在水中(即在外面).
由于SVG元素似乎允许鼠标事件处理,我认为这不应该是一个大问题(即,如果你可以判断鼠标指针是否在元素的顶部,你已经在解决了这个问题.多边形问题).
编辑:使问题复杂一点,我应该提到svg:path元素似乎是基于曲线而不是线,所以只是解析d属性来创建边数组似乎不是一个选项.
由于元素可以采用fill属性,在画布上渲染SVG然后在给定点找到像素的颜色值的贫民窟方法可以起作用,但这似乎是一种非常非常糟糕的方法.
关于命中测试 SVG 形状的答案?可能会帮助你完成这个任务。缺少浏览器支持存在问题,但您也许可以使用 svgroot.checkIntersection 来测试多边形形状内的一个小矩形(也许甚至 0 宽度/高度也可以?)。
| 归档时间: |
|
| 查看次数: |
6371 次 |
| 最近记录: |