HTML5地理位置与LBS应用开发的方法-成都快上网建站

HTML5地理位置与LBS应用开发的方法

这篇文章主要介绍“HTML5地理位置与LBS应用开发的方法”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“HTML5地理位置与LBS应用开发的方法”文章能帮助大家解决问题。

香洲网站建设公司创新互联,香洲网站设计制作,有大型网站制作公司丰富经验。已为香洲数千家提供企业网站建设服务。企业网站搭建\成都外贸网站建设公司要多少钱,请找那个售后服务好的香洲做网站的公司定做!

1. LBS应用开发示例

在5年前,我们不敢想象会有如此众多的供应商提供免费的电子地图服务,而现在,开发者拥有众多选择:阿里云电子地图,百度电子地图,新浪电子地图,谷歌电子地图等。这里我们演示的是阿里云电子地图。

下面表示一个典型的LBS服务,通过GPS,Wi-Fi或其他方式查找设备所在的位置信息,通过此信息,在方圆1000米的范围内查找所有的酒店,总共前10个酒店显示在地图上。

具体示例代码如下所示。

 

  定位功能</ title></p><p>  <meta  http-equiv = “ pragma“  content = ” no-cache“  /></p><p>  <meta  name = ” viewport“  content = ”宽度=设备宽度,高度=设备高度,初始比例= 1.0,最小比例= 1.0,最大比例= 1.0 ,user-scalable = no“  /></p><p>  <link  href = ” opera.css“  rel = ”stylesheet“  type = ” text / css“ /></p><p>  <script  src = “ http://api.ditu.aliyun.com/map.js”  type = “ text / javascript” ></p><p></ script> <!-上面提到的是阿里云地图-></p><p>  <脚本 类型= “ text / javascript”  charset = “ utf-8”  src = “ foropera.js” ></p><p></ script></p><p></ head></p><p><body></p><p>  <div  id = “ divLayer” 样式= “ background-color:#333 ; font-size:20px; color:#FFF; margin-top:200px; margin -left:0px; text-align:center; height:40px; line-height:40px;“ ></p><p>   = “ helpme” 样式= “不透明度:0.9;位置:绝对; z-index:1000;顶部:100px;左侧:20px;显示:无;背景颜色:#333; -webkit-border-radius:15px;右侧:20px;“ ></p><p>    <center  style = “ margin-left:10px; margin-right:10px; border-bottom:1px#777 solid;” ></p><p>      <span  style = “ color:#fff; height:30px; line-height:60px; font-size:26px;” >定位功能</ span></p><p>    </ center></p><p>    <div  style = “ color:#ccc; font-size:18px; margin-left:20px; margin-right:20px; margin-top:16px;” ></p><p>    </ div> <br  /></p><p>    <center></p><p>      <button  onclick = “ hiddeDiv('helpme')”“  style = ” opacity:1; background-color:#777; border:0px; height:35px; line-height:25px ; color:#eee; width:140px; font-size:18px; -webkit-border-radius:5px;“ >关闭提示</ button></p><p>    </ center> <br  /></p><p>  </ div></p><p>  <div  id = “ help”  style = “ z-index:1000; position:absolute; left:0px; top:30px;” > </ div> <script  type = “ text / javascript” ></p><p>// <!</p><p>'helpme')。样式.display = 'none' ;</p><p>  }</p><p>  函数showhelp(){</p><p>  document.getElementById('helpme')。样式.display = '' ;</p><p>  }</p><p>  // ]] ></p><p>  </ script></p><p>  <div  id = “ mapDiv”  style = “ width:480px; height:800px” > </ div></p><p>  <div  id = “ lsResultDiv” > </ div> <script  type = “ text / javascript“ ></p><p>// <![CDATA [</p><p>  $('+ window.innerWidth + “ px; height:” + window.innerHeight + “</p><p>  px ”;</p><p>  function func_control(){</p><p>  alert('此处可以定制为某项功能');</p><p>  }</p><p>  Jla.require(“ Ali.Map.MapType.AliMobile”); //加载手机地图的功能</p><p>  Jla.onReady(onLoad);</p><p>  函数onLoad(){</p><p>  $('divLayer')。style.top =((window.innerHeight / 2)-20)+ “ px” ;</p><p>  $('divLayer').style.left =((window.innerWidth / 2)-150)+ “ px” ;</p><p>  $('divLayer').style。</p><p>  $('divLayer').innerHTML = '正在加载地图......' ;</p><p>  var hasGeolocation = !!(navigator.geolocation);</p><p>  if(!hasGeolocation){</p><p>  alert(“浏览器不支持Geolocation”);</p><p>  }</p><p>  var map,markers = [];</p><p>  var map = new AliMap(“ mapDiv”); //使用id为mapDiv的层创建一个地图对象</p><p>  AliEvent.addListener(map,  “ click”,function(){ //监听事件</p><p>  alert(“有人放置了地图。”);</p><p>  });</p><p>  localStorage.wd = “ 0” ; //如果没有获取到任何地理坐标,则直接替换为0</p><p>  localStorage.jd = “ 0” ;如果没有获取到任何地理坐标,则</p><p>  直接替换为0 showmap(localStorage.wd,localStorage.jd,localStorage.cx); //展示地图</p><p>  var geolocationOptions = {timeout:30000,enableHighAccuracy:true,maximumAge:5000};</p><p>  $('divLayer').innerHTML = '正在获取坐标......' ;</p><p>  navigator.geolocation.getCurrentPosition(geolocationSuccess,geolocationError,</p><p>  geolocationOptions);</p><p>  function geolocationSuccess(position){</p><p>  alert(“北纬:” + position.coords.latitude + “,东经:” + position.coords.longitude);</p><p>  //打开当前的经纬度坐标</p><p>  localStorage.wd = position.coords.latitude;</p><p>  localStorage.jd = position.coords.longitude;</p><p>  localStorage.cx = position.coords.heading;</p><p>  showmap(localStorage.wd,localStorage.jd,localStorage.cx); //展示地图</p><p>  }</p><p>  setInterval(function(){</p><p>  //每隔20秒重新刷新地图</p><p>  showmap(localStorage.wd,localStorage.jd,localStorage.cx);</p><p>  },20000);</p><p>  function geolocationError(err){</p><p>  switch(err.code){</p><p>  case 1:</p><p>  $('divLayer').innerHTML = '坐标获取被拒绝,地图加载失败' ;</p><p>  休息;</p><p>  情况2:</p><p>  $('divLayer')。innerHTML = '连不上GPS卫星或网络断了' ;</p><p>  休息;</p><p>  情况3:</p><p>  $('divLayer').innerHTML = ';</p><p>  休息;</p><p>  默认值:</p><p>  $('divLayer').innerHTML = '发生严重异常,请刷新页面' ;</p><p>  休息;</p><p>  }</p><p>  }</p><p>  函数showmap(wd,jd,cx){</p><p>  $('divLayer').innerHTML = '正在展示数据......' ;</p><p>  //在该坐标处创建一个标记</p><p>  var MAPMAP = new AliLatLng(localStorage.wd,localStorage.jd);</p><p>  if(cx === null){</p><p>  alert('对不起,取不到当前朝向');</p><p>  }</p><p>  yycontrol = new AliMapOverviewControl({open:true}); //创建一个鹰眼控件</p><p>  map.addControl(yycontrol); //将鹰眼控件添加到地图</p><p>  //设置调用的地图类型为手机版地图</p><p>  map.setMapType(new(Jla.get(“ Ali.Map.MapType.AliMobile”))());</p><p>  map.centerAndZoom(MAPMAP,14); //定位地图</p><p>  search =新的AliLocalSearch(); //设置搜索结果处理函数</p><p>  AliEvent.addListener(search,“ searchcomplete”,onSearchComplete);</p><p>  AliEvent.addListener(search,“ searchexception ”,onSearchException);</p><p>  var search_keyword = “酒店” ;</p><p>  var search_radius = 1000; //搜索</p><p>  国会是1000米search.keyword = search_keyword; //设置关键字</p><p>  search.pageSize = 10; //设置返回结果数量</p><p>  search.center = map.getCenter();</p><p>  search.execute(); //开始搜索</p><p>  marker = new AliMarker(MAPMAP); //将标记添加到地图</p><p>  //创建事件监视器,在MapMove函数</p><p>  map.openInfoWindow(MAPMAP,'我的位置','<div>附近的蓝点,是方圆</p><p>  '+ search_radius +'米内的'+ search_keyword +' < \ / div> ');</p><p>  var icons = [</p><p>  newAliIcon(“ icon1.gif”,{x:16,y:27},{x:8,y:27}),</p><p>  newAliIcon(“ icon2.png”,{x:23,y:29} ,{x:13,y:14}),</p><p>  newAliIcon(“ icon3.png”,{x:49,y:59},{x:24,y:56})</p><p>  ]];</p><p>  marker.setIcon(icons [1]);</p><p>  map.addOverlay(marker);</p><p>  椭圆形=新</p><p>  AliOvalOverlay(map.getProjection()。getSquare(MAPMAP,search_</p><p>  radius),{editSymbolCtl:128}); //以中心为中心,3000米为直径的圆</p><p>  map.addOverlay(oval);</p><p>  椭圆形。开始编辑({keepRatio:true});</p><p>  椭圆形.endEditting({keepRatio:true});</p><p>  函数onSearchException(exception){</p><p>  alert(exception.message);</p><p>  }</p><p>  函数onSearchComplete(){  //处理搜索结果</p><p>  变量标记,resultDiv = document.getElementById(“ lsResultDiv”);</p><p>  AliEvent.deposeNode(resultDiv,true);</p><p>  while(marker = markers.pop()){</p><p>  map.removeOverlay(marker);</p><p>  }</p><p>  for(var i = 0; i < search.points.length; i++){</p><p>  var  poi = search.points [ i ];</p><p>  标记=新AliMarker(poi.latlng,{标题:POI名称});</p><p>  映射.addOverlay(marker);</p><p>  //将标记的信息浮窗内容记录下来</p><p>  marker._desc = “我是第” +(i + 1)+ “个” + search_keyword;</p><p>  AliEvent.bind(marker,  “ click”  ,marker,onMarkerclick);</p><p>  markers.push(marker);</p><p>  }</p><p>  }</p><p>  函数onMarkerclick(){</p><p>  //确保信息浮窗在视图范围内</p><p>  无功 infowin = this.openInfoWindow(此。标题,this._desc);</p><p>  infowin.moveIntoView();</p><p>  }</p><p>  $('divLayer').innerHTML = “” ;</p><p>  $('divLayer')。样式.top = “ 0px” ;</p><p>  $('divLayer')。样式.left = “ 0px” ;</p><p>  $('divLayer')。风格。width = “ 0px” ;</p><p>  $('divLayer')。样式.display = 'none' ;</p><p>  }</p><p>  }</p><p>  // ]] ></p><p>  </ script></p><p></ body></p><p>关于“HTML5地理位置与LBS应用开发的方法”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注创新互联行业资讯频道,小编每天都会为大家更新不同的知识点。</p> <br> 新闻标题:HTML5地理位置与LBS应用开发的方法 <br> 路径分享:<a href="http://kswjz.com/article/gphhhs.html">http://kswjz.com/article/gphhhs.html</a> </div> <div class="view-qrocde cl"> <div class="m z"><img src="/Public/Home/images/ew.jpg"/></div> <div class="text"> <h6>扫二维码与项目经理沟通</h6> <p>我们在微信上24小时期待你的声音</p> <p>解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流</p> </div> </div> <div class="othernews cl"> <h3>其他资讯</h3> <ul> <li><a href="/article/dophhdd.html">张朝阳谈智能聊天风口 张朝阳手下走出的ceo</a></li><li><a href="/article/dophpgs.html">php将数据转换成字符串 php字符集转换</a></li><li><a href="/article/dophhos.html">服务器ie安全选项灰色 ie安全性设置</a></li><li><a href="/article/dophhcc.html">帝国cms互动 帝国cms演示</a></li><li><a href="/article/dophpih.html">c语言程序库函数 c语言函数库的主要功能是什么</a></li> </ul> </div> </div> </div> <div class="sidebar"> <div class="tuijian"> <a href="#"> <h2 class="cl"><span>行业动态</span></h2> <h3>企业网站建设的重要性!</h3> <p>现在虽然是移动互联网时代,但企业网站依然重要,包含PC站点,移动站。可以说企业网站关系企业的未来发展和前途,尤其对中小企业更是如此,一些中小企业老板,对自己的名片很在乎,因为这是个门面。...</p> </a> </div> <div class="ser sidesub"> <h2>服务项目</h2> <ul class="ebox"> <li class="sub sub-1"> <div> <h3>网站建设</h3> <p></p> <a class="btn" href="/serve/website/">查看详情</a> </div> </li> <li class="sub sub-1"> <div> <h3>移动端/APP</h3> <p></p> <a class="btn" href="/serve/moblie/">查看详情</a> </div> </li> <li class="sub sub-1"> <div> <h3>微信/小程序</h3> <p></p> <a class="btn" href="/serve/small/">查看详情</a> </div> </li> <li class="sub sub-1"> <div> <h3>技术支持</h3> <p></p> <a class="btn" href="/serve/tech/">查看详情</a> </div> </li> <li class="sub sub-1"> <div> <h3>其它服务</h3> <p></p> <a class="btn" href="/serve/othe/">查看详情</a> </div> </li> <li class="sub sub-5"> <div> <h3>更多服务项目</h3> <p> <a>用我们的专业和诚信赢得您的信赖,从PC到移动互联网均有您想要的服务!</a></p> <a class="btn" href="/serve/">获取更多</a> </div> </li> </ul> </div> <div class="contact" id="fix"> <h2 class="cl"> <span>联系吧</span> <a href="https://map.baidu.com/" class="ditu" rel="nofollow" target="_blank">在百度地图上找到我们</a> </h2> <h3>电话:13518219792</h3> <p>如遇占线或暂未接听请拨:136xxx98888</p> <div class="qq"> <a href="//wpa.qq.com/msgrd?v=3&uin=244261566&site=qq&menu=yes" rel="nofollow" target="_blank">业务咨询</a> <a href="//wpa.qq.com/msgrd?v=3&uin=244261566&site=qq&menu=yes" rel="nofollow" target="_blank">技术咨询</a> <a href="//wpa.qq.com/msgrd?v=3&uin=244261566&site=qq&menu=yes" rel="nofollow" target="_blank">售后服务</a> </div> </div> </div> <script> //固定滚动 (function () { var oDiv = document.getElementById("fix"); var H = 120, iE6; var Y = oDiv; while (Y) { H += Y.offsetTop; Y = Y.offsetParent }; iE6 = window.ActiveXObject && !window.XMLHttpRequest; if (!iE6) { window.onscroll = function () { var s = document.body.scrollTop || document.documentElement.scrollTop; if (s > H) { oDiv.className = "contact fixed"; if (iE6) { oDiv.style.top = (s - H) + "px"; } } else { oDiv.className = "contact "; } }; } })(); </script> </div> <div class="footer"> <div class="wp"> <div class="wpss cl"> <dl class="about"> <dt>网站设计</dt> <dd><a href="http://www.kswcd.cn/" target="_blank" title="成都网站设计">成都网站设计</a></dd><dd><a href="http://www.kswsj.com/" target="_blank" title="成都网站设计">成都网站设计</a></dd><dd><a href="http://www.kswcd.cn/serve/" target="_blank" title="高端网站设计">高端网站设计</a></dd><dd><a href="http://chengdu.kswjz.com/" target="_blank" title="成都网站设计">成都网站设计</a></dd> </dl> <dl class="about"> <dt>网站制作</dt> <dd><a href="http://chengdu.cdxwcx.cn/" target="_blank" title="成都网站制作">成都网站制作</a></dd><dd><a href="http://www.kswcd.com/mobile/" target="_blank" title="手机网站制作">手机网站制作</a></dd><dd><a href="https://www.cdcxhl.com/zhizuo/chengdu.html" target="_blank" title="四川成都网站制作">四川成都网站制作</a></dd><dd><a href="http://www.cdxwcx.cn/bj/" target="_blank" title="网站制作报价">网站制作报价</a></dd> </dl> <dl class="contact"> <dt>联系我们</dt> <dd>电话:13518219792</dd> <dd>邮箱:631063699@qq.com</dd> <dd>地址:成都青羊区锦天国际1002号</dd> <dd>网址:www.kswjz.com</dd> </dl> <dl class="about" style="margin-left:50px;width:235px;"> <dt>网站建设</dt> <dd><a href="https://www.cdxwcx.com/city/neijiang/" target="_blank" title="内江网站建设">内江网站建设</a></dd><dd><a href="https://www.cdxwcx.com/" target="_blank" title="成都网站建设公司">成都网站建设公司</a></dd><dd><a href="https://www.cdcxhl.com/" target="_blank" title="网站建设公司">网站建设公司</a></dd><dd><a href="http://www.cxhljz.cn/" target="_blank" title="成都网站建设">成都网站建设</a></dd> </dl> <dl class="flow"> <dt></dt> <div class="ma cl"> <div class="m"> <img src="/Public/Home/images/ew.jpg" /> <p>微信二维码</p> </div> </div> </dl> </div> </div> <div class="footer-link wp"> <ul class="wpss cl"> <li class="fisrt">友情链接</li> <li><a href="http://www.dywzjz.com/" title="大英泰恒网站" target="_blank">大英泰恒网站</a></li><li><a href="https://www.cdcxhl.com/sheji/chengdu.html" title="四川成都网站设计" target="_blank">四川成都网站设计</a></li><li><a href="http://www.cdxwcx.cn/tuoguan/neijiang.html" title="内江托管服务器" target="_blank">内江托管服务器</a></li><li><a href="https://www.cdxwcx.com/wangzhan/gaiban.html" title="网页改版" target="_blank">网页改版</a></li><li><a href="http://seo.cdcxhl.cn/" title="成都网站推广" target="_blank">成都网站推广</a></li><li><a href="http://www.kswsj.cn/" title="全网营销网站推广" target="_blank">全网营销网站推广</a></li><li><a href="http://www.nzjike.com/" title="一带一路" target="_blank">一带一路</a></li><li><a href="http://www.sczitong.com/" title="彩乐斯" target="_blank">彩乐斯</a></li><li><a href="http://www.kswcd.com/" title="企业网站设计" target="_blank">企业网站设计</a></li><li><a href="http://www.cdkjz.cn/wangzhan/waimao/" title="成都外贸网站建设" target="_blank">成都外贸网站建设</a></li> </ul> </div> </div> <div class="bot-footer"> <div class="wp"> <p class="wpss"> <em>Copyright © 2002-2023 www.kswjz.com 快上网建站品牌 QQ:244261566 版权所有</em> <em>备案号:<a href="http://beian.miit.gov.cn/" rel="external nofollow">蜀ICP备19037934号</a></em> </p> <p class="wpss" style="line-height:30px !important;"> </p> </div> </div> <div class="footer-kefu"> <ul> <li class="qq"><a href="https://wpa.qq.com/msgrd?v=3&uin=244261566&site=qq&menu=yes"><em></em>在线咨询</a> </li> <li class="tel"><a href="tel:13518219792" target="_blank"><em></em>13518219792</a></li> <li class="wx"> <em></em> <div class="code"> <img src="/Public/Home/images/ew.jpg" /> <p>微信二维码</p> </div> </li> <li class="m"> <em></em> <div class="code"> <img src="/Public/Home/images/ew.jpg" /> <p>移动版官网</p> </div> </li> <li class="top"><em></em></li> </ul> </div> <script src="/Public/Home/js/all.js"></script> </body> </html> <script> $(".cont img").each(function(){ var src = $(this).attr("src"); //获取图片地址 var str=new RegExp("http"); var result=str.test(src); if(result==false){ var url = "https://www.cdcxhl.com"+src; //绝对路径 $(this).attr("src",url); } }); window.onload=function(){ document.oncontextmenu=function(){ return false; } } </script>