<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="initial-scale=1, maximum-scale=1, user-scalable=no, width=device-width">
<title>百度地图之自动提示--autoComplete</title>
</head>
<body>
<button id="btn1">将深圳设置为检索区域</button>
<button id="btn2">将上海设置为检索区域</button>
<input id="register2suggestId" size="30" type="text" class="w-100-nick" placeholder="请输入"/>
<div id="register2map" style="width:300px;height:200px;"></div>
<script src="http://api.map.baidu.com/api?v=2.0&ak=ZUHewhg0KDCnZa5emK9hxRib&callback=init"></script>
<script> window.windowMapBusiness = {
//创建和初始化地图函数:
initMap: function (id, addr, s) {
this.createMap(id, addr, s);//创建地图
this.setMapEvent();//设置地图事件
this.addMapControl();//向地图添加控件
},
//创建地图函数:
createMap: function (id, addr, s) {
s = s ? s : 8;
window.map = new BMap.Map(id);// 将map变量存储在全局 在百度地图容器中创建一个地图
if (addr) {
map.centerAndZoom(addr, s);//设定地图的中心点和坐标并将地图显示在地图容器中
} else {
var geolocation = new BMap.Geolocation(); //实例化定位对象。
geolocation.getCurrentPosition(function (r) { //定位结果对象会传递给r变量 r.point.lng 经度 r.point.lat 纬度
if (this.getStatus() == BMAP_STATUS_SUCCESS) { //通过Geolocation类的getStatus()可以判断是否成功定位。
map.centerAndZoom(r.point, s);//设定地图的中心点和坐标并将地图显示在地图容器中
var mk = new BMap.Marker(r.point); //基于定位的这个点的点位创建marker
map.addOverlay(mk); //将marker作为覆盖物添加到map地图上
map.panTo(r.point); //将地图中心点移动到定位的这个点位置。注意是r.point而不是r对象。
} else {
map.centerAndZoom('广东省深圳市', s);//设定地图的中心点和坐标并将地图显示在地图容器中
}
}, {enableHighAccuracy: true});
}
},
//地图事件设置函数:
setMapEvent: function () {
map.enableScrollWheelZoom();//启用地图滚轮放大缩小
map.enableKeyboard();//启用键盘上下左右键移动地图
//map.disableDragging(); //禁止拖拽
// map.enableDragging(); // 开启拖拽
map.enableInertialDragging(); // 开启惯性拖拽
},
//地图控件添加函数:
addMapControl: function (sc) {
//向地图中添加缩放控件
var ctrl_nav = new BMap.NavigationControl({
anchor: BMAP_ANCHOR_TOP_LEFT,
type: BMAP_NAVIGATION_CONTROL_LARGE
});
map.addControl(ctrl_nav);
//向地图中添加缩略图控件
if (sc) {
var ctrl_ove = new BMap.OverviewMapControl({
anchor: BMAP_ANCHOR_BOTTOM_RIGHT,
isOpen: 1
});
map.addControl(ctrl_ove);
//向地图中添加比例尺控件
var ctrl_sca = new BMap.ScaleControl({
anchor: BMAP_ANCHOR_BOTTOM_LEFT
});
map.addControl(ctrl_sca);
}
},
// 设置单个标注-有单行提示文字
addMarker: function (addr, sc, lf, top) {
map.clearOverlays();//清除所有标注
new BMap.Geocoder().getPoint(addr, function (point) {
if (point) {
var sc = sc ? sc : 8,
lf = lf ? lf : 10 - addr.length * 6,//百度地图标注字体12px
top = top ? top : -20,
address = new BMap.Point(point.lng, point.lat);
map.centerAndZoom(address, sc);
var marker = new BMap.Marker(point);
map.addOverlay(marker);
marker.setLabel(new BMap.Label(addr, {offset: new BMap.Size(lf, top)}));
}
});
}, //处理地址--传入地址、函数 处理经纬度等 执行环境window 赋值通过scope 如 $scope.Lon=point.lng; $scope.Lat=point.lat;
responseAddr: function (addr, fun) {
new BMap.Geocoder().getPoint(addr, function (point) {
if (point) {//point.lng point.lat
fun(point);
}
});
},
//百度地图自动提示 -(未解决)还是检索的上一次的区域
autoComplete: function (suggestId, setLocation, keywords, sc, lf, top) {// id必填 keywords-array 其余-string
var me = this,
//建立一个自动完成的对象
ac = new BMap.Autocomplete({
"input": suggestId, //输入框id
"location": setLocation//设定返回结果的所属范围
}),
iptTrigger = document.getElementById(suggestId); //删除多余的元素,但百度地图自动生成的js报错 报错并不影响提示功能 暂设置为隐藏多余元素
function hideRestAcBox() {
var elm = Array.prototype.slice.call(document.getElementsByClassName('tangram-suggestion-main'));
if (elm.length) {
elm.forEach(function (v, i) {
// v.parentNode.removeChild(v);
v.style.zIndex = -1;
v.style.visibility = 'hidden';
});
elm[elm.length - 1].style.zIndex = 999;
elm[elm.length - 1].style.visibility = 'visible';
}
} function hideAcBox() {
var elm = Array.prototype.slice.call(document.getElementsByClassName('tangram-suggestion-main'));
elm.forEach(function (v, i) {
v.style.zIndex = -1;
v.style.visibility = 'hidden';
});
} //输入框的值控制 提示信息列表容器显示隐藏
function boxHide() {
console.log(this.value);
if (this.value) {
if (keywords) {//发起某个关键字的提示请求,会引起onSearchComplete的回调
ac.search.apply(ac, keywords);
}
hideRestAcBox();
} else {
hideAcBox();
}
} iptTrigger.oninput = boxHide;//非ie
iptTrigger.onpropertychange = boxHide;//ie
//鼠标点击下拉列表后的事件
ac.addEventListener("onconfirm", function (e) {
hideAcBox();
var _value = e.item.value;
var myValue = _value.province + _value.city + _value.district + _value.street + _value.business;
console.log(myValue);
me.addMarker(myValue, sc, lf, top);
});
} }; document.getElementById('btn1').onclick = function () {
console.log(1); windowMapBusiness.autoComplete('register2suggestId', '深圳市', ['大厦', '楼', '大学', '校区', '学院', '中专', '中学', '小学', '幼儿园']); };
document.getElementById('btn2').onclick = function () {
console.log(2); windowMapBusiness.autoComplete('register2suggestId', '上海市', ['大厦', '楼', '大学', '校区', '学院', '中专', '中学', '小学', '幼儿园']); }; setTimeout(function () {
windowMapBusiness.initMap('register2map', '深圳');
}, 1000);
</script>
</body>
</html>

