① html5应用 调用百度地图API 为什么在手机端
最近项目需要,稍微研究一下html5获取当前地理位置的问题。
获取当前位置的经纬度很简单,一句代码就搞定
[javascript]view plain
navigator.geolocation.getCurrentPosition(function(position){
longitude=position.coords.longitude;
latitude=position.coords.latitude;
});
[javascript]view plain
varmap=newBMap.Map("allmap");<prename="code"class="javascript">varpoint=newBMap.Point(longitude,latitude);<prename="code"class="javascript">vargeoc=newBMap.Geocoder();
[javascript]view plain
geoc.getLocation(point,function(rs){
varaddComp=rs.addressComponents;
alert(addComp.province+","+addComp.city+","+addComp.district+","+addComp.street+","+addComp.streetNumber);
});
一开始以为是html5获取经纬度的偏差问题,然而并不是
然后开始查资料,求助强大的度娘,然后无意中发现了一个叫做坐标转换的东西,一搜索才知道,原来网络地图对坐标进行了深度封装,必须通过他提供的接口进行坐标转换才行
(当然了,还是因为我以前没接触过网络地图,所以不知道这点知识,常用网络地图api的应该对这个很熟悉的吧)
好了,废话不多说,上最终代码吧
[javascript]view plain
varmap=newBMap.Map("allmap");
varlongitude,latitude;
navigator.geolocation.getCurrentPosition(function(position){
longitude=position.coords.longitude;
latitude=position.coords.latitude;
});
setTimeout(function(){
vargpsPoint=newBMap.Point(longitude,latitude);
BMap.Convertor.translate(gpsPoint,0,function(point){
vargeoc=newBMap.Geocoder();
geoc.getLocation(point,function(rs){
varaddComp=rs.addressComponents;
alert(addComp.province+","+addComp.city+","+addComp.district+","+addComp.street+","+addComp.streetNumber);
});
});
},3000);
[html]view plain
<scripttype="text/javascript"src="http://api.map..com/api?v=2.0&ak=秘钥"></script>
<scripttype="text/javascript"src="http://developer..com/map/jsdemo/demo/convertor.js"></script>
② 关于百度地图API的问题
网络地图 API中,初始有设置地图中心位置的。设定好就OK。
③ 下面代码提示convertor.js语法错误,请高手修改,高分悬赏
http://dev..com/wiki/static/map/API/examples/script/convertor.js 这个地址改了,换成这个试试
http://developer..com/map/jsdemo/demo/convertor.js 我也是才发现的,这是个demo的地址,不知道有没有常用地址.
④ 在百度地图api,经纬度怎么转换成百度坐标
//经纬度坐标
var x = 116.32715863448607;
var y = 39.990912172420714;
var ggPoint = new BMap.Point(x,y);
//坐标转换完之后的回调函数
translateCallback = function (data){
if(data.status === 0) {
var marker = new BMap.Marker(data.points[0]);
//data.points[0])就是转换后的网络坐标
}
}
//坐标转换
setTimeout(function(){
var convertor = new BMap.Convertor();
var pointArr = [];
pointArr.push(ggPoint);
convertor.translate(pointArr, 1, 5, translateCallback)
}, 1000);
⑤ html5 v2.0百度地图手机触屏缩放地图
网络搜索下“网络地图生成器”,里面都有你想要的缩放,可以选择的。
有疑问可以继续问,望采纳!
⑥ 我在一个页面,调用了百度地图的API,我整到一个js文件内,但是同页面的另一个js特效却没用了
把引入文件的链接代码,放在最下面
⑦ 点击按钮显示百度地图 js如何实现 在html里面 不是jsp
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>HTML5定位</title>
<script type="text/javascript" src="http://lib.sinaapp.com/js/jquery/1.7.2/jquery.min.js"></script>
<script type="text/javascript" src="http://api.map..com/api?v=2.0&ak=wqBXfIN3HkpM1AHKWujjCdsi"></script>
<script type="text/javascript" src="http://developer..com/map/jsdemo/demo/convertor.js"></script>
<style type="text/css">
*{ margin: 0px; padding: 0px;}
body{text-align: center; height: 100%;overflow:hidden;}
#allmap{ width: 100%;height: 100%; position: absolute;}
</style>
</head>
<body>
<div id="allmap"></div>
<script type="text/javascript">
$(function(){
if(supportsGeoLocation()){
alert("你的浏览器支持 GeoLocation.");
}else{
alert("不支持 GeoLocation.")
}
// 检测浏览器是否支持HTML5
function supportsGeoLocation(){
return !!navigator.geolocation;
}
// 单次位置请求执行的函数
function getLocation(){
navigator.geolocation.getCurrentPosition(mapIt,locationError);
}
//定位成功时,执行的函数
function mapIt(position){
var lon = position.coords.longitude;
var lat = position.coords.latitude;
// alert("您位置的经度是:"+lon+" 纬度是:"+lat);
var map = new BMap.Map("allmap");
var point = new BMap.Point(""+lon+"",""+lat+"");
map.centerAndZoom(point,19);
var gc = new BMap.Geocoder();
translateCallback = function (point){
var marker = new BMap.Marker(point);
map.addOverlay(marker);
map.setCenter(point);
gc.getLocation(point, function(rs){
var addComp = rs.addressComponents;
if(addComp.province!==addComp.city){
var sContent =
"<div><h4 style='margin:0 0 5px 0;padding:0.2em 0'>你当前的位置是:</h4>" +
"<p style='margin:0;line-height:1.5;font-size:13px;text-indent:2em'>"+addComp.province + ", " + addComp.city + ", " + addComp.district + ", " + addComp.street + ", " + addComp.streetNumber+"</p>" +
"</div>";}
else{
var sContent =
"<div><h4 style='margin:0 0 5px 0;padding:0.2em 0'>你当前的位置是:</h4>" +
"<p style='margin:0;line-height:1.5;font-size:13px;text-indent:2em'>"+ addComp.city + ", " + addComp.district + ", " + addComp.street + ", " + addComp.streetNumber+"</p>" +
"</div>";
}
var infoWindow = new BMap.InfoWindow(sContent);
map.openInfoWindow(infoWindow,point);
});
}
BMap.Convertor.translate(point,0,translateCallback);
}
// 定位失败时,执行的函数
function locationError(error)
{
switch(error.code)
{
case error.PERMISSION_DENIED:
alert("User denied the request for Geolocation.");
break;
case error.POSITION_UNAVAILABLE:
alert("Location information is unavailable.");
break;
case error.TIMEOUT:
alert("The request to get user location timed out.");
break;
case error.UNKNOWN_ERROR:
alert("An unknown error occurred.");
break;
}
}
// 页面加载时执行getLocation函数
window.onload = getLocation;
})
</script>
</body>
</html>