zoukankan      html  css  js  c++  java
  • [C# WinFrom 使用 Google Map] 在地图上画轨迹线

    google map 上画 多条线段是使用 google.maps.Polyline 来实现的.

    javascript 代码:

       var polyline;   
    //画多边形 google.maps.Polyline function drawPolyline(latLngArray) { var path = new Array(); var latLngs = latLngArray.toString().split(";"); for(index in latLngs) { var latLng = latLngs[index].split(","); if(latLng.length==2) { path.push((new google.maps.LatLng(latLng[0], latLng[1]))); } } polyline = new google.maps.Polyline( { map: map, path: path, geodesic: true, strokeColor: "#FF0000", strokeOpacity: 0.6, strokeWeight: 2 }); } function clearPolyLine() { if(polyline!=null) { polyline.setMap(null); } }

    C#调用代码:

            public static string DrawPolyline(WebBrowser wb, List<PointF> ptList)
            {
                StringBuilder sb = new StringBuilder();
                foreach (var item in ptList)
                {
                    sb.AppendFormat("{0},{1};", item.Y, item.X);
                }

                Object[] objArray = new Object[1] { sb.ToString().TrimEnd(';') };
       

                string optName = "drawPolyline";
                return DoneGoogleMapOp(wb, optName, objArray);
            }


    // 执行脚本命令 private static string DoneGoogleMapOp(WebBrowser wb, string optName, Object[] objArray) { string retStr = ""; try { Object objRet = wb.Document.InvokeScript(optName, objArray); if (objRet != null) retStr = objRet.ToString(); } catch { } return retStr; } //画轨迹数据 public static string DrawPolyline(WebBrowser wb, List<LatLng> trackList) { List<PointF> ptList = new List<PointF>(); trackList.ForEach(item => ptList.Add(new PointF((float)item.Lng, (float)item.Lat))); return DrawPolyline(wb, ptList); } // clearPolyLine public static string ClearPolyLine(WebBrowser wb) { return DoneGoogleMapOp(wb, "clearPolyLine", null); }

     使用实际参数调用:

       DrawPolyline(wbGoogleMap, trackList);

      

    ~做事情贵在坚持~
  • 相关阅读:
    webpack learn2-vue的jsx写法和postcss 1
    浏览器缓存旧的js文件或css文件导致没出现预期效果
    webpack learn1-webpack-dev-server的配置和使用3
    Python正课60 —— configparser模块
    Python正课59 —— json与pickle模块
    Python正课58 —— 小说阅读项目 初级
    Python正课57 —— ATM+购物车 前戏
    Python正课56 —— shutil模块
    Python正课55 —— sys模块
    Python正课54 —— os模块
  • 原文地址:https://www.cnblogs.com/csMapx/p/2534417.html
Copyright © 2011-2022 走看看