zoukankan      html  css  js  c++  java
  • H5结合百度map实现GPS定位

    前言

         目前我们做m端时都会用到定位,当用户第一次打开h5页面时会启动gps定位,并结合百度map来查找城市。按照我们的逻辑思路就是gps定位获取经纬度,传到后台调用百度的一个接口查找城市名称。

         1、查询得到城市名称,我们根据城市名称在我们自己的数据库里再查询对应的城市id(查询会很频繁,可以基于xml 缓存查询,也可以放到redis里)

         2、为了保险起见,我们也会在自己的库里根据经纬度维护一套城市信息,防止接口不可用时不影响定位。

    H5 GPS定位

     1  (function () {
     2         var
     3             isGeolocation = false,
     4             lat = 0,
     5             lng = 0,
     6             coords = null;
     7             
     8         if (navigator.geolocation) { isGeolocation = true; };
     9         if (isGeolocation) {
    10             function getPosSuccess(position) {
    11                 coords = position.coords;
    12                 lat = coords.latitude, lng = coords.longitude;
    13                 $.ajax({
    14                     type: 'GET',
    15                     dataType: 'json',
    16                     url: '/Home/GetPositionArea',
    17                     data: { 'lat': lat, 'lng': lng },
    18                     success: function (data) {
    19 
    20                     }
    21                 });
    22             };
    23             function getPosError(err) {
    24                 switch (err) {
    25                     case err.PERMISSION_DENIED:
    26                         console.log("您拒绝了共享位置,可手动选择城市。");
    27                         break;
    28                     case err.POSITION_UNAVAILABLE:
    29                         console.log("无法获取当前位置");
    30                         break;
    31                     case err.TIMEOUT:
    32                         console.log("获取位置超时");
    33                         break;
    34                     default:
    35                         console.log("未知错误");
    36                         break;
    37                 }
    38                 
    39             };
    40             navigator.geolocation.getCurrentPosition(getPosSuccess, getPosError, null);
    41         } else {
    42             
    43         };
    44 
    45     })();

    结合百度接口查询具体城市


    public
    JsonResult GetPositionArea(decimal lng, decimal lat) { string api = string.Format( "http://api.map.baidu.com/geocoder/v2/?output=json&ak=XXXXX&location={0},{1}", lat, lng); //传入自己的业务参数ak string result = HttpRequestHelper.Get(api); return Json(result, JsonRequestBehavior.AllowGet); }
  • 相关阅读:
    在MyEclipse中运行tomcat报错 严重: Error starting static Resources
    MyEclipse 2015 运行tomcat 内存溢出的解决方法
    (转)Tomcat内存设置详解
    Object调用控件的办法
    Hibernate主键生成方式之hilo
    (转)“中国第一程序员” 求伯君的传奇经历
    雷军相识求伯君
    (转)雷军重掌金山幕后:与求伯君暗战三年两次逼宫
    华军软件发展及盈利模式
    中年人编程
  • 原文地址:https://www.cnblogs.com/sword-successful/p/6945588.html
Copyright © 2011-2022 走看看