tool.js 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  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. const earthDistance = function (location1, location2) {
  15. const lat1 = parseFloat(location1.lat);
  16. const lng1 = parseFloat(location1.lng);
  17. const lat2 = parseFloat(location2.lat);
  18. const lng2 = parseFloat(location2.lng);
  19. const EARTH_RADIUS = 6378137.0; //单位M
  20. const PI = Math.PI;
  21. function getRad(d) {
  22. return d * PI / 180.0;
  23. }
  24. let f = getRad((lat1 + lat2) / 2);
  25. let g = getRad((lat1 - lat2) / 2);
  26. let l = getRad((lng1 - lng2) / 2);
  27. let sg = Math.sin(g);
  28. let sl = Math.sin(l);
  29. let sf = Math.sin(f);
  30. let s, c, w, r, d, h1, h2;
  31. let a = EARTH_RADIUS;
  32. let fl = 1 / 298.257;
  33. sg = sg * sg;
  34. sl = sl * sl;
  35. sf = sf * sf;
  36. s = sg * (1 - sl) + (1 - sf) * sl;
  37. c = (1 - sg) * (1 - sl) + sf * sl;
  38. w = Math.atan(Math.sqrt(s / c));
  39. r = Math.sqrt(s * c) / w;
  40. d = 2 * w * a;
  41. h1 = (3 * r - 1) / 2 / c;
  42. h2 = (3 * r + 1) / 2 / s;
  43. return d * (1 + fl * (h1 * sf * (1 - sg) - h2 * (1 - sf) * sg));
  44. };
  45. //rpx转换px px=rpx * (屏幕宽度 / 750)
  46. export const rpxTopx = function (rpx) {
  47. let width = uni.getWindowInfo().screenWidth
  48. let px = rpx *( width / 750 );
  49. return px
  50. }
  51. /**
  52. * 腾讯经纬度转百度地图经纬度
  53. * @param {Object} lng
  54. * @param {Object} lat
  55. */
  56. export function qqMapTransBMap(lng, lat) {
  57. let x_pi = (3.14159265358979324 * 3000.0) / 180.0
  58. let x = lng
  59. let y = lat
  60. let z = Math.sqrt(x * x + y * y) + 0.00002 * Math.sin(y * x_pi)
  61. let theta = Math.atan2(y, x) + 0.000003 * Math.cos(x * x_pi)
  62. let lngs = z * Math.cos(theta) + 0.0065
  63. let lats = z * Math.sin(theta) + 0.006
  64. return {
  65. lng: lngs,
  66. lat: lats,
  67. }
  68. }
  69. /**
  70. * 百度地图经纬度转腾讯地图经纬度
  71. * @param {Object} lng
  72. * @param {Object} lat
  73. */
  74. export function bMapTransQQMap(lng, lat) {
  75. let x_pi = (3.14159265358979324 * 3000.0) / 180.0
  76. let x = lng - 0.0065
  77. let y = lat - 0.006
  78. let z = Math.sqrt(x * x + y * y) - 0.00002 * Math.sin(y * x_pi)
  79. let theta = Math.atan2(y, x) - 0.000003 * Math.cos(x * x_pi)
  80. let lngs = z * Math.cos(theta)
  81. let lats = z * Math.sin(theta)
  82. return {
  83. lng: lngs,
  84. lat: lats,
  85. }
  86. }
  87. /**
  88. * 将百度坐标(DB-09)转为GCJ-02(火星坐标):
  89. */
  90. export function transformFromBaiduToGCJ(latitude, longitude) {
  91. var xPi = 3.14159265358979323846264338327950288 * 3000.0 / 180.0;
  92. var x = longitude - 0.0065;
  93. var y = latitude - 0.006;
  94. var z = Math.sqrt(x * x + y * y) - 0.00002 * Math.sin(y * xPi);
  95. var theta = Math.atan2(y, x) - 0.000003 * Math.cos(x * xPi);
  96. var a_latitude = z * Math.sin(theta);
  97. var a_longitude = z * Math.cos(theta);
  98. return { latitude: a_latitude, longitude: a_longitude };
  99. }
  100. /**
  101. * 判断经纬度是否超出中国境内
  102. */
  103. function isLocationOutOfChina(latitude, longitude) {
  104. if (longitude < 72.004 || longitude > 137.8347 || latitude < 0.8293 || latitude > 55.8271)
  105. return true;
  106. return false;
  107. }
  108. function transformLatWithXY(x, y) {
  109. var pi = 3.14159265358979324;
  110. 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));
  111. lat += (20.0 * Math.sin(6.0 * x * pi) + 20.0 * Math.sin(2.0 * x * pi)) * 2.0 / 3.0;
  112. lat += (20.0 * Math.sin(y * pi) + 40.0 * Math.sin(y / 3.0 * pi)) * 2.0 / 3.0;
  113. lat += (160.0 * Math.sin(y / 12.0 * pi) + 320 * Math.sin(y * pi / 30.0)) * 2.0 / 3.0;
  114. return lat;
  115. }
  116. function transformLonWithXY(x, y) {
  117. var pi = 3.14159265358979324;
  118. var lon = 300.0 + x + 2.0 * y + 0.1 * x * x + 0.1 * x * y + 0.1 * Math.sqrt(Math.abs(x));
  119. lon += (20.0 * Math.sin(6.0 * x * pi) + 20.0 * Math.sin(2.0 * x * pi)) * 2.0 / 3.0;
  120. lon += (20.0 * Math.sin(x * pi) + 40.0 * Math.sin(x / 3.0 * pi)) * 2.0 / 3.0;
  121. lon += (150.0 * Math.sin(x / 12.0 * pi) + 300.0 * Math.sin(x / 30.0 * pi)) * 2.0 / 3.0;
  122. return lon;
  123. }
  124. /**
  125. * 谷歌地图经纬度转gcj02经纬度
  126. * @param {Object} lng
  127. * @param {Object} lat
  128. */
  129. export function transformFromWGSToGCJ(latitude, longitude) {
  130. var lat = "";
  131. var lon = "";
  132. var ee = 0.00669342162296594323;
  133. var a = 6378245.0;
  134. var pi = 3.14159265358979324;
  135. if (isLocationOutOfChina(latitude, longitude)) {
  136. lat = latitude;
  137. lon = longitude;
  138. }
  139. else {
  140. var adjustLat = transformLatWithXY(longitude - 105.0, latitude - 35.0);
  141. var adjustLon = transformLonWithXY(longitude - 105.0, latitude - 35.0);
  142. var radLat = latitude / 180.0 * pi;
  143. var magic = Math.sin(radLat);
  144. magic = 1 - ee * magic * magic;
  145. var sqrtMagic = Math.sqrt(magic);
  146. adjustLat = (adjustLat * 180.0) / ((a * (1 - ee)) / (magic * sqrtMagic) * pi);
  147. adjustLon = (adjustLon * 180.0) / (a / sqrtMagic * Math.cos(radLat) * pi);
  148. latitude = latitude + adjustLat;
  149. longitude = longitude + adjustLon;
  150. }
  151. return { latitude: latitude, longitude: longitude };
  152. }