vue + 高德原生 API实现地图可视化

vue + 高德原生 API

由于项目需求,需要使用地图定位,最终决定使用 vue + 高德原生API;

当前项目环境 vue2.0+;

创建项目时,如果安装 eslint ,建议关闭eslint语法限制;

关闭方法:

在build/webpack.base.conf.js文件中,注释或者删除掉:module->rules中有关eslint的规则;

module: {
	rules: [
		  //...(config.dev.useEslint ? [createLintingRule()] : []), // 注释或者删除
		  {
		    test: /\.vue$/,
		    loader: 'vue-loader',
		    options: vueLoaderConfig
		  },
		  ...
		  }
	]
}

获取高德地图的key

获取地址:高德开放平台 https://lbs.amap.com/

在 index.html 引入

代码粘贴到项目中index.html文件中,并且把代码中“申请的key值”改为在高德开放平台申请的key值;

 <script type="text/javascript" src="https://webapi.amap.com/maps?v=1.4.15&key=申请的key值&&plugin=AMap.Autocomplete,AMap.PlaceSearch"></script>

** 定位:采用浏览器精确定位 **

在这里插入图片描述

    var map = new AMap.Map('container', {
        resizeEnable: true
    });
    AMap.plugin('AMap.Geolocation', function() {
        var geolocation = new AMap.Geolocation({
            enableHighAccuracy: true,//是否使用高精度定位,默认:true
            timeout: 10000,          //超过10秒后停止定位,默认:5s
            buttonPosition:'RB',    //定位按钮的停靠位置
            buttonOffset: new AMap.Pixel(10, 20),//定位按钮与设置的停靠位置的偏移量,默认:Pixel(10, 20)
            zoomToAccuracy: true,   //定位成功后是否自动调整地图视野到定位点

        });
        map.addControl(geolocation);
        geolocation.getCurrentPosition(function(status,result){
            if(status=='complete'){
                console.log(result) //解析定位结果
            }else{
                console.log(result) //解析定位错误信息
            }
        });
    });

** 输入提示后查询**

在这里插入图片描述

在这里插入图片描述

    //输入提示
    var map = new AMap.Map("container", {
        resizeEnable: true
    });
    var autoOptions = {
        input: "tipinput"
    };
    var auto = new AMap.Autocomplete(autoOptions);
    var placeSearch = new AMap.PlaceSearch({
        map: map
    });  //构造地点查询类
    AMap.event.addListener(auto, "select", (e)=>{
        placeSearch.setCity(e.poi.adcode);
        placeSearch.search(e.poi.name);  
    });//注册监听,当选中某条记录时会触发

** 点击按钮直接定位**

点击按钮直接实现地位,其实还是使用上面的 AMap.PlaceSearch

       placeSearch.setCity('110106'); //不设置也可以
       
       placeSearch.search('天安门');  //关键字查询查询

在这里插入图片描述
** 周边搜索**

当前案例是搜索周边 餐饮服务

    var map = new AMap.Map("container", {
        resizeEnable: true
    });
    AMap.service(["AMap.PlaceSearch"], function() {
        //构造地点查询类
        var placeSearch = new AMap.PlaceSearch({ 
            type: '餐饮服务', // 兴趣点类别
            pageSize: 30, // 单页显示结果条数
            pageIndex: 1, // 页码
            city: "010", // 兴趣点城市
            citylimit: true,  //是否强制限制在设置的城市内搜索
            map: map, // 展现结果的地图实例
        });
        
        //中心点坐标
        //这一块的中心点坐标可以根据 鼠标点击位置获取
        var cpoint = [116.405467, 39.907761]; 
        
        placeSearch.searchNearBy('', cpoint, 200, function(status, result) {
            console.log(status,result)
        });
    });

在这里插入图片描述
全部代码:vue + 高德原生 Api 实现地图可视化

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值