河东区腾讯网站建设怎么做网站的内部链接

news/2025/9/24 2:19:45/文章来源:
河东区腾讯网站建设,怎么做网站的内部链接,seo怎么做整站排名,成都网站平面设计UniApp是一个跨平台的应用开发框架#xff0c;可以帮助开发者快速地在多个平台上构建应用程序。其中#xff0c;实现路线规划是一个常见的需求#xff0c;特别是对于地图类应用或者出行类应用来说#xff0c;路线规划功能是非常重要的。 首先引入QQMapWX#xff1b; impo…UniApp是一个跨平台的应用开发框架可以帮助开发者快速地在多个平台上构建应用程序。其中实现路线规划是一个常见的需求特别是对于地图类应用或者出行类应用来说路线规划功能是非常重要的。 首先引入QQMapWX import QQMapWX from /qqmap-wx-jssdk.js; 下面是完整文件qqmap-wx-jssdk.js /*** 微信小程序JavaScriptSDK* * version 1.2* date 2019-03-06*/var ERROR_CONF {KEY_ERR: 311,KEY_ERR_MSG: key格式错误,PARAM_ERR: 310,PARAM_ERR_MSG: 请求参数信息有误,SYSTEM_ERR: 600,SYSTEM_ERR_MSG: 系统错误,WX_ERR_CODE: 1000,WX_OK_CODE: 200 }; var BASE_URL https://apis.map.qq.com/ws/; var URL_SEARCH BASE_URL place/v1/search; var URL_SUGGESTION BASE_URL place/v1/suggestion; var URL_GET_GEOCODER BASE_URL geocoder/v1/; var URL_CITY_LIST BASE_URL district/v1/list; var URL_AREA_LIST BASE_URL district/v1/getchildren; var URL_DISTANCE BASE_URL distance/v1/; var URL_DIRECTION BASE_URL direction/v1/; var MODE {driving: driving,transit: transit }; var EARTH_RADIUS 6378136.49; var Utils {/*** md5加密方法* 版权所有©2011 Sebastian Tschanhttps//blueimp.net*/safeAdd(x, y) {var lsw (x 0xffff) (y 0xffff);var msw (x 16) (y 16) (lsw 16);return (msw 16) | (lsw 0xffff);},bitRotateLeft(num, cnt) {return (num cnt) | (num (32 - cnt));},md5cmn(q, a, b, x, s, t) {return this.safeAdd(this.bitRotateLeft(this.safeAdd(this.safeAdd(a, q), this.safeAdd(x, t)), s), b);},md5ff(a, b, c, d, x, s, t) {return this.md5cmn((b c) | (~b d), a, b, x, s, t);},md5gg(a, b, c, d, x, s, t) {return this.md5cmn((b d) | (c ~d), a, b, x, s, t);},md5hh(a, b, c, d, x, s, t) {return this.md5cmn(b ^ c ^ d, a, b, x, s, t);},md5ii(a, b, c, d, x, s, t) {return this.md5cmn(c ^ (b | ~d), a, b, x, s, t);},binlMD5(x, len) {/* append padding */x[len 5] | 0x80 (len % 32);x[((len 64) 9 4) 14] len;var i;var olda;var oldb;var oldc;var oldd;var a 1732584193;var b -271733879;var c -1732584194;var d 271733878;for (i 0; i x.length; i 16) {olda a;oldb b;oldc c;oldd d;a this.md5ff(a, b, c, d, x[i], 7, -680876936);d this.md5ff(d, a, b, c, x[i 1], 12, -389564586);c this.md5ff(c, d, a, b, x[i 2], 17, 606105819);b this.md5ff(b, c, d, a, x[i 3], 22, -1044525330);a this.md5ff(a, b, c, d, x[i 4], 7, -176418897);d this.md5ff(d, a, b, c, x[i 5], 12, 1200080426);c this.md5ff(c, d, a, b, x[i 6], 17, -1473231341);b this.md5ff(b, c, d, a, x[i 7], 22, -45705983);a this.md5ff(a, b, c, d, x[i 8], 7, 1770035416);d this.md5ff(d, a, b, c, x[i 9], 12, -1958414417);c this.md5ff(c, d, a, b, x[i 10], 17, -42063);b this.md5ff(b, c, d, a, x[i 11], 22, -1990404162);a this.md5ff(a, b, c, d, x[i 12], 7, 1804603682);d this.md5ff(d, a, b, c, x[i 13], 12, -40341101);c this.md5ff(c, d, a, b, x[i 14], 17, -1502002290);b this.md5ff(b, c, d, a, x[i 15], 22, 1236535329);a this.md5gg(a, b, c, d, x[i 1], 5, -165796510);d this.md5gg(d, a, b, c, x[i 6], 9, -1069501632);c this.md5gg(c, d, a, b, x[i 11], 14, 643717713);b this.md5gg(b, c, d, a, x[i], 20, -373897302);a this.md5gg(a, b, c, d, x[i 5], 5, -701558691);d this.md5gg(d, a, b, c, x[i 10], 9, 38016083);c this.md5gg(c, d, a, b, x[i 15], 14, -660478335);b this.md5gg(b, c, d, a, x[i 4], 20, -405537848);a this.md5gg(a, b, c, d, x[i 9], 5, 568446438);d this.md5gg(d, a, b, c, x[i 14], 9, -1019803690);c this.md5gg(c, d, a, b, x[i 3], 14, -187363961);b this.md5gg(b, c, d, a, x[i 8], 20, 1163531501);a this.md5gg(a, b, c, d, x[i 13], 5, -1444681467);d this.md5gg(d, a, b, c, x[i 2], 9, -51403784);c this.md5gg(c, d, a, b, x[i 7], 14, 1735328473);b this.md5gg(b, c, d, a, x[i 12], 20, -1926607734);a this.md5hh(a, b, c, d, x[i 5], 4, -378558);d this.md5hh(d, a, b, c, x[i 8], 11, -2022574463);c this.md5hh(c, d, a, b, x[i 11], 16, 1839030562);b this.md5hh(b, c, d, a, x[i 14], 23, -35309556);a this.md5hh(a, b, c, d, x[i 1], 4, -1530992060);d this.md5hh(d, a, b, c, x[i 4], 11, 1272893353);c this.md5hh(c, d, a, b, x[i 7], 16, -155497632);b this.md5hh(b, c, d, a, x[i 10], 23, -1094730640);a this.md5hh(a, b, c, d, x[i 13], 4, 681279174);d this.md5hh(d, a, b, c, x[i], 11, -358537222);c this.md5hh(c, d, a, b, x[i 3], 16, -722521979);b this.md5hh(b, c, d, a, x[i 6], 23, 76029189);a this.md5hh(a, b, c, d, x[i 9], 4, -640364487);d this.md5hh(d, a, b, c, x[i 12], 11, -421815835);c this.md5hh(c, d, a, b, x[i 15], 16, 530742520);b this.md5hh(b, c, d, a, x[i 2], 23, -995338651);a this.md5ii(a, b, c, d, x[i], 6, -198630844);d this.md5ii(d, a, b, c, x[i 7], 10, 1126891415);c this.md5ii(c, d, a, b, x[i 14], 15, -1416354905);b this.md5ii(b, c, d, a, x[i 5], 21, -57434055);a this.md5ii(a, b, c, d, x[i 12], 6, 1700485571);d this.md5ii(d, a, b, c, x[i 3], 10, -1894986606);c this.md5ii(c, d, a, b, x[i 10], 15, -1051523);b this.md5ii(b, c, d, a, x[i 1], 21, -2054922799);a this.md5ii(a, b, c, d, x[i 8], 6, 1873313359);d this.md5ii(d, a, b, c, x[i 15], 10, -30611744);c this.md5ii(c, d, a, b, x[i 6], 15, -1560198380);b this.md5ii(b, c, d, a, x[i 13], 21, 1309151649);a this.md5ii(a, b, c, d, x[i 4], 6, -145523070);d this.md5ii(d, a, b, c, x[i 11], 10, -1120210379);c this.md5ii(c, d, a, b, x[i 2], 15, 718787259);b this.md5ii(b, c, d, a, x[i 9], 21, -343485551);a this.safeAdd(a, olda);b this.safeAdd(b, oldb);c this.safeAdd(c, oldc);d this.safeAdd(d, oldd);}return [a, b, c, d];},binl2rstr(input) {var i;var output ;var length32 input.length * 32;for (i 0; i length32; i 8) {output String.fromCharCode((input[i 5] (i % 32)) 0xff);}return output;},rstr2binl(input) {var i;var output [];output[(input.length 2) - 1] undefined;for (i 0; i output.length; i 1) {output[i] 0;}var length8 input.length * 8;for (i 0; i length8; i 8) {output[i 5] | (input.charCodeAt(i / 8) 0xff) (i % 32);}return output;},rstrMD5(s) {return this.binl2rstr(this.binlMD5(this.rstr2binl(s), s.length * 8));},rstrHMACMD5(key, data) {var i;var bkey this.rstr2binl(key);var ipad [];var opad [];var hash;ipad[15] opad[15] undefined;if (bkey.length 16) {bkey this.binlMD5(bkey, key.length * 8);}for (i 0; i 16; i 1) {ipad[i] bkey[i] ^ 0x36363636;opad[i] bkey[i] ^ 0x5c5c5c5c;}hash this.binlMD5(ipad.concat(this.rstr2binl(data)), 512 data.length * 8);return this.binl2rstr(this.binlMD5(opad.concat(hash), 512 128));},rstr2hex(input) {var hexTab 0123456789abcdef;var output ;var x;var i;for (i 0; i input.length; i 1) {x input.charCodeAt(i);output hexTab.charAt((x 4) 0x0f) hexTab.charAt(x 0x0f);}return output;},str2rstrUTF8(input) {return unescape(encodeURIComponent(input));},rawMD5(s) {return this.rstrMD5(this.str2rstrUTF8(s));},hexMD5(s) {return this.rstr2hex(this.rawMD5(s));},rawHMACMD5(k, d) {return this.rstrHMACMD5(this.str2rstrUTF8(k), str2rstrUTF8(d));},hexHMACMD5(k, d) {return this.rstr2hex(this.rawHMACMD5(k, d));},md5(string, key, raw) {if (!key) {if (!raw) {return this.hexMD5(string);}return this.rawMD5(string);}if (!raw) {return this.hexHMACMD5(key, string);}return this.rawHMACMD5(key, string);},/*** 得到md5加密后的sig参数* param {Object} requestParam 接口参数* param {String} sk签名字符串* param {String} featrue 方法名* return 返回加密后的sig参数*/getSig(requestParam, sk, feature, mode) {var sig null;var requestArr [];Object.keys(requestParam).sort().forEach(function(key){requestArr.push(key requestParam[key]);});if (feature search) {sig /ws/place/v1/search? requestArr.join() sk;}if (feature suggest) {sig /ws/place/v1/suggestion? requestArr.join() sk;}if (feature reverseGeocoder) {sig /ws/geocoder/v1/? requestArr.join() sk;}if (feature geocoder) {sig /ws/geocoder/v1/? requestArr.join() sk;}if (feature getCityList) {sig /ws/district/v1/list? requestArr.join() sk;}if (feature getDistrictByCityId) {sig /ws/district/v1/getchildren? requestArr.join() sk;}if (feature calculateDistance) {sig /ws/distance/v1/? requestArr.join() sk;}if (feature direction) {sig /ws/direction/v1/ mode ? requestArr.join() sk;}sig this.md5(sig);return sig;},/*** 得到终点query字符串* param {Array|String} 检索数据*/location2query(data) {if (typeof data string) {return data;}var query ;for (var i 0; i data.length; i) {var d data[i];if (!!query) {query ;;}if (d.location) {query query d.location.lat , d.location.lng;}if (d.latitude d.longitude) {query query d.latitude , d.longitude;}}return query;},/*** 计算角度*/rad(d) {return d * Math.PI / 180.0;}, /*** 处理终点location数组* return 返回终点数组*/getEndLocation(location){var to location.split(;);var endLocation [];for (var i 0; i to.length; i) {endLocation.push({lat: parseFloat(to[i].split(,)[0]),lng: parseFloat(to[i].split(,)[1])})}return endLocation;},/*** 计算两点间直线距离* param a 表示纬度差* param b 表示经度差* return 返回的是距离单位m*/getDistance(latFrom, lngFrom, latTo, lngTo) {var radLatFrom this.rad(latFrom);var radLatTo this.rad(latTo);var a radLatFrom - radLatTo;var b this.rad(lngFrom) - this.rad(lngTo);var distance 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(a / 2), 2) Math.cos(radLatFrom) * Math.cos(radLatTo) * Math.pow(Math.sin(b / 2), 2)));distance distance * EARTH_RADIUS;distance Math.round(distance * 10000) / 10000;return parseFloat(distance.toFixed(0));},/*** 使用微信接口进行定位*/getWXLocation(success, fail, complete) {wx.getLocation({type: gcj02,success: success,fail: fail,complete: complete});},/*** 获取location参数*/getLocationParam(location) {if (typeof location string) {var locationArr location.split(,);if (locationArr.length 2) {location {latitude: location.split(,)[0],longitude: location.split(,)[1]};} else {location {};}}return location;},/*** 回调函数默认处理*/polyfillParam(param) {param.success param.success || function () { };param.fail param.fail || function () { };param.complete param.complete || function () { };},/*** 验证param对应的key值是否为空* * param {Object} param 接口参数* param {String} key 对应参数的key*/checkParamKeyEmpty(param, key) {if (!param[key]) {var errconf this.buildErrorConfig(ERROR_CONF.PARAM_ERR, ERROR_CONF.PARAM_ERR_MSG key 参数格式有误);param.fail(errconf);param.complete(errconf);return true;}return false;},/*** 验证参数中是否存在检索词keyword* * param {Object} param 接口参数*/checkKeyword(param){return !this.checkParamKeyEmpty(param, keyword);},/*** 验证location值* * param {Object} param 接口参数*/checkLocation(param) {var location this.getLocationParam(param.location);if (!location || !location.latitude || !location.longitude) {var errconf this.buildErrorConfig(ERROR_CONF.PARAM_ERR, ERROR_CONF.PARAM_ERR_MSG location参数格式有误);param.fail(errconf);param.complete(errconf);return false;}return true;},/*** 构造错误数据结构* param {Number} errCode 错误码* param {Number} errMsg 错误描述*/buildErrorConfig(errCode, errMsg) {return {status: errCode,message: errMsg};},/*** * 数据处理函数* 根据传入参数不同处理不同数据* param {String} feature 功能名称* search 地点搜索* suggest关键词提示* reverseGeocoder逆地址解析* geocoder地址解析* getCityList获取城市列表父集* getDistrictByCityId获取区县列表子集* calculateDistance距离计算* param {Object} param 接口参数* param {Object} data 数据*/handleData(param,data,feature){if (feature search) {var searchResult data.data;var searchSimplify [];for (var i 0; i searchResult.length; i) {searchSimplify.push({id: searchResult[i].id || null,title: searchResult[i].title || null,latitude: searchResult[i].location searchResult[i].location.lat || null,longitude: searchResult[i].location searchResult[i].location.lng || null,address: searchResult[i].address || null,category: searchResult[i].category || null,tel: searchResult[i].tel || null,adcode: searchResult[i].ad_info searchResult[i].ad_info.adcode || null,city: searchResult[i].ad_info searchResult[i].ad_info.city || null,district: searchResult[i].ad_info searchResult[i].ad_info.district || null,province: searchResult[i].ad_info searchResult[i].ad_info.province || null})}param.success(data, {searchResult: searchResult,searchSimplify: searchSimplify})} else if (feature suggest) {var suggestResult data.data;var suggestSimplify [];for (var i 0; i suggestResult.length; i) {suggestSimplify.push({adcode: suggestResult[i].adcode || null,address: suggestResult[i].address || null,category: suggestResult[i].category || null,city: suggestResult[i].city || null,district: suggestResult[i].district || null,id: suggestResult[i].id || null,latitude: suggestResult[i].location suggestResult[i].location.lat || null,longitude: suggestResult[i].location suggestResult[i].location.lng || null,province: suggestResult[i].province || null,title: suggestResult[i].title || null,type: suggestResult[i].type || null})}param.success(data, {suggestResult: suggestResult,suggestSimplify: suggestSimplify})} else if (feature reverseGeocoder) {var reverseGeocoderResult data.result;var reverseGeocoderSimplify {address: reverseGeocoderResult.address || null,latitude: reverseGeocoderResult.location reverseGeocoderResult.location.lat || null,longitude: reverseGeocoderResult.location reverseGeocoderResult.location.lng || null,adcode: reverseGeocoderResult.ad_info reverseGeocoderResult.ad_info.adcode || null,city: reverseGeocoderResult.address_component reverseGeocoderResult.address_component.city || null,district: reverseGeocoderResult.address_component reverseGeocoderResult.address_component.district || null,nation: reverseGeocoderResult.address_component reverseGeocoderResult.address_component.nation || null,province: reverseGeocoderResult.address_component reverseGeocoderResult.address_component.province || null,street: reverseGeocoderResult.address_component reverseGeocoderResult.address_component.street || null,street_number: reverseGeocoderResult.address_component reverseGeocoderResult.address_component.street_number || null,recommend: reverseGeocoderResult.formatted_addresses reverseGeocoderResult.formatted_addresses.recommend || null,rough: reverseGeocoderResult.formatted_addresses reverseGeocoderResult.formatted_addresses.rough || null};if (reverseGeocoderResult.pois) {//判断是否返回周边poivar pois reverseGeocoderResult.pois;var poisSimplify [];for (var i 0;i pois.length;i) {poisSimplify.push({id: pois[i].id || null,title: pois[i].title || null,latitude: pois[i].location pois[i].location.lat || null,longitude: pois[i].location pois[i].location.lng || null,address: pois[i].address || null,category: pois[i].category || null,adcode: pois[i].ad_info pois[i].ad_info.adcode || null,city: pois[i].ad_info pois[i].ad_info.city || null,district: pois[i].ad_info pois[i].ad_info.district || null,province: pois[i].ad_info pois[i].ad_info.province || null})}param.success(data,{reverseGeocoderResult: reverseGeocoderResult,reverseGeocoderSimplify: reverseGeocoderSimplify,pois: pois,poisSimplify: poisSimplify})} else {param.success(data, {reverseGeocoderResult: reverseGeocoderResult,reverseGeocoderSimplify: reverseGeocoderSimplify})}} else if (feature geocoder) {var geocoderResult data.result;var geocoderSimplify {title: geocoderResult.title || null,latitude: geocoderResult.location geocoderResult.location.lat || null,longitude: geocoderResult.location geocoderResult.location.lng || null,adcode: geocoderResult.ad_info geocoderResult.ad_info.adcode || null,province: geocoderResult.address_components geocoderResult.address_components.province || null,city: geocoderResult.address_components geocoderResult.address_components.city || null,district: geocoderResult.address_components geocoderResult.address_components.district || null,street: geocoderResult.address_components geocoderResult.address_components.street || null,street_number: geocoderResult.address_components geocoderResult.address_components.street_number || null,level: geocoderResult.level || null};param.success(data,{geocoderResult: geocoderResult,geocoderSimplify: geocoderSimplify});} else if (feature getCityList) {var provinceResult data.result[0];var cityResult data.result[1];var districtResult data.result[2];param.success(data,{provinceResult: provinceResult,cityResult: cityResult,districtResult: districtResult});} else if (feature getDistrictByCityId) {var districtByCity data.result[0];param.success(data, districtByCity);} else if (feature calculateDistance) {var calculateDistanceResult data.result.elements; var distance [];for (var i 0; i calculateDistanceResult.length; i){distance.push(calculateDistanceResult[i].distance);} param.success(data, {calculateDistanceResult: calculateDistanceResult,distance: distance});} else if (feature direction) {var direction data.result.routes;param.success(data,direction);} else {param.success(data);}},/*** 构造微信请求参数公共属性处理* * param {Object} param 接口参数* param {Object} param 配置项* param {String} feature 方法名*/buildWxRequestConfig(param, options, feature) {var that this;options.header { content-type: application/json };options.method GET;options.success function (res) {var data res.data;if (data.status 0) {that.handleData(param, data, feature);} else {param.fail(data);}};options.fail function (res) {res.statusCode ERROR_CONF.WX_ERR_CODE;param.fail(that.buildErrorConfig(ERROR_CONF.WX_ERR_CODE, res.errMsg));};options.complete function (res) {var statusCode res.statusCode;switch(statusCode) {case ERROR_CONF.WX_ERR_CODE: {param.complete(that.buildErrorConfig(ERROR_CONF.WX_ERR_CODE, res.errMsg));break;}case ERROR_CONF.WX_OK_CODE: {var data res.data;if (data.status 0) {param.complete(data);} else {param.complete(that.buildErrorConfig(data.status, data.message));}break;}default:{param.complete(that.buildErrorConfig(ERROR_CONF.SYSTEM_ERR, ERROR_CONF.SYSTEM_ERR_MSG));}}};return options;},/*** 处理用户参数是否传入坐标进行不同的处理*/locationProcess(param, locationsuccess, locationfail, locationcomplete) {var that this;locationfail locationfail || function (res) {res.statusCode ERROR_CONF.WX_ERR_CODE;param.fail(that.buildErrorConfig(ERROR_CONF.WX_ERR_CODE, res.errMsg));};locationcomplete locationcomplete || function (res) {if (res.statusCode ERROR_CONF.WX_ERR_CODE) {param.complete(that.buildErrorConfig(ERROR_CONF.WX_ERR_CODE, res.errMsg));}};if (!param.location) {that.getWXLocation(locationsuccess, locationfail, locationcomplete);} else if (that.checkLocation(param)) {var location Utils.getLocationParam(param.location);locationsuccess(location);}} };class QQMapWX {/*** 构造函数* * param {Object} options 接口参数,key 为必选参数*/constructor(options) {if (!options.key) {throw Error(key值不能为空);}this.key options.key;};/*** POI周边检索** param {Object} options 接口参数对象* * 参数对象结构可以参考* see http://lbs.qq.com/webservice_v1/guide-search.html*/search(options) {var that this;options options || {};Utils.polyfillParam(options);if (!Utils.checkKeyword(options)) {return;}var requestParam {keyword: options.keyword,orderby: options.orderby || _distance,page_size: options.page_size || 10,page_index: options.page_index || 1,output: json,key: that.key};if (options.address_format) {requestParam.address_format options.address_format;}if (options.filter) {requestParam.filter options.filter;}var distance options.distance || 1000;var auto_extend options.auto_extend || 1;var region null;var rectangle null;//判断城市限定参数if (options.region) {region options.region;}//矩形限定坐标(暂时只支持字符串格式)if (options.rectangle) {rectangle options.rectangle;}var locationsuccess function (result) { if (region !rectangle) {//城市限定参数拼接requestParam.boundary region( region , auto_extend , result.latitude , result.longitude );if (options.sig) {requestParam.sig Utils.getSig(requestParam, options.sig, search);}} else if (rectangle !region) {//矩形搜索requestParam.boundary rectangle( rectangle );if (options.sig) {requestParam.sig Utils.getSig(requestParam, options.sig, search);}} else {requestParam.boundary nearby( result.latitude , result.longitude , distance , auto_extend );if (options.sig) {requestParam.sig Utils.getSig(requestParam, options.sig, search);}} wx.request(Utils.buildWxRequestConfig(options, {url: URL_SEARCH,data: requestParam}, search));};Utils.locationProcess(options, locationsuccess);};/*** sug模糊检索** param {Object} options 接口参数对象* * 参数对象结构可以参考* http://lbs.qq.com/webservice_v1/guide-suggestion.html*/getSuggestion(options) {var that this;options options || {};Utils.polyfillParam(options);if (!Utils.checkKeyword(options)) {return;}var requestParam {keyword: options.keyword,region: options.region || 全国,region_fix: options.region_fix || 0,policy: options.policy || 0,page_size: options.page_size || 10,//控制显示条数page_index: options.page_index || 1,//控制页数get_subpois : options.get_subpois || 0,//返回子地点output: json,key: that.key};//长地址if (options.address_format) {requestParam.address_format options.address_format;}//过滤if (options.filter) {requestParam.filter options.filter;}//排序if (options.location) {var locationsuccess function (result) {requestParam.location result.latitude , result.longitude;if (options.sig) {requestParam.sig Utils.getSig(requestParam, options.sig, suggest);}wx.request(Utils.buildWxRequestConfig(options, {url: URL_SUGGESTION,data: requestParam}, suggest)); };Utils.locationProcess(options, locationsuccess);} else {if (options.sig) {requestParam.sig Utils.getSig(requestParam, options.sig, suggest);}wx.request(Utils.buildWxRequestConfig(options, {url: URL_SUGGESTION,data: requestParam}, suggest)); } };/*** 逆地址解析** param {Object} options 接口参数对象* * 请求参数结构可以参考* http://lbs.qq.com/webservice_v1/guide-gcoder.html*/reverseGeocoder(options) {var that this;options options || {};Utils.polyfillParam(options);var requestParam {coord_type: options.coord_type || 5,get_poi: options.get_poi || 0,output: json,key: that.key};if (options.poi_options) {requestParam.poi_options options.poi_options}var locationsuccess function (result) {requestParam.location result.latitude , result.longitude;if (options.sig) {requestParam.sig Utils.getSig(requestParam, options.sig, reverseGeocoder);}wx.request(Utils.buildWxRequestConfig(options, {url: URL_GET_GEOCODER,data: requestParam}, reverseGeocoder));};Utils.locationProcess(options, locationsuccess);};/*** 地址解析** param {Object} options 接口参数对象* * 请求参数结构可以参考* http://lbs.qq.com/webservice_v1/guide-geocoder.html*/geocoder(options) {var that this;options options || {};Utils.polyfillParam(options);if (Utils.checkParamKeyEmpty(options, address)) {return;}var requestParam {address: options.address,output: json,key: that.key};//城市限定if (options.region) {requestParam.region options.region;}if (options.sig) {requestParam.sig Utils.getSig(requestParam, options.sig, geocoder);}wx.request(Utils.buildWxRequestConfig(options, {url: URL_GET_GEOCODER,data: requestParam},geocoder));};/*** 获取城市列表** param {Object} options 接口参数对象* * 请求参数结构可以参考* http://lbs.qq.com/webservice_v1/guide-region.html*/getCityList(options) {var that this;options options || {};Utils.polyfillParam(options);var requestParam {output: json,key: that.key};if (options.sig) {requestParam.sig Utils.getSig(requestParam, options.sig, getCityList);}wx.request(Utils.buildWxRequestConfig(options, {url: URL_CITY_LIST,data: requestParam},getCityList));};/*** 获取对应城市ID的区县列表** param {Object} options 接口参数对象* * 请求参数结构可以参考* http://lbs.qq.com/webservice_v1/guide-region.html*/getDistrictByCityId(options) {var that this;options options || {};Utils.polyfillParam(options);if (Utils.checkParamKeyEmpty(options, id)) {return;}var requestParam {id: options.id || ,output: json,key: that.key};if (options.sig) {requestParam.sig Utils.getSig(requestParam, options.sig, getDistrictByCityId);}wx.request(Utils.buildWxRequestConfig(options, {url: URL_AREA_LIST,data: requestParam},getDistrictByCityId));};/*** 用于单起点到多终点的路线距离(非直线距离)计算* 支持两种距离计算方式步行和驾车。* 起点到终点最大限制直线距离10公里。** 新增直线距离计算。* * param {Object} options 接口参数对象* * 请求参数结构可以参考* http://lbs.qq.com/webservice_v1/guide-distance.html*/calculateDistance(options) {var that this;options options || {};Utils.polyfillParam(options);if (Utils.checkParamKeyEmpty(options, to)) {return;}var requestParam {mode: options.mode || walking,to: Utils.location2query(options.to),output: json,key: that.key};if (options.from) {options.location options.from;}//计算直线距离if(requestParam.mode straight){ var locationsuccess function (result) {var locationTo Utils.getEndLocation(requestParam.to);//处理终点坐标var data {message:query ok,result:{elements:[]},status:0};for (var i 0; i locationTo.length; i) {data.result.elements.push({//将坐标存入distance: Utils.getDistance(result.latitude, result.longitude, locationTo[i].lat, locationTo[i].lng),duration:0,from:{lat: result.latitude,lng:result.longitude},to:{lat: locationTo[i].lat,lng: locationTo[i].lng}}); }var calculateResult data.result.elements;var distanceResult [];for (var i 0; i calculateResult.length; i) {distanceResult.push(calculateResult[i].distance);} return options.success(data,{calculateResult: calculateResult,distanceResult: distanceResult});};Utils.locationProcess(options, locationsuccess);} else {var locationsuccess function (result) {requestParam.from result.latitude , result.longitude;if (options.sig) {requestParam.sig Utils.getSig(requestParam, options.sig, calculateDistance);}wx.request(Utils.buildWxRequestConfig(options, {url: URL_DISTANCE,data: requestParam},calculateDistance));};Utils.locationProcess(options, locationsuccess);} };/*** 路线规划* * param {Object} options 接口参数对象* * 请求参数结构可以参考* https://lbs.qq.com/webservice_v1/guide-road.html*/direction(options) {var that this;options options || {};Utils.polyfillParam(options);if (Utils.checkParamKeyEmpty(options, to)) {return;}var requestParam {output: json,key: that.key};//to格式处理if (typeof options.to string) {requestParam.to options.to;} else {requestParam.to options.to.latitude , options.to.longitude;}//初始化局部请求域名var SET_URL_DIRECTION null;//设置默认mode属性options.mode options.mode || MODE.driving;//设置请求域名SET_URL_DIRECTION URL_DIRECTION options.mode;if (options.from) {options.location options.from;}if (options.mode MODE.driving) {if (options.from_poi) {requestParam.from_poi options.from_poi;}if (options.heading) {requestParam.heading options.heading;}if (options.speed) {requestParam.speed options.speed;}if (options.accuracy) {requestParam.accuracy options.accuracy;}if (options.road_type) {requestParam.road_type options.road_type;}if (options.to_poi) {requestParam.to_poi options.to_poi;}if (options.from_track) {requestParam.from_track options.from_track;}if (options.waypoints) {requestParam.waypoints options.waypoints;}if (options.policy) {requestParam.policy options.policy;}if (options.plate_number) {requestParam.plate_number options.plate_number;}}if (options.mode MODE.transit) {if (options.departure_time) {requestParam.departure_time options.departure_time;}if (options.policy) {requestParam.policy options.policy;}} var locationsuccess function (result) {requestParam.from result.latitude , result.longitude;if (options.sig) {requestParam.sig Utils.getSig(requestParam, options.sig, direction,options.mode);}wx.request(Utils.buildWxRequestConfig(options, {url: SET_URL_DIRECTION,data: requestParam}, direction));};Utils.locationProcess(options, locationsuccess);} };module.exports QQMapWX; 然后再return中声明 long: , //初始经度lat: , //初始纬度end_long: , //目标经度end_lat: , //目标纬度scale: 20,qqmapsdk: {}, // 腾讯地图小程序的SDKpolyline: [], // 路线map: null, // 创建的map对象 然后再onReady中创建map对象 onReady() {// 创建map对象this.map uni.createMapContext(map)}, 然后在onLoad中调用相关事件 this.long this.data.buy_long;this.lat this.data.buy_lat;this.end_lat this.data.latit;this.end_long this.data.longit;this.qqmapsdk new QQMapWX({key: 33XBZ-7JJK5-6MNII-IFL5W-G7F6S-FWBYD // 自己申请的key值});this.routePlanning(this.long, this.lat); 其中this.data为缓存的数据 然后是methods中的方法 // 路线规划routePlanning(long, lat) {let that thisconsole.log(long, 111);console.log(lat, 111);that.qqmapsdk.direction({mode: driving, // 驾车from: { // 起始位置(当前位置)坐标latitude: lat,longitude: long},to: { // 目的地坐标latitude: that.end_lat,longitude: that.end_long,},// 目的地位置坐标success(res) {var coors res.result.routes[0].polylinevar pl [] // 点串数组// 坐标解压(返回的点串坐标通过前向差分进行压缩)var kr 1000000for (var i 2; i coors.length; i) {coors[i] Number(coors[i - 2]) Number(coors[i]) / kr}// 将解压后的坐标放入点串数组pl中for (var i 0; i coors.length; i 2) {pl.push({latitude: coors[i],longitude: coors[i 1]})}console.log(点串数组, pl)// 设置polyline属性将路线显示出来将解压坐标第一个数据作为起点that.polyline [{points: pl,color: #367EEF, // 线的填充色width: 3, // 折现宽度borderWidth: 2, // 边线宽度 borderColor: #5B98FD, // 边线颜色lineCap: square, // 线端头showArrow: true, // 沿线路方向显示箭头}]},error(err) {console.log(err);}})}, 最后放上view代码 map idmap classmap :latitudelat :longitudelong :show-locationfalse:polylinepolyline/map 希望上述代码对您有帮助有疑问欢迎留言

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/914583.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何判断网站是否被收录html5自学教程

