zoukankan      html  css  js  c++  java
  • 【笔记】使用腾讯地图坐标转换

    首先是js的引用

    <script charset="utf-8" src="http://map.qq.com/api/js?v=2.exp&key=YOUR_KEY"></script>

    腾讯地图js除了提供基本的功能库外,还提供了一些有用的附加库,下面这个是引用了坐标转换库的js引用

    <script type="text/javascript" charset="utf-8" src="http://map.qq.com/api/js?v=2.exp&key=YOUR_KEY&libraries=convertor"></script>

    其中libraries参数用来指明加载的附加库,可以指定多个附加库名称,

    名称之间用英文半角字符逗号","分隔。支持的附加库种类:

    • drawing 绘图工具库,用于在地图上方绘制折线、多边形、圆等几何图形;
    • geometry 几何运算库,用于计算地球表面的距离、面积等;
    • autocomplete 文本输入提示库,用于快速帮助用户完成检索关键词输入;
    • convertor 坐标转换库,将标准经纬度或其它地图API经纬度转换为腾讯经纬度坐标系。

    关于附加库的详细接口,请参见腾讯地图的参考手册

    我这里只需要引用坐标转换库

    首先是地图坐标转换,其实这些在腾讯地图API中都能找的到,我这边只是做个笔记,方便下次用到。

    //百度地图坐标转腾讯地图坐标
    conver: function () {
      //转换百度坐标为腾讯坐标
       qq.maps.convertor.translate(new qq.maps.LatLng("百度坐标N", "百度坐标E"), 3, function (res) {
         latlng = res[0];
         //console.log(latlng);
         location.href = "http://apis.map.qq.com/uri/v1/marker?marker=coord:" + latlng.lat + "," + latlng.lng + ";title:想要显示的坐标名称&referer=myapp"; })
    }

    然后是根据地址查询坐标

    selectLoaction: function () {
      //调用地址解析类
       geocoder = new qq.maps.Geocoder({
         complete: function (result) {
            location.href = "http://apis.map.qq.com/uri/v1/marker?marker=coord:" + result.detail.location.lat + "," + result.detail.location.lng + ";title:想要显示的坐标名称&referer=myapp";
           }
       });
       geocoder.getLocation("需要查询的地址");
    }

    最后一个是对标记的操作,在地图上点击时添加一个标记,并删除原来的标记。

    //初始坐标
    var center = new qq.maps.LatLng(39.916527, 116.397128); map = new qq.maps.Map(document.getElementById('container'), { center: center, zoom: 15 }); //添加监听事件,获取鼠标单击事件 qq.maps.event.addListener(map, 'click', function (event) { //删除一个初始标记 if (markersArray) { for (i in markersArray) { markersArray[i].setMap(null); } } //添加标记 var marker = new qq.maps.Marker({ position: event.latLng, map: map }); console.log(event.latLng); //删除原来的标记 qq.maps.event.addListener(map, 'click', function (event) { marker.setMap(null); }); });
  • 相关阅读:
    Restful接口传入多参数
    map转换成JSON的3种方式
    项目打包后执行start.sh提示“no such file or directory”解决办法,linux中给文件增加权限
    如何将一个a表a1字段与b表b1字段的笛卡尔积插入到e表中
    get、set方法的取代注释之lombok插件
    推荐 33 个 IDEA 最牛配置转(Java技术栈)
    mysql-----group by 对多个字段进行分组
    mysql获取某段时间内每一天的统计数据
    发票流水号生成方式
    postman之post请求传参
  • 原文地址:https://www.cnblogs.com/yuzuoxiang/p/5809014.html
Copyright © 2011-2022 走看看