百度地图API : 自定义标注图标

简介: 百度地图API : 自定义标注图标

通过Icon类可实现自定义标注的图标,下面示例通过参数MarkerOptions的icon属性进行设置,
也可以使用marker.setIcon()方法。

<!DOCTYPE html>
<html>

<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
    <style type="text/css">
        body,
        html,
        #allmap {
            width: 100%;
            height: 100%;
            overflow: hidden;
            margin: 0;
            font-family: "微软雅黑";
        }
    </style>
    <script type="text/javascript"
        src="https://api.map.baidu.com/api?v=2.0&ak=LaQ2jfcObK42sDixAN2BraP2jbGMU6BC"></script>
    <script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>

    <title>GPS转百度</title>
</head>

<body>
    <div id="allmap"></div>
</body>

</html>
<script type="text/javascript">
    // 百度地图API功能 
    var map = new BMap.Map("allmap");    // 创建Map实例
    var ggpoint = new BMap.Point(129.879392, 32.790481)
    map.centerAndZoom(ggpoint, 16);  // 初始化地图,设置中心点坐标和地图级别
    map.addControl(new BMap.MapTypeControl());   //添加地图类型控件
    map.setCurrentCity("长崎");          // 设置地图显示的城市 此项是必须设置的
    map.enableScrollWheelZoom(true);     //开启鼠标滚轮缩放

    var points = [
        [123.319727767605, 41.4229349260951],
        [125.725967756961, 39.0269627713093],
        [126.976200904837, 37.559805362172],
        [126.995866800926, 37.5646576789431],
        [127.717276492584, 37.8846597149346],
        [127.845636602218, 36.5247159814598],
        [129.881057104894, 32.7479331075868],
        [129.877945175468, 32.7441603140361],
        [129.823280322228, 32.8551075968325],
        [129.996944752118, 33.439129860535],
        [129.857128998386, 33.2587933885413],
        [129.788714312017, 33.7842305297287],
        [130.241407289985, 32.7843329855946],
    ];

    // // 坐标转换完之后的回调函数
    translateCallback = function (data) {
        if (data.status === 0) {
            // 向地图添加标注
            for (var i = 0; i < points.length; i++) {
                var myIcon = new BMap.Icon("https://i.loli.net/2020/10/21/hQeUEjzTaZv63uB.png", new BMap.Size(23, 35));
                var point = new BMap.Point(points[i][0], points[i][1]);
                // 创建标注对象并添加到地图 
                var marker = new BMap.Marker(point, { icon: myIcon });
                map.addOverlay(marker);
            };
            map.addOverlay(marker); // 将标注添加到地图中
            var label = new BMap.Label("您现在的位置", { offset: new BMap.Size(20, -10) });
            marker.setLabel(label); //添加百度label
            map.setCenter(data.points[0]);
        }
    }

    setTimeout(function () {
        var convertor = new BMap.Convertor();
        var pointArr = [];
        pointArr.push(ggpoint);
        convertor.translate(pointArr, 1, 5, translateCallback)
    }, 1000)


    // 地图的点击事件
    map.addEventListener('click', function (e) {
        console.log('点击位置经纬度:' + e.point.lng + ',' + e.point.lat);
    });
</script>
相关文章
|
14天前
|
缓存 API 定位技术
使用Python调用百度地图API实现地址查询
使用Python调用百度地图API实现地址查询
146 0
|
12天前
|
定位技术 API
Angular 调用导入百度地图API接口,2024春招BAT面试真题详解
Angular 调用导入百度地图API接口,2024春招BAT面试真题详解
|
14天前
|
自然语言处理 API 语音技术
Python加百度语音API实现文字转语音功能
Python加百度语音API实现文字转语音功能
68 0
|
14天前
|
JSON JavaScript 定位技术
Vue中使用echarts@4.x中国地图及AMap相关API的使用
Vue中使用echarts@4.x中国地图及AMap相关API的使用
208 0
Vue中使用echarts@4.x中国地图及AMap相关API的使用
|
14天前
|
SQL 存储 DataWorks
DataWorks中API、desc、数据地图,这3个怎么对起来?
DataWorks中API、desc、数据地图,这3个怎么对起来?
48 0
|
5月前
|
定位技术 API
百度地图API的使用教程以及案例(二)
百度地图API的使用教程以及案例
|
5月前
|
定位技术 API 容器
百度地图API的使用教程以及案例(一)
百度地图API的使用教程以及案例
|
API 定位技术 Android开发
百度地图移动版API 1.2.2版本(Android)地图偏移的最佳解决办法
Import import com.baidu.mapapi.CoordinateConvert;import com.baidu.mapapi.GeoPoint; Code GeoPoint p = new GeoPoint(x, y);GeoPoint p2 = CoordinateConvert.
669 0
|
2天前
|
监控 数据挖掘 API
京东商品API接口:电商数据自动化的钥匙
京东商品API接口为电商领域带来了巨大的便利和潜力。通过本篇文章,读者应该能够了解如何使用京东商品API接口,并通过示例代码学习如何实际调用API获取商品数据。 随着技术的不断发展,京东商品API接口将继续为电商自动化、数据分析和市场研究提供支持,帮助商家和开发者在竞争激烈的市场中保持领先。我们鼓励读者继续探索和学习,充分利用京东商品API接口带来的机遇。
|
12天前
|
监控 安全 数据挖掘
Email 接口API有哪些?具体分析一下阿里云和AOK的优点
本文介绍了常见的Email接口API,如阿里云邮件推送、AOKSend、SendGrid、Mailgun和Amazon SES。阿里云API以其高稳定性和数据分析功能脱颖而出,支持批量发送和多语言;而AOKSend API以易于集成、高安全性和优秀客户支持为亮点。企业在选择时应考虑自身需求和预算,以优化邮件营销效果。