在公司开发的时候遇到的一个很玄幻的问题,这个项目是21年开发的,现在我是24年中途二开增加新功能 这个项目经过多人之手,现在已经出现了问题------项目依赖安不上,我能启动完全是因为在23年的时候写这个项目的时候将依赖费九牛二虎之力下载好后打成了压缩包发给另外一个安不上依…

云抢购网官方网站北京信息发布平台

随着互联网应用的不断发展,网站的访问速度成为了用户体验的重要指标之一。为了解决网站访问速度过慢的问题,CDN(内容分发网络)技术被广泛应用。CDN作为一种分布式的网络架构,可以将静态资源如图片、视频、JS、CSS等内容…

建网站麻烦吗专业网站设计公司排名

返回:SQLite—系列文章目录 上一篇:SQLiteC/C接口详细介绍sqlite3_stmt类(四)- 下一篇: 无 12. sqlite3_bind_text16函数 sqlite3_bind_text16函数用于将UTF-16编码的文本数据(字符串)绑定…

传统pc网站货架网站开发

目录 描述 相关属性 使用 描述 盒子模型 例如下面房子模型 • Content 矩形区域: 存放控件内容.⽐如包含的⽂本/图标等. • Border 矩形区域: 控件的边框. • Padding 矩形区域: 内边距. 边框和内容之间的距离. • Margin 矩形区域: 外边距. 边框到控件 geometry 返回的矩形…

