完全可以将多段线的坐标传递给谷歌地图,但需要考虑很多因素
首先,多段线坐标必须是UTM(即经度和纬度)
接下来,您必须在地图浏览器中嵌入javascript才能传递点
最后,您必须使用谷歌API从点构建多段线,并将其设置到地图中
有几个注意事项…webbrowser控件允许您调用脚本(请记住Javascript区分大小写),但它只允许您传递单个变量。好消息是,变量必须是javascript函数的每个必需参数的数组
考虑到您有一个要显示的标记,您可能只需要传递一个地理编码点(-112.53412,84.84533),这样您的javascript函数就可以接受两个变量,一个代表经度,一个表示纬度。然而,如果您需要传递未知数量的垂直度,javascript函数将不会接受超出其定义处理范围的变量。要解决此问题,请使用带分隔符的字符串作为点数组,然后将分隔符传递给javascript函数
- 'This is our argument array
- Dim Args(1) As String
- 'Build our list of points, X & Y coords (i.e. Lon/Lat)
- For N = 0 to polypoints.count - 1
- Args(0) = Args(0) & polypoints(N).X & "," & polypoints(N).Y
- Next
- 'Pass our delimiter
- Args(1) = ","
- 'Call the script
- WebBrowser1.document.InvokeScript("MakePoly",Args)
- function MakePoly(points, delimiter){
- //you need to unpack your points using the delimiter
- //and create an array of GLatLng for API V2 or LatLng for API V3
- //polyline building code goes here
- }
在我发火之前,我已经';t使用VBA有一段时间了,因此示例可能包含错误。特别是对于AutoCAD对象…我可以';我真不敢相信我忘记这些事情的速度有多快…
顺便提一句,你也可以将函数的值作为com对象返回给你的调用函数,但没有关于如何与它交互的文档,虽然我已经取得了一些进展,但它在很大程度上是碰运气的,尽管字符串和标记返回得很好,并且相对容易交互和操作
祝你好运! |