C# 调用百度地图

16年上传的资源,一个html加载百度地图,C#代码与html 的js交互,不用注册百度地图key,用的1.4版本,资源链接是: https://download.csdn.net/download/henrymoore/9504873

效果如下:

C# 调用百度地图

关键的html文件代码:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title>百度地图API显示多个标注点带提示的代码</title>
    <!--css-->
    <style type="text/css">
        body, html, #map {
            width: 100%;
            height: 100%;
            overflow: hidden;
            margin: 0;
            font-family: "微软雅黑";
        }

        #l-map {
            height: 100%;
            width: 78%;
            float: left;
            border-right: 2px solid #bcbcbc;
        }

        #r-result {
            height: 100%;
            width: 20%;
            float: left;
        }
    </style>
    <!--javascript-->
    <script src="http://www.w3school.com.cn/jquery/jquery.js" type="text/javascript"></script>
</head>
<body>
    <div id="map">
    </div>
    <script type="text/javascript">

        var map; //Map实例
        var myGeo;//地址解析
        function map_init() {
            map = new BMap.Map("map");

            //第1步:设置地图中心点,广州市
            var point = new BMap.Point(113.312213, 23.147267);

            //第2步:初始化地图,设置中心点坐标和地图级别。
            map.centerAndZoom(point, 13);

            //第3步:启用滚轮放大缩小
            map.enableScrollWheelZoom(true);

            //启用键盘上下左右移动地图
            map.enableKeyboard();

            //第4步:向地图中添加缩放控件
            var ctrlNav = new window.BMap.NavigationControl({
                anchor: BMAP_ANCHOR_TOP_LEFT,
                type: BMAP_NAVIGATION_CONTROL_LARGE
            });
            map.addControl(ctrlNav);

            //第5步:向地图中添加缩略图控件
            var ctrlOve = new window.BMap.OverviewMapControl({
                anchor: BMAP_ANCHOR_BOTTOM_RIGHT,
                isOpen: 1
            });
            map.addControl(ctrlOve);

            //第6步:向地图中添加比例尺控件
            var ctrlSca = new window.BMap.ScaleControl({
                anchor: BMAP_ANCHOR_BOTTOM_LEFT
            });
            map.addControl(ctrlSca);
        }

        //清除覆盖物
        function removeOverlay() {
            map.clearOverlays();
        }

        //移动到某一点
        function MoveToPoint(lng, lat) {
            map.panTo(new BMap.Point(lng, lat));
        }

        // 添加标注
        function addMarker(lng, lat, index, title, des) {

            //标注图标
            var myIcon = new BMap.Icon("http://api.map.baidu.com/img/markers.png",
                new BMap.Size(23, 25), {
                    offset: new BMap.Size(10, 25),
                    imageOffset: new BMap.Size(0, 0 - index * 25)
                });
            var point = new BMap.Point(lng, lat);
            var marker = new BMap.Marker(point, { icon: myIcon });
            map.addOverlay(marker);

            //跳动的动画
            marker.setAnimation(BMAP_ANIMATION_BOUNCE);

            //根据坐标点,获取详细地址信息
            if (myGeo == null)
                myGeo = new BMap.Geocoder();
            myGeo.getLocation(point, function (res) {
                if (res == null)
                    //设置点击详细信息
                    addInfoWindow(marker, title, des);
                else
                    addInfoWindow(marker, res.address, res.business);
            });
            return marker;
        }

        // 添加信息窗口
        function addInfoWindow(marker, title, des) {

            //标签
            var label = new BMap.Label(title, { offset: new BMap.Size(20, -10) });
            marker.setLabel(label);

            //pop弹窗标题
            var title = '<div style="font-weight:bold;color:#CE5521;font-size:14px">' + title + '</div>';
            //pop弹窗信息
            var html = [];
            html.push('<table cellspacing="0" style="table-layout:fixed;width:100%;font:12px arial,simsun,sans-serif"><tbody>');
            html.push('<tr>');
            html.push('<td style="vertical-align:top;line-height:16px;width:48px;white-space:nowrap;word-break:keep-all">详细信息:</td>');
            html.push('<td style="vertical-align:top;line-height:16px">' + des + ' </td>');
            html.push('</tr>');
            html.push('</tbody></table>');
            var infoWindow = new BMap.InfoWindow(html.join(""), { title: title, width: 200 });

            var openInfoWinFun = function () {
                marker.openInfoWindow(infoWindow);
            };
            marker.addEventListener("click", openInfoWinFun);
            return openInfoWinFun;
        }

        //异步调用百度js
        function map_load() {
            var load = document.createElement("script");
            load.src = "http://api.map.baidu.com/api?v=1.4&callback=map_init";
            document.body.appendChild(load);
        }
        window.onload = map_load;
    </script>
</body>
</html>

其他比如winform WebBrowser或者WPF WebBrowser控件加载html,及后台cs代码与js交互大家可以下载资源查看,比较简单。

2020-06-20更新

整合了一个版本,将源码同步到开源项目TerminalMACS.ManagerForWPF中,欢迎star,给个支持哦,点击浏览源码

除非注明,文章均由 Dotnet9 整理发布,欢迎转载。

转载请注明:
作者:Dotnet9
链接:https://dotnet9.com/3089.html
来源:Dotnet9
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

发表评论

登录后才能评论