镇江网站制作哪家公司比较好我的小程序入口

基本概念:进程和程序的区别 :1、程序是静态概念,本身作为一种软件资源长期保存;而进程是程序的执行过程,它是动态概念,有一定的生命期,是动态产生和消亡的。2、程序和进程无一一对应关系。一个程…

怎么搭建自己的网站服务器南京公司网站建设怎么收费

Docker最全教程之MySQL容器化 (二十四) 原文:Docker最全教程之MySQL容器化 (二十四)前言 MySQL是目前最流行的开源的关系型数据库,MySQL的容器化之前有朋友投稿并且写过此块,本篇仅从笔者角…

中国建设银行对公网站网页在线生成app

1、表格插入 方法一:直接创建表添加 #导入库 from docx import Document #创建文档对象 document Document()#创建5行7列表格 table document.add_table(rows5, cols7)#修改第2行第3列单元格的内容为中国 table.cell(1,2).text中国 #修改第3行第4列单元格的内容…

网站上的彩票走势图是怎么做的wordpress 导入分类

JAR包正常的情况下出现 服务器没有找到驱动jar 报错Cannot load JDBC driver class com.mysql.jdbc.Driv 原因是没有把MYSQL驱动放在TOMCAT的LIB目录下 解决方法:把JDBC驱动放到Tomcat的common/lib下,重新启动服务器 转载于:https://www.cnblogs.com/leiteng/archiv…