百度地图之自动提示--autoComplete的更多相关文章

  1. 百度地图的demo提示key验证错误!错误码:230;

    在已经有BaiduMap的APIKey后使用AndroidStudio导入Baidu地图的as版的demo,提示key验证错误!错误码:230; 首先,因为百度地图demo中用自己的keystore文 ...

  2. 使用百度地图API自动获取地址和经纬度

    先上效果图,这是直接点击获取经纬度和地址的.没有做搜索的功能. 代码: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitiona ...

  3. echarts 中国地图 数据自动提示

    mounted() { // 首先每种图是根据series -->type决定的 eg:bar--柱状图 line 折线图 pie饼图 map地图等等三部曲 跟着走 // @第一步都是初始化 v ...

  4. 顾维灏谈百度地图数据采集:POI自动处理率达90%

    顾维灏谈百度地图数据采集:POI自动处理率达90%   发布时间:2015-12-21 22:37        来源:cnsoftnews.com        作者:   百度地图还创新研发高精地 ...

  5. Vue中加载百度地图

    借助百度地图的 LocalSearch 和 Autocomplete 两个方法 实现方式:通过promise以及百度地图的callback回调函数 map.js 1 export function M ...

  6. 百度地图api 实例 自动提示 并计算两地的行驶距离

    百度地图api 实例 自动提示 并计算两地的行驶距离 <!DOCTYPE html> <html> <head> <meta http-equiv=" ...

  7. 百度地图API提示"230错误 APP Scode校验失败"

    笔者近2天在 Android Studio上玩了一下百度地图,碰到了常见的"230错误 APP Scode校验失败",下面我来介绍一下具体的解决办法. 1.在andriodstud ...

  8. 百度地图API 级别自动缩放

    今天做一个基于百度地图API的小项目 查了很长时间apid都没有找到地图呈现出来的时候地图按坐标的多少自动缩放显示的等级比例,特此记录笔记!var points = [point1, point2,p ...

  9. 百度地图API显示多个标注点,解决提示信息问题以及给标注增加地图旁的文字连接提示的另一种解决办法

    原文:百度地图API显示多个标注点,解决提示信息问题以及给标注增加地图旁的文字连接提示的另一种解决办法 公司的网站改版要求在一个页面显示百度地图.上面要同时显示很多标注点,标注点当然要有提示信息嘛,提 ...

随机推荐

  1. Dubbo实践(十二)Refer

    Spring在启动Dubbo客户端应用时,会实例化ReferenceBean<T>并设置配置属性,然后调用ReferenceConfig中的get方法: public synchroniz ...

  2. Shell笔记-02

    Shell支持自定义变量. 定义变量 定义变量时,变量名不加美元符号($),如: variableName="value" 注意,变量名和等号之间不能有空格,这可能和你熟悉的所有编 ...

  3. JNI由浅入深_5_基本类型应用

    1.基本类型应用 对于JNI处理基本类型还是比较简单的,下面是Java代码: <span style="font-size:14px;"> public native ...

  4. 【题解】洛谷P1966 [NOIP2013TG] 火柴排队(树状数组+逆序对)

    次元传送门:洛谷P1966 思路 显然在两排中 每排第i小的分别对应就可取得最小值(对此不给予证明懒) 所以我们只在意两排的火柴是第几根 高度只需要用来进行排序(先把两个序列改成有序的方便离散化) 因 ...

  5. CC2640R2F&TI-RTOS 拿到 TI CC2640R2F 开发板 第一件事就是移植串口驱动,重定向 printf

    /* * board_uart.c * * Created on: 2018年7月3日 * Author: admin */ #include "board_uart.h" #in ...

  6. .NET Core中基类可以反射子类的成员

    我们定义一个类DemoA,再定义一个类DemoB继承DemoA.当构造一个DemoB类对象后,我们可以通过其调用基类DemoA中的方法来反射子类DemoB的成员. 新建一个.NET Core控制台项目 ...

  7. C#中Array类

    Array类是C#中所有数组的基类,它是在System命名空间中定义的,Array类提供了各种用于数组的属性和方法

  8. uboot中ftd命令

    可以从u-boot官网源码下载一个比较新的u-boot, 查看它的cmd/fdt.cftp://ftp.denx.de/pub/u-boot/ fdt命令使用示例nand read.jffs2 320 ...

  9. import 本质

    一. 模块:用来从逻辑上来组织python代码(变量,函数,类,逻辑,实现一个功能),本质就是,py结尾的python文件 1.1 导入方法: import module import module1 ...

  10. package-lock.json 作用

    package.json里面定义的是版本范围(比如^1.0.0),具体跑npm install的时候安的什么版本,要解析后才能决定,这里面定义的依赖关系树,可以称之为逻辑树(logical tree) ...