百度地图之自动提示--autoComplete
<!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的更多相关文章
- 百度地图的demo提示key验证错误!错误码:230;
在已经有BaiduMap的APIKey后使用AndroidStudio导入Baidu地图的as版的demo,提示key验证错误!错误码:230; 首先,因为百度地图demo中用自己的keystore文 ...
- 使用百度地图API自动获取地址和经纬度
先上效果图,这是直接点击获取经纬度和地址的.没有做搜索的功能. 代码: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitiona ...
- echarts 中国地图 数据自动提示
mounted() { // 首先每种图是根据series -->type决定的 eg:bar--柱状图 line 折线图 pie饼图 map地图等等三部曲 跟着走 // @第一步都是初始化 v ...
- 顾维灏谈百度地图数据采集:POI自动处理率达90%
顾维灏谈百度地图数据采集:POI自动处理率达90% 发布时间:2015-12-21 22:37 来源:cnsoftnews.com 作者: 百度地图还创新研发高精地 ...
- Vue中加载百度地图
借助百度地图的 LocalSearch 和 Autocomplete 两个方法 实现方式:通过promise以及百度地图的callback回调函数 map.js 1 export function M ...
- 百度地图api 实例 自动提示 并计算两地的行驶距离
百度地图api 实例 自动提示 并计算两地的行驶距离 <!DOCTYPE html> <html> <head> <meta http-equiv=" ...
- 百度地图API提示"230错误 APP Scode校验失败"
笔者近2天在 Android Studio上玩了一下百度地图,碰到了常见的"230错误 APP Scode校验失败",下面我来介绍一下具体的解决办法. 1.在andriodstud ...
- 百度地图API 级别自动缩放
今天做一个基于百度地图API的小项目 查了很长时间apid都没有找到地图呈现出来的时候地图按坐标的多少自动缩放显示的等级比例,特此记录笔记!var points = [point1, point2,p ...
- 百度地图API显示多个标注点,解决提示信息问题以及给标注增加地图旁的文字连接提示的另一种解决办法
原文:百度地图API显示多个标注点,解决提示信息问题以及给标注增加地图旁的文字连接提示的另一种解决办法 公司的网站改版要求在一个页面显示百度地图.上面要同时显示很多标注点,标注点当然要有提示信息嘛,提 ...
随机推荐
- Unity3D-制作火焰效果
1.插件的准备 随着官网上的迭代更新,连下载按钮都找了好久,今天制作的火焰效果要依赖一个插件,LowPoly Environment Pack 输入网址unity3d.com在Assert Store ...
- PAT——1037. 在霍格沃茨找零钱
如果你是哈利·波特迷,你会知道魔法世界有它自己的货币系统 —— 就如海格告诉哈利的:“十七个银西可(Sickle)兑一个加隆(Galleon),二十九个纳特(Knut)兑一个西可,很容易.”现在,给定 ...
- Http_load的安装和使用
Http_load的安装和使用 http_load基于linux平台的一种性能测工具.以并行复用的方式运行,用以测试web服务器的吞吐量与负载,测试web页面的性能. 安装: 进入工作目录:#cd / ...
- Reading Fast Packet Processing A Survey
COMST 2018 主要内容 这是一篇有关快速包转发的综述,先介绍了包转发的有关基础知识和背景,具体介绍了包转发的主流方法,对这些方法进行了细致详尽的比较,最后介绍了最新的方法和未来的研究方向. 包 ...
- HDU 3695 Computer Virus on Planet Pandora (AC自己主动机)
题意:有n种病毒序列(字符串),一个模式串,问这个字符串包括几种病毒. 包括相反的病毒也算.字符串中[qx]表示有q个x字符.具体见案列. 0 < q <= 5,000,000尽然不会超, ...
- npm run dev启动项目报错 Cannot find module 'webpack-cli/bin/config-yargs'
一般是webpack的版本和webpackserver的版本不兼容导致的错误. 解决方法是先卸载这两个版本,再安装指定的版本. 卸载: 再安装指定或者最新版本的webpack和webpack-dev- ...
- 05_Dockerfile实战(上)
在上一章我们介绍了docker镜像的概念,并且介绍了构建镜像的两种方式 使用docker commit命令提交创建的容器. 使用Dockerfile文件和docker build命令,这种更为推荐和常 ...
- C++练习 | 创建并倒序输出不带头结点的链表
#include <iostream> #include <cstdio> #include <stdlib.h> #include <stack> u ...
- Flume(4)-监控模型
一. 监控端口数据 首先启动Flume任务,监控本机44444端口,服务端: 然后通过netcat工具向本机44444端口发送消息,客户端: 最后Flume将监听的数据实时显示在控制台. 1. 安装n ...
- urllib库使用方法 2 parse
import urllib.parse #url.parse用法包含三个方法:quote url, unquote rul, urlencode#quote url 编码函数,url规范只识别字母.数 ...