tool.js 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212
  1. //防抖debounce代码:
  2. export function debounce(fn,delay=500) {
  3. var timeout = null; // 创建一个标记用来存放定时器的返回值
  4. return function (e) {
  5. // 每当用户输入的时候把前一个 setTimeout clear 掉
  6. clearTimeout(timeout);
  7. // 然后又创建一个新的 setTimeout, 这样就能保证interval 间隔内如果时间持续触发,就不会执行 fn 函数
  8. timeout = setTimeout(() => {
  9. fn.apply(this, arguments);
  10. }, delay);
  11. };
  12. }
  13. // 时间戳转换
  14. export function parseDate(time, cFormat) {
  15. if (arguments.length === 0) {
  16. return null
  17. }
  18. const format = cFormat || '{y}-{m}-{d}'
  19. let date
  20. if (typeof time === 'object') {
  21. date = time
  22. } else {
  23. if ((typeof time === 'string') && (/^[0-9]+$/.test(time))) {
  24. time = parseInt(time)
  25. }
  26. if ((typeof time === 'number') && (time.toString().length === 10)) {
  27. time = time * 1000
  28. }
  29. date = new Date(time)
  30. }
  31. const formatObj = {
  32. y: date.getFullYear(),
  33. m: date.getMonth() + 1,
  34. d: date.getDate(),
  35. h: date.getHours(),
  36. i: date.getMinutes(),
  37. s: date.getSeconds(),
  38. a: date.getDay()
  39. }
  40. const time_str = format.replace(/{([ymdhisa])+}/g, (result, key) => {
  41. const value = formatObj[key]
  42. if (key === 'a') { return ['日', '一', '二', '三', '四', '五', '六'][value ] }
  43. return value.toString().padStart(2, '0')
  44. })
  45. return time_str
  46. }
  47. // 返回两个经纬度之间的距离 单位米
  48. const earthDistance = function (location1, location2) {
  49. const lat1 = parseFloat(location1.lat);
  50. const lng1 = parseFloat(location1.lng);
  51. const lat2 = parseFloat(location2.lat);
  52. const lng2 = parseFloat(location2.lng);
  53. const EARTH_RADIUS = 6378137.0; //单位M
  54. const PI = Math.PI;
  55. function getRad(d) {
  56. return d * PI / 180.0;
  57. }
  58. let f = getRad((lat1 + lat2) / 2);
  59. let g = getRad((lat1 - lat2) / 2);
  60. let l = getRad((lng1 - lng2) / 2);
  61. let sg = Math.sin(g);
  62. let sl = Math.sin(l);
  63. let sf = Math.sin(f);
  64. let s, c, w, r, d, h1, h2;
  65. let a = EARTH_RADIUS;
  66. let fl = 1 / 298.257;
  67. sg = sg * sg;
  68. sl = sl * sl;
  69. sf = sf * sf;
  70. s = sg * (1 - sl) + (1 - sf) * sl;
  71. c = (1 - sg) * (1 - sl) + sf * sl;
  72. w = Math.atan(Math.sqrt(s / c));
  73. r = Math.sqrt(s * c) / w;
  74. d = 2 * w * a;
  75. h1 = (3 * r - 1) / 2 / c;
  76. h2 = (3 * r + 1) / 2 / s;
  77. return d * (1 + fl * (h1 * sf * (1 - sg) - h2 * (1 - sf) * sg));
  78. };
  79. //rpx转换px px=rpx * (屏幕宽度 / 750)
  80. export const rpxTopx = function (rpx) {
  81. let width = uni.getWindowInfo().screenWidth
  82. let px = rpx *( width / 750 );
  83. return px
  84. }
  85. /**
  86. * 腾讯经纬度转百度地图经纬度
  87. * @param {Object} lng
  88. * @param {Object} lat
  89. */
  90. export function qqMapTransBMap(lng, lat) {
  91. let x_pi = (3.14159265358979324 * 3000.0) / 180.0
  92. let x = lng
  93. let y = lat
  94. let z = Math.sqrt(x * x + y * y) + 0.00002 * Math.sin(y * x_pi)
  95. let theta = Math.atan2(y, x) + 0.000003 * Math.cos(x * x_pi)
  96. let lngs = z * Math.cos(theta) + 0.0065
  97. let lats = z * Math.sin(theta) + 0.006
  98. return {
  99. lng: lngs,
  100. lat: lats,
  101. }
  102. }
  103. /**
  104. * 百度地图经纬度转腾讯地图经纬度
  105. * @param {Object} lng
  106. * @param {Object} lat
  107. */
  108. export function bMapTransQQMap(lng, lat) {
  109. let x_pi = (3.14159265358979324 * 3000.0) / 180.0
  110. let x = lng - 0.0065
  111. let y = lat - 0.006
  112. let z = Math.sqrt(x * x + y * y) - 0.00002 * Math.sin(y * x_pi)
  113. let theta = Math.atan2(y, x) - 0.000003 * Math.cos(x * x_pi)
  114. let lngs = z * Math.cos(theta)
  115. let lats = z * Math.sin(theta)
  116. return {
  117. lng: lngs,
  118. lat: lats,
  119. }
  120. }
  121. /**
  122. * 将百度坐标(DB-09)转为GCJ-02(火星坐标):
  123. */
  124. export function transformFromBaiduToGCJ(latitude, longitude) {
  125. var xPi = 3.14159265358979323846264338327950288 * 3000.0 / 180.0;
  126. var x = longitude - 0.0065;
  127. var y = latitude - 0.006;
  128. var z = Math.sqrt(x * x + y * y) - 0.00002 * Math.sin(y * xPi);
  129. var theta = Math.atan2(y, x) - 0.000003 * Math.cos(x * xPi);
  130. var a_latitude = z * Math.sin(theta);
  131. var a_longitude = z * Math.cos(theta);
  132. return { latitude: a_latitude, longitude: a_longitude };
  133. }
  134. /**
  135. * 判断经纬度是否超出中国境内
  136. */
  137. function isLocationOutOfChina(latitude, longitude) {
  138. if (longitude < 72.004 || longitude > 137.8347 || latitude < 0.8293 || latitude > 55.8271)
  139. return true;
  140. return false;
  141. }
  142. function transformLatWithXY(x, y) {
  143. var pi = 3.14159265358979324;
  144. var lat = -100.0 + 2.0 * x + 3.0 * y + 0.2 * y * y + 0.1 * x * y + 0.2 * Math.sqrt(Math.abs(x));
  145. lat += (20.0 * Math.sin(6.0 * x * pi) + 20.0 * Math.sin(2.0 * x * pi)) * 2.0 / 3.0;
  146. lat += (20.0 * Math.sin(y * pi) + 40.0 * Math.sin(y / 3.0 * pi)) * 2.0 / 3.0;
  147. lat += (160.0 * Math.sin(y / 12.0 * pi) + 320 * Math.sin(y * pi / 30.0)) * 2.0 / 3.0;
  148. return lat;
  149. }
  150. function transformLonWithXY(x, y) {
  151. var pi = 3.14159265358979324;
  152. var lon = 300.0 + x + 2.0 * y + 0.1 * x * x + 0.1 * x * y + 0.1 * Math.sqrt(Math.abs(x));
  153. lon += (20.0 * Math.sin(6.0 * x * pi) + 20.0 * Math.sin(2.0 * x * pi)) * 2.0 / 3.0;
  154. lon += (20.0 * Math.sin(x * pi) + 40.0 * Math.sin(x / 3.0 * pi)) * 2.0 / 3.0;
  155. lon += (150.0 * Math.sin(x / 12.0 * pi) + 300.0 * Math.sin(x / 30.0 * pi)) * 2.0 / 3.0;
  156. return lon;
  157. }
  158. /**
  159. * 谷歌地图经纬度转gcj02经纬度
  160. * @param {Object} lng
  161. * @param {Object} lat
  162. */
  163. export function transformFromWGSToGCJ(latitude, longitude) {
  164. var lat = "";
  165. var lon = "";
  166. var ee = 0.00669342162296594323;
  167. var a = 6378245.0;
  168. var pi = 3.14159265358979324;
  169. if (isLocationOutOfChina(latitude, longitude)) {
  170. lat = latitude;
  171. lon = longitude;
  172. }
  173. else {
  174. var adjustLat = transformLatWithXY(longitude - 105.0, latitude - 35.0);
  175. var adjustLon = transformLonWithXY(longitude - 105.0, latitude - 35.0);
  176. var radLat = latitude / 180.0 * pi;
  177. var magic = Math.sin(radLat);
  178. magic = 1 - ee * magic * magic;
  179. var sqrtMagic = Math.sqrt(magic);
  180. adjustLat = (adjustLat * 180.0) / ((a * (1 - ee)) / (magic * sqrtMagic) * pi);
  181. adjustLon = (adjustLon * 180.0) / (a / sqrtMagic * Math.cos(radLat) * pi);
  182. latitude = latitude + adjustLat;
  183. longitude = longitude + adjustLon;
  184. }
  185. return { latitude: latitude, longitude: longitude };
  186. }