个人团购网站 转入备案代账公司注册条件

损失函数(Loss Function)和代价函数(Cost Function)是同一个东西;例如:有一组样本数据,用f1(x),f2(x),f3(x)三个函数(模型)分别来拟合,三个函数的输出F(x)与真实值可能相同也可能不同,为了表示拟…

iis怎么部署网站用dz做网站怎么设置数据库

Filter 可认为是 Servlet的一种 “ 加强版 ”,它主要用于对用户请求进行预处理, 也可以对HttpServletResponse 进行后处理,是个典型的处理链。Filter 也可对用户请求生成响应,这一 点与Servlet 相同, 但实际上很少会使…

徐州模板网站wordpress默认动态路径

前言 最近在写一个项目,在写react的过程中遇到过很多坑,现在总结一下,为以后的项目作参考.另外借此项目来比较一下 vue.js 和 react.js 之间的一些异同. 先说说组件 刚刚开始写组件的时候,感觉难度不大(跟vue差不多)。最有意思的应该是jsx语法…

公司做网上推广哪家好seo排名优化教程

现在有一段时间,我正在研究“云”。 研究它的功能,它可以做什么,为什么我们应该切换到“云”,进行讨论,与RealDolmen的云专家maartenballiauw等人交谈。 我已经在Google App Engine(用于Java)上…

