博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
html5通过坐标定位城市,HTML5如何获取地理经纬度并通过百度接口得到实时位置...
阅读量:4363 次
发布时间:2019-06-07

本文共 4298 字,大约阅读时间需要 14 分钟。

本篇教程探讨了HTML5如何获取地理经纬度并通过百度接口得到实时位置,希望阅读本篇文章以后大家有所收获,帮助大家HTML5+CSS3从入门到精通 。

<

注:用的时候将获取北京位置那放到获取经度纬度后面即可

-----------实际用的时候的代码如下:start  --------

var myCity;

getLocation()

function getLocation(){

//根据IP获取城市

myCity = new BMap.LocalCity();

var options={

enableHighAccuracy:true,

maximumAge:1000

}

if(navigator.geolocation){

//浏览器支持geolocation

navigator.geolocation.getCurrentPosition(onSuccess,onError,options);

}else{

//浏览器不支持geolocation

console.log("浏览器不支持");

}

}

function onSuccess(position){

//position.coords.longitude;//经度

// position.coords.latitude;//纬度

console.log(position.coords.longitude)

setTimeout(function(){

myCity.get(getCityByIP);

},500)

}

//根据IP获取城市

function getCityByIP(rs) {

var cityName = rs.name;

console.log(rs)

alert("根据IP定位您所在的城市为:" + cityName);

}

//失败时

function onError(error){

switch(error.code){

case 1:

alert("位置服务被拒绝");

break;

case 2:

alert("暂时获取不到位置信息");

break;

case 3:

alert("获取信息超时");

break;

case 4:

alert("未知错误");

break;

}

}

------------------------ end ---------------------

https://blog.csdn.net/dreamboycx/article/details/52130772

html>

获取当前位置

html{height:100%}

body{height:100%;margin:0px;padding:0px}

#container{height:500px; width: 500px; margin: 0 auto;}

//v2.0版本的引用方式:src="http://api.map.baidu.com/api?v=2.0&ak=您的密钥"

//v1.4版本及以前版本的引用方式:src="http://api.map.baidu.com/api?v=1.4&key=您的密钥&callback=initialize"

点击这个按钮,获得您的经纬度:

获取位置

var map;

var ggPoint;

var marker;

function getLocation(){

//根据IP获取城市

var myCity = new BMap.LocalCity();

myCity.get(getCityByIP);

var options={

enableHighAccuracy:true,

maximumAge:1000

}

if(navigator.geolocation){

//浏览器支持geolocation

navigator.geolocation.getCurrentPosition(onSuccess,onError,options);

}else{

//浏览器不支持geolocation

console.log("浏览器不支持");

}

}

function onSuccess(position){

var longitude =position.coords.longitude;//经度

var latitude = position.coords.latitude;//纬度

document.getElementById("demo").innerHTML = "程序已获取你所在的位置为:

经度"+longitude+",纬度"+latitude;

//--------------设置地图显示----------------

map = new BMap.Map("container"); // 创建地图实例

ggPoint = new BMap.Point(longitude, latitude); // 创建点坐标

map.centerAndZoom(ggPoint, 15); // 初始化地图,设置中心点坐标和地图级别

//--------------设置地图显示----------------

var convertor = new BMap.Convertor();

var pointArr = [];

pointArr.push(ggPoint);

convertor.translate(pointArr, 1, 5, translateCallback);

//--------------设置标注相关-------------------

/*var marker = new BMap.Marker(point); // 创建点

map.addOverlay(marker);

marker.setAnimation(BMAP_ANIMATION_BOUNCE); //跳动的动画

marker.enableDragging();//设置点可拖动

//--------------设置标注相关---------------------

//--------------获取地理位置---------------------

var geoc = new BMap.Geocoder();

geoc.getLocation(point, function(rs){

var addComp = rs.addressComponents;

alert(addComp.province + ", " + addComp.city + ", " + addComp.district + ", " + addComp.street + ", " + addComp.streetNumber);

});*/

//--------------获取地理位置----------------------

}

//坐标转换完之后的回调函数

function translateCallback(data){

if(data.status === 0) {

marker = new BMap.Marker(data.points[0]);

map.addOverlay(marker);

marker.setAnimation(BMAP_ANIMATION_BOUNCE); //跳动的动画

marker.enableDragging();//设置点可拖动

marker.addEventListener("dragend",getAttr);

//alert(marker.getPosition());

map.setCenter(data.points[0]);

getPosit(data.points[0]);

}

}

function getAttr(){

var p = marker.getPosition(); //获取marker的位置

//alert("marker的位置是" + p.lng + "," + p.lat);

getPosit(new BMap.Point(p.lng, p.lat));

}

function getPosit(obj){

var geoc = new BMap.Geocoder();

geoc.getLocation(obj, function(rs){

var addComp = rs.addressComponents;

//alert(addComp.province + ", " + addComp.city + ", " + addComp.district + ", " + addComp.street + ", " + addComp.streetNumber);

var address = "您的地址:" + addComp.province + "," + addComp.city + "," + addComp.district + "," + addComp.street + "," + addComp.streetNumber;

document.getElementById("position").innerHTML = address;

//var labelbaidu = new BMap.Label(address, { offset: new BMap.Size(20, -10) });

//marker.setLabel(labelbaidu); //添加百度标注

});

}

//根据IP获取城市

function getCityByIP(rs) {

var cityName = rs.name;

alert("根据IP定位您所在的城市为:" + cityName);

}

//失败时

function onError(error){

switch(error.code){

case 1:

alert("位置服务被拒绝");

break;

case 2:

alert("暂时获取不到位置信息");

break;

case 3:

alert("获取信息超时");

break;

case 4:

alert("未知错误");

break;

}

}

本文由职坐标整理并发布,希望对同学们有所帮助。了解更多详情请关注职坐标WEB前端HTML5/CSS3频道!

你可能感兴趣的文章
关于动态添加iview admin路由以及刷新侧边栏
查看>>
ApplicationInsights的探测器尝鲜
查看>>
java 解析Json格式数据
查看>>
unix中的线程池技术详解
查看>>
CSS简介
查看>>
常用三大软件评价1
查看>>
MVC各层介绍使用---初步理解
查看>>
单例对象的创建与销毁
查看>>
知识点关键词(记录一下)
查看>>
国际结算业务
查看>>
嵌套循环概念
查看>>
IOS开发札记
查看>>
ASP.NET MVC Model绑定(二)
查看>>
一步一步写算法(之hash表)
查看>>
漫谈并发编程(一) - 并发简单介绍
查看>>
JDBC连接MySQL数据库及演示样例
查看>>
Beta 冲刺(1/7)
查看>>
修改 Vultr 登录密码
查看>>
CSS学习
查看>>
Centos 安装lnmp完整版
查看>>