newmiracle

html5获取自己定位的方法
直接用高德地图api 不要用百度地图api 不准确


<pre>
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="initial-scale=1.0, user-scalable=no, width=device-width">
<title>浏览器定位</title>
<link rel="stylesheet" href="http://cache.amap.com/lbs/static/main1119.css"/>
<script type="text/javascript"
src="http://webapi.amap.com/maps?v=1.3&key=00955dce4bad4be3ec81058776e0e307"></script>
<script type="text/javascript" src="http://cache.amap.com/lbs/static/addToolbar.js"></script>
<body>

<div style="width:30px; height:30px; background: #000; position: absolute;left:10px; top:10px;z-index: 9999" class="dss" onclick="getdingwei();"></div>
<div id="result"></div>
<div id=\'container\' style="display: none"></div>
<div id="tip"></div>
<script type="text/javascript">

function regeocoder(lnglatXY) { //逆地理编码
var geocoder = new AMap.Geocoder({
radius: 1000,
extensions: "all"
});
geocoder.getAddress(lnglatXY, function(status, result) {
if (status === \'complete\' && result.info === \'OK\') {
geocoder_CallBack(result);
}
});
var marker = new AMap.Marker({ //加点
map: map,
position: lnglatXY
});
}
function geocoder_CallBack(data) {
var address = data.regeocode.formattedAddress; //返回地址描述
document.getElementById("result").innerHTML = address;
}
function getdingwei() {
map.plugin(\'AMap.Geolocation\', function() {
geolocation = new AMap.Geolocation({
enableHighAccuracy: true,//是否使用高精度定位,默认:true
timeout: 10000, //超过10秒后停止定位,默认:无穷大
buttonOffset: new AMap.Pixel(10, 20),//定位按钮与设置的停靠位置的偏移量,默认:Pixel(10, 20)
zoomToAccuracy: true, //定位成功后调整地图视野范围使定位位置及精度范围视野内可见,默认:false
buttonPosition:\'RB\'
});
map.addControl(geolocation);
geolocation.getCurrentPosition();
AMap.event.addListener(geolocation, \'complete\', onComplete);//返回定位信息
AMap.event.addListener(geolocation, \'error\', onError); //返回定位出错信息
});
}

/***************************************
由于Chrome、IOS10等已不再支持非安全域的浏览器定位请求,为保证定位成功率和精度,请尽快升级您的站点到HTTPS。
***************************************/
var map, geolocation;
//加载地图,调用浏览器定位服务
map = new AMap.Map(\'container\', {
resizeEnable: true
});

//解析定位结果
function onComplete(data) {
lnglatXY = [data.position.getLng(), data.position.getLat()]; //已知点坐标
regeocoder(lnglatXY);
var str=[\'定位成功\'];
str.push(\'经度:\' + data.position.getLng());
str.push(\'纬度:\' + data.position.getLat());
if(data.accuracy){
str.push(\'精度:\' + data.accuracy + \' 米\');
}//如为IP精确定位结果则没有精度信息
str.push(\'是否经过偏移:\' + (data.isConverted ? \'是\' : \'否\'));
document.getElementById(\'tip\').innerHTML = str.join(\'<br>\');
}
//解析定位错误信息
function onError(data) {
document.getElementById(\'tip\').innerHTML = \'定位失败\';
}
</script>
</body>
</html>
</pre>
直接点黑色方块就可以获取定位 pc和浏览器都支持
ps:别用谷歌浏览器的那个模拟手机端的机制测试 会定位失败

分类:

技术点:

相关文章:

  • 2021-12-20
  • 2022-12-23
  • 2021-10-16
  • 2021-11-30
  • 2022-12-23
  • 2021-05-19
猜你喜欢
  • 2021-12-20
  • 2022-01-01
  • 2022-12-23
  • 2022-12-23
  • 2021-07-27
  • 2022-02-23
相关资源
相似解决方案