素材网站开发wordpress上传安装包

雨是柔弱的,是世界上最轻灵的东西,敲不响那钢筋水泥造的高楼。而瓦屋则不同,雨滴在上面,叮叮当当的,立即奏出悦耳的声音。身在小屋的人也就有了在雨中亲近自然的福气。而且在雨天睡觉是最舒服的了~在阴雨天气中最熟悉的…

电商网站开发平台有哪些北京 建公司网站要多少钱

JDK 11是预定被释放的一般可用性上周二,9月25日2018年2018年8月16日马克莱因霍尔德消息上OpenJDK的JDK-dev邮件列表宣布“ JDK 11现在在候选发布版阶段 。” 但是,Reinhold在2018年8月17日同一封邮件列表中的消息中提供了更新的详细信息,他在…

wordpress多站点 用户网站建设管理条例

创建并显示文本提示框、对话框和操作菜单。 说明 本模块首批接口从API version 9开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。 该模块不支持在UIAbility的文件声明处使用,即不能在UIAbility的生命周期中调用,需要在创建…

大学生如何建立网站网页设计与制作好学吗

身为一个伟大的程序员,我不允许你不懂isBlank和isEmpty的区别 正文 StrUtil.isBlank(message)和StrUtil.isEmpty(message)这两个方法都是用来检查一个字符串是否为空,但它们的行为是不同的: StrUtil.isEmpty(message):这个方法会检查字符串是…

