微信公众号获得城市及街道位置信息

  • 一 概念介绍
  • 二 js和java坐标转换工具库
  • 三 获得当前城市或经纬度对应的位置
  • 四 总结

一、 概念介绍

目前国内主要有以下三种坐标系:
1. WGS84:为一种大地坐标系,也是目前广泛使用的GPS全球卫星定位系统使用的坐标系,即国际标准经纬度坐标;
2. GCJ02:表示经过国测局加密的坐标;
3. BD09:为百度坐标系,其中bd09ll表示百度经纬度坐标,bd09mc表示百度墨卡托米制坐标(Web服务坐标);

二、 js和java坐标转换工具库

上面3种坐标可想到转换,而且百度地图毕境在国内是个大的地图内容提供商,所以获得其它坐标基本上都会把它转换成BD09百度坐标系。
js坐标转换库

var GPS = {PI : 3.14159265358979324,x_pi : 3.14159265358979324 * 3000.0 / 180.0,delta : function (lat, lon) {// Krasovsky 1940//// a = 6378245.0, 1/f = 298.3// b = a * (1 - f)// ee = (a^2 - b^2) / a^2;var a = 6378245.0; //  a: 卫星椭球坐标投影到平面地图坐标系的投影因子。var ee = 0.00669342162296594323; //  ee: 椭球的偏心率。var dLat = this.transformLat(lon - 105.0, lat - 35.0);var dLon = this.transformLon(lon - 105.0, lat - 35.0);var radLat = lat / 180.0 * this.PI;var magic = Math.sin(radLat);magic = 1 - ee * magic * magic;var sqrtMagic = Math.sqrt(magic);dLat = (dLat * 180.0) / ((a * (1 - ee)) / (magic * sqrtMagic) * this.PI);dLon = (dLon * 180.0) / (a / sqrtMagic * Math.cos(radLat) * this.PI);return {'lat': dLat, 'lon': dLon};},//WGS-84坐标系  转  GCJ-02坐标系gcj_encrypt : function (wgsLat, wgsLon) {if (this.outOfChina(wgsLat, wgsLon))return {'lat': wgsLat, 'lon': wgsLon};var d = this.delta(wgsLat, wgsLon);return {'lat' : wgsLat + d.lat,'lon' : wgsLon + d.lon};},//GCJ-02坐标系  转 WGS-84坐标系gcj_decrypt : function (gcjLat, gcjLon) {if (this.outOfChina(gcjLat, gcjLon))return {'lat': gcjLat, 'lon': gcjLon};var d = this.delta(gcjLat, gcjLon);return {'lat': gcjLat - d.lat, 'lon': gcjLon - d.lon};},//更精确的计算GCJ-02坐标系  转  WGS-84坐标系gcj_decrypt_exact : function (gcjLat, gcjLon) {var initDelta = 0.01;var threshold = 0.000000001;var dLat = initDelta, dLon = initDelta;var mLat = gcjLat - dLat, mLon = gcjLon - dLon;var pLat = gcjLat + dLat, pLon = gcjLon + dLon;var wgsLat, wgsLon, i = 0;while (1) {wgsLat = (mLat + pLat) / 2;wgsLon = (mLon + pLon) / 2;var tmp = this.gcj_encrypt(wgsLat, wgsLon)dLat = tmp.lat - gcjLat;dLon = tmp.lon - gcjLon;if ((Math.abs(dLat) < threshold) && (Math.abs(dLon) < threshold))break;if (dLat > 0) pLat = wgsLat; else mLat = wgsLat;if (dLon > 0) pLon = wgsLon; else mLon = wgsLon;if (++i > 10000) break;}//console.log(i);return {'lat': wgsLat, 'lon': wgsLon};},//GCJ-02坐标系  转  BD-09坐标系bd_encrypt : function (gcjLat, gcjLon) {var x = gcjLon, y = gcjLat;  var z = Math.sqrt(x * x + y * y) + 0.00002 * Math.sin(y * this.x_pi);  var theta = Math.atan2(y, x) + 0.000003 * Math.cos(x * this.x_pi);  bdLon = z * Math.cos(theta) + 0.0065;  bdLat = z * Math.sin(theta) + 0.006; return {'lat' : bdLat,'lon' : bdLon};},//BD-09坐标系  转  GCJ-02坐标系bd_decrypt : function (bdLat, bdLon) {var x = bdLon - 0.0065, y = bdLat - 0.006;  var z = Math.sqrt(x * x + y * y) - 0.00002 * Math.sin(y * this.x_pi);  var theta = Math.atan2(y, x) - 0.000003 * Math.cos(x * this.x_pi);  var gcjLon = z * Math.cos(theta);  var gcjLat = z * Math.sin(theta);return {'lat' : gcjLat, 'lon' : gcjLon};},//WGS-84坐标系  转   bd09mc百度墨卡托米制坐标//mercatorLat -> y mercatorLon -> xmercator_encrypt : function(wgsLat, wgsLon) {var x = wgsLon * 20037508.34 / 180.;var y = Math.log(Math.tan((90. + wgsLat) * this.PI / 360.)) / (this.PI / 180.);y = y * 20037508.34 / 180.;return {'lat' : y, 'lon' : x};/*if ((Math.abs(wgsLon) > 180 || Math.abs(wgsLat) > 90))return null;var x = 6378137.0 * wgsLon * 0.017453292519943295;var a = wgsLat * 0.017453292519943295;var y = 3189068.5 * Math.log((1.0 + Math.sin(a)) / (1.0 - Math.sin(a)));return {'lat' : y, 'lon' : x};//*/},// Web mercator to WGS-84//bd09mc百度墨卡托米制坐标   转   WGS-84坐标系// mercatorLat -> y mercatorLon -> xmercator_decrypt : function(mercatorLat, mercatorLon) {var x = mercatorLon / 20037508.34 * 180.;var y = mercatorLat / 20037508.34 * 180.;y = 180 / this.PI * (2 * Math.atan(Math.exp(y * this.PI / 180.)) - this.PI / 2);return {'lat' : y, 'lon' : x};/*if (Math.abs(mercatorLon) < 180 && Math.abs(mercatorLat) < 90)return null;if ((Math.abs(mercatorLon) > 20037508.3427892) || (Math.abs(mercatorLat) > 20037508.3427892))return null;var a = mercatorLon / 6378137.0 * 57.295779513082323;var x = a - (Math.floor(((a + 180.0) / 360.0)) * 360.0);var y = (1.5707963267948966 - (2.0 * Math.atan(Math.exp((-1.0 * mercatorLat) / 6378137.0)))) * 57.295779513082323;return {'lat' : y, 'lon' : x};//*/},// 计算2个经纬间距离distance : function (latA, lonA, latB, lonB) {var earthR = 6371000.;var x = Math.cos(latA * this.PI / 180.) * Math.cos(latB * this.PI / 180.) * Math.cos((lonA - lonB) * this.PI / 180);var y = Math.sin(latA * this.PI / 180.) * Math.sin(latB * this.PI / 180.);var s = x + y;if (s > 1) s = 1;if (s < -1) s = -1;var alpha = Math.acos(s);var distance = alpha * earthR;return distance;},//确定坐标是国外还是国内outOfChina : function (lat, lon) {if (lon < 72.004 || lon > 137.8347)return true;if (lat < 0.8293 || lat > 55.8271)return true;return false;},transformLat : function (x, y) {var ret = -100.0 + 2.0 * x + 3.0 * y + 0.2 * y * y + 0.1 * x * y + 0.2 * Math.sqrt(Math.abs(x));ret += (20.0 * Math.sin(6.0 * x * this.PI) + 20.0 * Math.sin(2.0 * x * this.PI)) * 2.0 / 3.0;ret += (20.0 * Math.sin(y * this.PI) + 40.0 * Math.sin(y / 3.0 * this.PI)) * 2.0 / 3.0;ret += (160.0 * Math.sin(y / 12.0 * this.PI) + 320 * Math.sin(y * this.PI / 30.0)) * 2.0 / 3.0;return ret;},transformLon : function (x, y) {var ret = 300.0 + x + 2.0 * y + 0.1 * x * x + 0.1 * x * y + 0.1 * Math.sqrt(Math.abs(x));ret += (20.0 * Math.sin(6.0 * x * this.PI) + 20.0 * Math.sin(2.0 * x * this.PI)) * 2.0 / 3.0;ret += (20.0 * Math.sin(x * this.PI) + 40.0 * Math.sin(x / 3.0 * this.PI)) * 2.0 / 3.0;ret += (150.0 * Math.sin(x / 12.0 * this.PI) + 300.0 * Math.sin(x / 30.0 * this.PI)) * 2.0 / 3.0;return ret;}
};

java坐标转换库
PositionUtil.java:


package yui.comn.util;import yui.comn.model.Gps;/*** 各地图API坐标系统比较与转换;* WGS84坐标系:即地球坐标系,国际上通用的坐标系。设备一般包含GPS芯片或者北斗芯片获取的经纬度为WGS84地理坐标系,* 谷歌地图采用的是WGS84地理坐标系(中国范围除外);* GCJ02坐标系:即火星坐标系,是由中国国家测绘局制订的地理信息系统的坐标系统。由WGS84坐标系经加密后的坐标系。* 谷歌中国地图和搜搜中国地图采用的是GCJ02地理坐标系; BD09坐标系:即百度坐标系,GCJ02坐标系经加密后的坐标系;* 搜狗坐标系、图吧坐标系等,估计也是在GCJ02基础上加密而成的。 * @author Henry* */
public class PositionUtil {public static final String BAIDU_LBS_TYPE = "bd09ll";public static double pi = 3.1415926535897932384626;public static double a = 6378245.0;public static double ee = 0.00669342162296594323;/*** 84 to 火星坐标系 (GCJ-02) World Geodetic System ==> Mars Geodetic System* * @param lat* @param lon* @return*/public static Gps gps84_To_Gcj02(double lat, double lon) {if (outOfChina(lat, lon)) {return null;}double dLat = transformLat(lon - 105.0, lat - 35.0);double dLon = transformLon(lon - 105.0, lat - 35.0);double radLat = lat / 180.0 * pi;double magic = Math.sin(radLat);magic = 1 - ee * magic * magic;double sqrtMagic = Math.sqrt(magic);dLat = (dLat * 180.0) / ((a * (1 - ee)) / (magic * sqrtMagic) * pi);dLon = (dLon * 180.0) / (a / sqrtMagic * Math.cos(radLat) * pi);double mgLat = lat + dLat;double mgLon = lon + dLon;return new Gps(mgLat, mgLon);}/*** * 火星坐标系 (GCJ-02) to 84 * * @param lon * @param lat * @return* */public static Gps gcj_To_Gps84(double lat, double lon) {Gps gps = transform(lat, lon);double lontitude = lon * 2 - gps.getWgLon();double latitude = lat * 2 - gps.getWgLat();return new Gps(latitude, lontitude);}/*** 火星坐标系 (GCJ-02) 与百度坐标系 (BD-09) 的转换算法 将 GCJ-02 坐标转换成 BD-09 坐标* * @param gg_lat* @param gg_lon*/public static Gps gcj02_To_Bd09(double gg_lat, double gg_lon) {double x = gg_lon, y = gg_lat;double z = Math.sqrt(x * x + y * y) + 0.00002 * Math.sin(y * pi);double theta = Math.atan2(y, x) + 0.000003 * Math.cos(x * pi);double bd_lon = z * Math.cos(theta) + 0.0065;double bd_lat = z * Math.sin(theta) + 0.006;return new Gps(bd_lat, bd_lon);}/*** * 火星坐标系 (GCJ-02) 与百度坐标系 (BD-09) 的转换算法 * * 将 BD-09 坐标转换成GCJ-02 坐标 * * @param* bd_lat * @param bd_lon * @return*/public static Gps bd09_To_Gcj02(double bd_lat, double bd_lon) {double x = bd_lon - 0.0065, y = bd_lat - 0.006;double z = Math.sqrt(x * x + y * y) - 0.00002 * Math.sin(y * pi);double theta = Math.atan2(y, x) - 0.000003 * Math.cos(x * pi);double gg_lon = z * Math.cos(theta);double gg_lat = z * Math.sin(theta);return new Gps(gg_lat, gg_lon);}/*** (BD-09)-->84* @param bd_lat* @param bd_lon* @return*/public static Gps bd09_To_Gps84(double bd_lat, double bd_lon) {Gps gcj02 = PositionUtil.bd09_To_Gcj02(bd_lat, bd_lon);Gps map84 = PositionUtil.gcj_To_Gps84(gcj02.getWgLat(),gcj02.getWgLon());return map84;}/*** 将84 坐标转换成 BD-09 坐标* @param bd_lat* @param bd_lon* @return*/public static Gps gps84_To_Bd09(double lat, double lon) {Gps gps = gps84_To_Gcj02(lat,lon);return   gcj02_To_Bd09(gps.getWgLat(),gps.getWgLon());}public static boolean outOfChina(double lat, double lon) {if (lon < 72.004 || lon > 137.8347)return true;if (lat < 0.8293 || lat > 55.8271)return true;return false;}public static Gps transform(double lat, double lon) {if (outOfChina(lat, lon)) {return new Gps(lat, lon);}double dLat = transformLat(lon - 105.0, lat - 35.0);double dLon = transformLon(lon - 105.0, lat - 35.0);double radLat = lat / 180.0 * pi;double magic = Math.sin(radLat);magic = 1 - ee * magic * magic;double sqrtMagic = Math.sqrt(magic);dLat = (dLat * 180.0) / ((a * (1 - ee)) / (magic * sqrtMagic) * pi);dLon = (dLon * 180.0) / (a / sqrtMagic * Math.cos(radLat) * pi);double mgLat = lat + dLat;double mgLon = lon + dLon;return new Gps(mgLat, mgLon);}public static double transformLat(double x, double y) {double ret = -100.0 + 2.0 * x + 3.0 * y + 0.2 * y * y + 0.1 * x * y+ 0.2 * Math.sqrt(Math.abs(x));ret += (20.0 * Math.sin(6.0 * x * pi) + 20.0 * Math.sin(2.0 * x * pi)) * 2.0 / 3.0;ret += (20.0 * Math.sin(y * pi) + 40.0 * Math.sin(y / 3.0 * pi)) * 2.0 / 3.0;ret += (160.0 * Math.sin(y / 12.0 * pi) + 320 * Math.sin(y * pi / 30.0)) * 2.0 / 3.0;return ret;}public static double transformLon(double x, double y) {double ret = 300.0 + x + 2.0 * y + 0.1 * x * x + 0.1 * x * y + 0.1* Math.sqrt(Math.abs(x));ret += (20.0 * Math.sin(6.0 * x * pi) + 20.0 * Math.sin(2.0 * x * pi)) * 2.0 / 3.0;ret += (20.0 * Math.sin(x * pi) + 40.0 * Math.sin(x / 3.0 * pi)) * 2.0 / 3.0;ret += (150.0 * Math.sin(x / 12.0 * pi) + 300.0 * Math.sin(x / 30.0* pi)) * 2.0 / 3.0;return ret;}public static void main(String[] args) {// 北斗芯片获取的经纬度为WGS84地理坐标 31.426896,119.496145Gps gps = new Gps(31.426896, 119.496145);System.out.println("gps :" + gps);Gps gcj = gps84_To_Gcj02(gps.getWgLat(), gps.getWgLon());System.out.println("gcj :" + gcj);Gps star = gcj_To_Gps84(gcj.getWgLat(), gcj.getWgLon());System.out.println("star:" + star);Gps bd = gcj02_To_Bd09(gcj.getWgLat(), gcj.getWgLon());System.out.println("bd  :" + bd);Gps gcj2 = bd09_To_Gcj02(bd.getWgLat(), bd.getWgLon());System.out.println("gcj :" + gcj2);}
}

Gps.java

package yui.comn.model;public class Gps {private double wgLat;private double wgLon;public Gps(double wgLat, double wgLon) {setWgLat(wgLat);setWgLon(wgLon);}public double getWgLat() {return wgLat;}public void setWgLat(double wgLat) {this.wgLat = wgLat;}public double getWgLon() {return wgLon;}public void setWgLon(double wgLon) {this.wgLon = wgLon;}@Overridepublic String toString() {return wgLat + "," + wgLon;}
}

三、 获得当前城市或经纬度对应的位置

参照《微信接入js-sdk-获取地理位置,打开微信内置地图》设置微信公众号获得地理位置服务及配置。这里使用百度js_api将获得经纬度转成百度坐标,再用百度api查询到位置信息。

我自己总结的微信位置方法库WeiXinConfig.js:

document.write("<script src='http://res.wx.qq.com/open/js/jweixin-1.2.0.js'></script>");
function WeiXinConfig(){}
//有引入Common.js
//1.basePath路径
//2./weixin/getJsTicket后台有服务//微信关闭渡口
WeiXinConfig.closeBridge = function() {WeixinJSBridge.call('closeWindow');
}//分享给朋友
WeiXinConfig.onMenuShareAppMessage=function(title,desc,link,imgUrl,successCB,cancelCB){wx.onMenuShareAppMessage({title: title, // 分享标题desc: desc, // 分享描述link: link, // 分享链接,该链接域名或路径必须与当前页面对应的公众号JS安全域名一致imgUrl:imgUrl,success: function(){if(successCB){successCB.call(this);}},cancel: function(){if(cancelCB){cancelCB.call(this);}}});
}//分享给朋友圈
WeiXinConfig.onMenuShareTimeline=function(title,desc,link,imgUrl,successCB,cancelCB){wx.onMenuShareTimeline({title: title, // 分享标题desc: desc, // 分享描述link: link, // 分享链接,该链接域名或路径必须与当前页面对应的公众号JS安全域名一致imgUrl:imgUrl,success: function(){if(successCB){successCB.call(this);}},cancel: function(){if(cancelCB){cancelCB.call(this);}}});
}//配置
WeiXinConfig.config = function() {var thisPageUrl = location.href.split('#')[0];var json = {url : thisPageUrl};
//  Common.getRemote({url:basePath + "/weixin/getJsTicket",data:json,success:function(data){//      if (data != null) {//          configWeiXin(data.appId, data.timestamp, data.nonceStr,
//                  data.signature);
//      } else {//          console.log("配置weixin jsapi失败");
//      }
//  },error:function(data){//      console.log("配置请求错误");
//  }})$.get({url:basePath + "/weixin/getJsTicket",data:json,success:function(data){if (data != null) {configWeiXin(data.appId, data.timestamp, data.nonceStr,data.signature);} else {console.log("配置weixin jsapi失败");}},error:function(data){console.log("配置请求错误");}})
}function configWeiXin(appId, timestamp, nonceStr, signature) {wx.config({debug : false,// 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。appId : appId,timestamp : timestamp,nonceStr : nonceStr,signature : signature,jsApiList : [ 'chooseImage', 'uploadImage', 'downloadImage','previewImage', 'openLocation', 'getLocation','scanQRCode', 'checkJsApi', 'onMenuShareTimeline','onMenuShareAppMessage', 'onMenuShareQQ','onMenuShareWeibo', 'onMenuShareQZone' ]});
}var successCBack;
var errorCBack;/**支付*/
WeiXinConfig.prePayFor=function(jsonData, success, error){successCBack = success;errorCBack = error;doPrePayFor(jsonData);
}//立即支付
function doPrePayFor(jsonData) {$.ajax({type: "GET",url: basePath + "/bss/pay/ordPrePay",xhrFields: {withCredentials: true},data: jsonData,contentType: "application/x-www-form-urlencoded",dataType: "json",async: true,success: function (data) {doBridgeReady(data);},error: function (res) {console.log("ajax请求失败11,res:" + JSON.stringify(res));}});
}function doBridgeReady(data){if (typeof WeixinJSBridge == "undefined"){if( document.addEventListener ){document.addEventListener('WeixinJSBridgeReady', onBridgeReady, false);}else if (document.attachEvent){document.attachEvent('WeixinJSBridgeReady', onBridgeReady); document.attachEvent('onWeixinJSBridgeReady', onBridgeReady);}}else{onBridgeReady(data);}
}function onBridgeReady(data) {WeixinJSBridge.invoke('getBrandWCPayRequest', {"appId" : data.appId, /* 微信支付,坑一 冒号是中文字符 */
//      "appId" : data.appId, // 公众号名称,由商户传入"timeStamp" : data.timeStamp, // 时间戳,自1970年以来的秒数"nonceStr" : data.nonceStr, // 随机串"package" : data.package,"signType" : data.signType, // 微信签名方式:"paySign" : data.paySign// 微信签名}, function(res) {console.log(res);if (res.err_msg == "get_brand_wcpay_request:ok") {if(successCBack){successCBack.call(this);}} else {layerTip("支付失败");if(errorCBack){errorCBack.call(this);}}});
}WeiXinConfig.codeScan=function(success){wx.scanQRCode({needResult: 1, // 默认为0,扫描结果由微信处理,1则直接返回扫描结果,scanType: ["qrCode","barCode"], // 可以指定扫二维码还是一维码,默认二者都有success: function (res) {var result = res.resultStr; // 当needResult 为 1 时,扫码返回的结果if(success){success.call(this, result);}}});
}function alertMessage(text) {layer.open({content : text,skin : 'msg',time : 4});
}function layerTip(msg, success){layer.open({type: 1,className: '',content: '<div class="m-window"> <h2>提示信息<span class="j-close"></span></h2> <h4>'+msg+'</h4> <p><a class="j-true" href="javascript:;" style="width: 100%;border: none">确定</a></p> </div>',style: 'border-radius:8px',success:function(){$('.j-close,.j-true').click(function(){layer.closeAll();if(success){success.call(this);}});}});
};

其中basePath是

<script type="text/javascript">var basePath = "${pageContext.request.contextPath}";
</script>

我要使用的html或jsp代码里引入WeiXinConfig.js和Gps.js:

<script src="${pageContext.request.contextPath}/static/common/WeiXinConfig.js"></script>
<script src="${pageContext.request.contextPath}/static/common/Gps.js"></script>
<script src="http://api.map.baidu.com/api?v=2.0&ak=你自己的AK"></script>

获得位置经纬度信息并转换成城市道理信息方法如下:

 WeiXinConfig.config();wx.ready(function(){getLocation();});function getLocation() {wx.getLocation({type : 'gcj02', // 默认为wgs84的gps坐标,如果要返回直接给openLocation用的火星坐标,可传入'gcj02'success : function(res) {wgs84_lng = res.longitude;wgs84_lat = res.latitude;baiduLocation(res.longitude, res.latitude);},cancel : function(res) {}});}function baiduLocation(longitude, latitude){var json = GPS.bd_encrypt(latitude, longitude);console.log("json" + JSON.stringify(json));var myGeo = new BMap.Geocoder();// 根据坐标得到地址描述myGeo.getLocation(new BMap.Point(json.lon, json.lat), function(result){if (result){Tip.layerTip("您当前的位置:" + result.address);
//              alert(JSON.stringify(result));}});}

结果如下:

其实最重要的方法是:


function baiduLocation(longitude, latitude){var json = GPS.bd_encrypt(latitude, longitude);console.log("json" + JSON.stringify(json));var myGeo = new BMap.Geocoder();// 根据坐标得到地址描述myGeo.getLocation(new BMap.Point(json.lon, json.lat), function(result){if (result){Tip.layerTip("您当前的位置:" + result.address);
//              alert(JSON.stringify(result));}});}

将经纬度通过百度js_api转换成城市道理信息。

能够将地址信息转换为地理坐标点信息。
根据地址描述获得坐标
百度地图API提供Geocoder类进行地址解析,您可以通过Geocoder.getPoint()方法来将一段地址描述转换为一个坐标。在下面的示例中,我们将获得地址“北京市海淀区上地10街10号”的地理坐标位置,并在这个位置上添加一个标注。注意在调用Geocoder.getPoint()方法时您需要提供地址解析所在的城市(本例为“北京市”)。
var map = new BMap.Map(“l-map”);
map.centerAndZoom(new BMap.Point(116.404, 39.915), 11);
// 创建地址解析器实例
var myGeo = new BMap.Geocoder();
// 将地址解析结果显示在地图上,并调整地图视野
myGeo.getPoint(“北京市海淀区上地10街10号”, function(point){
if (point) {
map.centerAndZoom(point, 16);
map.addOverlay(new BMap.Marker(point));
}
}, “北京市”);
反向地理编码
反向地理编码的过程正好相反,它根据一个坐标点得到一个地址的描述。您可以通过Geocoder.getLocation()方法获得地址描述。当解析工作完成后,您提供的回调函数将会被触发。如果解析成功,则回调函数的参数为GeocoderResult对象,否则为null。
var map = new BMap.Map(“l-map”);
map.centerAndZoom(new BMap.Point(116.404, 39.915), 11);
// 创建地理编码实例
var myGeo = new BMap.Geocoder();
// 根据坐标得到地址描述
myGeo.getLocation(new BMap.Point(116.364, 39.993), function(result){
if (result){
alert(result.address);
}
});

四、 总结

上面仅仅提供了经纬度与城市道理位置转换的简单例子,上面经度度转换的方法可以放在任何地方使用,不一定非要在微信公众号里使用。
想获得更多百度坐标服务还是建议上百度官方提供的api上学习
百度JavaScript API

微信公众号获得城市及街道位置信息相关推荐

  1. 怎样实现微信公众号点击菜单自动回复文字信息

    为了满足微信公众号点击菜单自动回复文字信息的需要,第三方平台微号帮提供了粉丝点菜单定时推送功能实现,粉丝点击公众号菜单栏可以自动回复文字信息,可以更改回复信息的昵称和头像,回复信息内容可以显示粉丝昵称 ...

  2. 微信公众号网页授权,获取用户信息以及openid -- PHP后台

    微信公众号网页授权,获取用户信息以及openid 这几天做项目,想通过公众号的appid获取用户的openid就,然后在网上查资料,问朋友,最后找到了方法,就是这个网页授权. 起初一直很蒙,这个怎么弄 ...

  3. 微信公众号开发--获取当前用户位置,并把经度纬度转化成省市县

    这里主要写的是获取当前用户的地理位置,调用微信接口,成功之后会返回经纬度,这里我们把它转化成了省市县方便调用 主逻辑函数 // 这个要在<head>里面引入 <script src= ...

  4. 微信公众号开发之授权获取用户信息

    微信开发交流群:148540125 系列文章参考地址 极速开发微信公众号 欢迎留言.转发.打赏 项目源码参考地址 点我点我--欢迎Start 前几篇文章已讲完如何导入项目,如何启动配置项目,如何成为开 ...

  5. python微信点赞脚本_Python爬取微信公众号评论、点赞等相关信息

    微信公众号爬虫方案分析(爬取文艺相处公众号) 之前考虑过使用搜狗微信来爬取微信公众号信息,不过搜狗提供的数据有诸多弊端,比如文章链接是临时的,文章没有阅读量等指标,所以考虑通过手机客户端利用 Pyth ...

  6. 微信公众号授权登录,获取用户信息openid(亲测有效)

    需求:客户登录微信公众号进行账号注册,绑定微信openid,下次根据openid验证自动登录. 详细代码:https://download.csdn.net/download/yaya_jn/7492 ...

  7. 微信公众号留言评论功能最新开通信息讲解(内附留言功能开通视频信息讲解链接)...

    腾讯针对公众号留言这一功能经过多次调整,下面为大家详细讲讲其规则,最开始的时候只要长期坚持发原创文章,等拿到腾讯的原创保护邀请后,就可以拥有留言这个功能了,邀请如下图所示: 接下来大概是2017年年底 ...

  8. 微信公众号--根据用户opneId获取用户信息

    一.登录微信公众号的测试环境,找到"网页授权获取用户基本信息"点击修改,添加上自己的回调地址域名.测试时可以写IP:端口号,正式环境只支持域名不要写http://或https:// ...

  9. php微信公众号向指定客服发信息,微信公众号给用户发送一条消息 客服消息

    可以用客服消息接口或模板消息接口实现.但是需要认证公众号才能有权限. 认证服务号可以发送客服接口消息[需要对应openid24小时内有互动]和模板消息,订阅号则没有模板消息权限. 下面是发送客服消息的 ...

  10. 微信公众号添加关注后自动回复图文信息(素材)

    公众号在被添加关注后其实不仅可以回复单纯的文字,还有一个效果更好的方式是直接回复图文,在图文信息中传达你的感谢和说明一些公众号的情况.那么微信公众号添加关注后怎么自动回复图文信息?下面小编就为大家介绍 ...

最新文章

  1. 某网友认为程序员来钱太快!动不动就百万年薪!国内多数人工作一辈子也拿不到百万年薪!程序员:别总盯着行业头部少数人!...
  2. “Hello World!”团队第二次会议
  3. java.util.Date和java.sql.Date之间的相互转换
  4. 一起谈.NET技术,异步调用与多线程的区别
  5. 「云」发展的怎么样了?
  6. 汇编语言:实验8分析一个奇怪的程序
  7. 线性回归 php,PHP实现简单线性回归之数学库的重要性
  8. 实施ERP过程中必须注意的“后天条件”
  9. 【详细图文教程】Anaconda的下载及安装
  10. web前端课程架构梳理
  11. 黑苹果双系统时间不一致_黑苹果系统与windows时间差问题的解决
  12. 数据结构笔记【全-408统考】【附思维导图】
  13. 华为OD机试(JAVA)真题22版
  14. mysql 分库分表实战_DBLE分库分表实战
  15. Base64自定义编码表及破解
  16. 罗技鼠标M330拆解
  17. 面试系列-1 大厂面试幂等性
  18. 秦汉考场科目三路线图_秦汉科目三考场考试攻略,附考场路线图
  19. 7-2 寻找大富翁 (25 分)
  20. html/css 钢琴黑白格布局

热门文章

  1. 如何用matlab建立风力机模型,风力机的Matlab模型及其应用
  2. Javascript es6 在线编辑器
  3. Java-Aspose实现上传Excel、Word转换为PDF并进行下载
  4. java 类的加载机制详解
  5. Clang checker类总结
  6. mysql的数据库实例名是啥_数据库名、数据库实例名与数据库域名
  7. [ Keil ] keil4工程转keil5方法
  8. xLua(一)——介绍
  9. uVision2项目实践:HelloWorld
  10. 文本自动校对技术研究综述