wordpress仿站教程2016在网站建设中 为了防止工期拖延

引言 相信大家都玩过贪吃蛇这个游戏! 玩家控制一个不断移动的蛇形角色,在一个封闭空间内移动。随着时间推进,这个蛇形角色会逐渐增长,通常是通过吞食屏幕上出现的物品(如点或者其他标志)来实现。每当贪吃…

炒股配资网站建设公司企业网站开发

最近要使用python做一个在web上管理交换机的程序,需要远程登录,就查了点资料,由于还没有搞到交换机,就先用自己的机器测试一下。 首先python的标准库中包含telnet,用起来也很方便,查看一下文档写了个小程序…

网站上的咨询窗口是怎么做的小程序登录入口网址

虚悬镜像是REPOSITORY和TAG为<none>的镜像 none镜像(虚悬镜像),那是因为 构建镜像过程中因为脚本错误导致很多镜像构建终止&#xff0c;产生很多none标签的版本 手动构建镜像的时候没有进行提交&#xff0c;遗留来的垃圾镜像 这些镜像占据较大的存储空间&#xff0c;需要…

网站合作客户第三性 wordpress

几个关键点需要知道 本文不谈原理&#xff0c;直接上实战。 几个关键点&#xff1a;如何拿到Spring上下文来创建bean或移除bean&#xff1f;如何准备构建bean所需的BeanDefinition&#xff1f; 第一问&#xff1a;可注入bean工厂org.springframework.beans.factory.support.…