deviceLocal1.js 74 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785
  1. // pages/deviceLocal/deviceLocal.js
  2. const config = require('../../common/config.js');
  3. const common = require('../../common/common.js');
  4. var http = require('../../common/http.js');
  5. var storage = require('../../common/storage.js');
  6. var QQMapWX = require('../../libs/qqmap-wx-jssdk.js');
  7. var qqmapsdk;
  8. export default {
  9. data() {
  10. return {
  11. deviceInfo: {},
  12. marker: [],
  13. mileage_total: 0,
  14. deviceMarker: [],
  15. trackMarker: [],
  16. alarmMarker: [],
  17. playMarker: [],
  18. endSlide: 0,
  19. polylines: [],
  20. trackPoints: [],
  21. trackStopList: [],
  22. batteryWidth: 37,
  23. alarmList: [],
  24. adjustSpeed: 1,
  25. scale: 8,
  26. speedTime: 200,
  27. trackDialogFrom: {
  28. startTime: new Date(new Date().getTime() - 3600000).getTime(),
  29. formatStartTime: common.formatDateTime(new Date(new Date().getTime() - 3600000).getTime()),
  30. endTime: new Date().getTime(),
  31. formatEndTime: common.formatDateTime(new Date().getTime())
  32. },
  33. latitude_my: null,
  34. longitude_my: null,
  35. trackDialogShow: false,
  36. selectTime: new Date().getTime(),
  37. selectTimeType: '',
  38. alarmPopupShow: false,
  39. trackStopPopupShow: false,
  40. timeSelectShow: false,
  41. inPlay: false,
  42. playTimer: null,
  43. nowPlayIndex: 0,
  44. totalTrackValue: 0,
  45. currentTrackValue: 0,
  46. macid: '',
  47. gps: 0,
  48. gsm: 0,
  49. status: '',
  50. address: '',
  51. showInfo: true,
  52. iconList: [],
  53. locationTimer: null,
  54. longitude: null,
  55. latitude: null,
  56. trace: false,
  57. tracePoints: [],
  58. traceTime: 0,
  59. traceTimer: null,
  60. fencePopupShow: false,
  61. fenceList: [],
  62. isLocationType: 1,
  63. circles: [],
  64. selectFence: null,
  65. mapParams: {
  66. enableSatellite: false,
  67. // 是否开启卫星图
  68. enableTraffic: false // 是否开启实时路况
  69. },
  70. isShowGPS: false,
  71. // locationInfo:{}
  72. locationType: '',
  73. locationAdress: '',
  74. locationGpsType: '',
  75. locationGpsAdress: '',
  76. gpsMarker: []
  77. };
  78. }
  79. /**
  80. * 生命周期函数--监听页面加载
  81. */,
  82. onLoad: function (options) {
  83. this.loadIconList();
  84. this.readyDeviceInfo();
  85. this.loadAlarmList();
  86. this.loadFenceList();
  87. this.locationLoop(true);
  88. //this.loadLastGpsInfo()
  89. this.locationTimer = setInterval(this.locationLoop, 10000);
  90. //获取当前位置
  91. uni.getLocation({
  92. type: 'gcj02',
  93. success: (res) => {
  94. //console.log(res)
  95. this.setData({
  96. latitude_my: res.latitude,
  97. longitude_my: res.longitude
  98. });
  99. }
  100. });
  101. this.mapCtx = uni.createMapContext('myMap');
  102. },
  103. onHide: function () {},
  104. onShow: function () {},
  105. onUnload: function () {
  106. clearInterval(this.locationTimer);
  107. clearInterval(this.traceTimer);
  108. clearInterval(this.playTimer);
  109. },
  110. methods: {
  111. loadIconList: function () {
  112. this.iconList = storage.getIconList();
  113. if (!this.iconList) {
  114. http.postApi(config.API_BATTERY_ICON_LIST, {}, (resp) => {
  115. if (resp.data.code === 200) {
  116. this.iconList = resp.data.data.list;
  117. storage.setIconList(resp.data.data.list);
  118. } else {
  119. common.simpleToast(resp.data.msg);
  120. }
  121. });
  122. }
  123. },
  124. trackPlayChange(e) {
  125. var index = e.detail.value;
  126. this.setData({
  127. nowPlayIndex: index
  128. });
  129. this.playLoop();
  130. },
  131. bindLocationType(e) {
  132. const index = e.currentTarget.dataset.index;
  133. console.log(index);
  134. this.setData({
  135. isLocationType: index
  136. });
  137. },
  138. trackPlayChangeAdress(e) {
  139. console.log('22222');
  140. var index = e.detail.value;
  141. this.setData({
  142. nowPlayIndex: index
  143. });
  144. const me = this;
  145. this.playLoop();
  146. console.log(me.playMarker.length);
  147. if (me.playMarker.length > 0) {
  148. console.log('22222333333');
  149. // qqmapsdk.reverseGeocoder({
  150. // location: {
  151. // latitude: me.data.playMarker[0].latitude,
  152. // longitude: me.data.playMarker[0].longitude
  153. // },
  154. // success: function (res) {
  155. // const formatted_addresses = res.result.formatted_addresses
  156. // const address = res.result.address
  157. // let ps = '';
  158. // let tmp_addr = '地址: ' + address
  159. // while (tmp_addr.length > 15) {
  160. // ps += tmp_addr.substring(0, 15) + "\n";
  161. // tmp_addr = tmp_addr.substring(15);
  162. // }
  163. // ps += tmp_addr
  164. // var playMark = me.data.playMarker
  165. // playMark[0].callout.content += ps
  166. // me.setData({
  167. // playMarker: playMark
  168. // })
  169. // console.log("1111111")
  170. // me.setMarkers()
  171. // }
  172. // })
  173. const me = this;
  174. const pData = {
  175. lng: me.playMarker[0].longitude,
  176. lat: me.playMarker[0].latitude,
  177. pi: 'wx_deviceLocal'
  178. };
  179. http.postApi(config.API_MAP_REGEO, pData, function (resp) {
  180. if (resp.data.code === 200) {
  181. var jsonData = resp.data.data.data;
  182. if (jsonData.code === 0) {
  183. const address = jsonData.address;
  184. let ps = '';
  185. let tmp_addr = '地址: ' + address;
  186. while (tmp_addr.length > 15) {
  187. ps += tmp_addr.substring(0, 15) + '\n';
  188. tmp_addr = tmp_addr.substring(15);
  189. }
  190. ps += tmp_addr;
  191. var playMark = me.playMarker;
  192. playMark[0].callout.content += ps;
  193. me.setData({
  194. playMarker: playMark
  195. });
  196. }
  197. }
  198. });
  199. }
  200. },
  201. bindFastForward() {
  202. if (this.adjustSpeed === 0) {
  203. this.setData({
  204. adjustSpeed: 1,
  205. speedTime: 400
  206. });
  207. clearInterval(this.playTimer);
  208. this.playTimer = setInterval(this.playLoop, this.speedTime);
  209. } else if (this.adjustSpeed === 1) {
  210. this.setData({
  211. adjustSpeed: 2,
  212. speedTime: 200
  213. });
  214. clearInterval(this.playTimer);
  215. this.playTimer = setInterval(this.playLoop, this.speedTime);
  216. } else if (this.adjustSpeed === 2) {
  217. this.setData({
  218. adjustSpeed: 0,
  219. speedTime: 600
  220. });
  221. clearInterval(this.playTimer);
  222. this.playTimer = setInterval(this.playLoop, this.speedTime);
  223. }
  224. },
  225. loadAlarmList() {
  226. common.loading();
  227. const deviceInfo = storage.getSelectedDeviceInfo();
  228. http.postApi(
  229. config.API_GPS_ALARM,
  230. {
  231. macid: deviceInfo.mac_id
  232. },
  233. (resp) => {
  234. uni.hideLoading();
  235. if (resp.data.code === 200) {
  236. var alarmList = resp.data.data.list;
  237. alarmList.forEach((p, i) => {
  238. alarmList[i].formatTime = common.formatDateTime(p.send_time * 1000);
  239. // qqmapsdk.reverseGeocoder({
  240. // location: {
  241. // latitude: p.latitude,
  242. // longitude: p.longitude
  243. // },
  244. // success: (res) => {
  245. // const formatted_addresses = res.result.formatted_addresses
  246. // const address = res.result.address //+ formatted_addresses.recommend
  247. // let ps = '';
  248. // let tmp_addr = '地址: ' + address
  249. // while (tmp_addr.length > 15) {
  250. // ps += tmp_addr.substring(0, 15) + "\n";
  251. // tmp_addr = tmp_addr.substring(15);
  252. // }
  253. // ps += tmp_addr
  254. // alarmList[i].address = address
  255. // alarmList[i].ps = ps
  256. // this.setData({
  257. // alarmList: alarmList
  258. // })
  259. // }
  260. // })
  261. });
  262. this.setData({
  263. alarmList: alarmList
  264. });
  265. } else {
  266. common.simpleToast(resp.data.msg);
  267. }
  268. }
  269. );
  270. },
  271. readyDeviceInfo() {
  272. const me = this;
  273. // 实例化API核心类
  274. qqmapsdk = new QQMapWX({
  275. key: config.QQ_MAP_KEY
  276. });
  277. const deviceInfo = storage.getSelectedDeviceInfo();
  278. if (deviceInfo) {
  279. console.log('1111');
  280. console.log(deviceInfo);
  281. // this.batteryWidth = deviceInfo.quantity/100*37
  282. // console.log(deviceInfo.quantity)
  283. uni.setNavigationBarTitle({
  284. title: deviceInfo.mac_id
  285. });
  286. if (parseInt(deviceInfo.expire) === 1) {
  287. common.simpleToast('设备到期');
  288. setTimeout(function () {
  289. uni.navigateBack({
  290. delta: 1
  291. });
  292. }, 1500);
  293. }
  294. } else {
  295. clearInterval(this.locationTimer);
  296. setTimeout(function () {
  297. uni.navigateBack({
  298. delta: 1
  299. });
  300. }, 1500);
  301. }
  302. },
  303. setMarkers() {
  304. this.setData({
  305. marker: this.deviceMarker.concat(this.trackMarker, this.alarmMarker, this.playMarker, this.gpsMarker)
  306. });
  307. },
  308. setPolylines() {
  309. var polylines = [
  310. {
  311. points: this.trackPoints,
  312. color: '#1989FADD',
  313. width: 5,
  314. arrowLine: true
  315. }
  316. ]; /*, {
  317. points: this.data.trackPoints.slice(0,this.data.nowPlayIndex+1),
  318. color: '#F56C6CDD',
  319. width: 3,
  320. }]*/
  321. if (this.trace) {
  322. polylines.push({
  323. points: this.tracePoints,
  324. color: '#DD4C4CDD',
  325. width: 3,
  326. arrowLine: true
  327. });
  328. }
  329. this.setData({
  330. polylines: polylines
  331. });
  332. },
  333. bindTrackDialogOpen() {
  334. this.setData({
  335. trackDialogShow: true
  336. });
  337. },
  338. // 计算里程数
  339. calculateMileage(history) {
  340. let mileage = 0;
  341. for (let i = 0; i < history.length - 1; i++) {
  342. mileage += parseInt(common.getFlatternDistance(history[i].longitude, history[i].latitude, history[i + 1].longitude, history[i + 1].latitude));
  343. }
  344. var mileage_total = mileage == 0 ? 0 : (mileage / 1000).toFixed(2);
  345. console.log('公里');
  346. console.log(mileage_total);
  347. this.setData({
  348. mileage_total: mileage_total
  349. });
  350. },
  351. getCurrentMil(mileage, i, history) {
  352. //var mileage = mileage_current
  353. mileage += parseInt(common.getFlatternDistance(history[i].longitude, history[i].latitude, history[i + 1].longitude, history[i + 1].latitude));
  354. console.log(mileage);
  355. return mileage;
  356. },
  357. bindTrackDialogConfirm() {
  358. this.bindTrackDialogClose();
  359. this.setData({
  360. inPlay: false
  361. });
  362. clearInterval(this.playTimer);
  363. common.loading();
  364. const deviceInfo = storage.getSelectedDeviceInfo();
  365. http.postApi(
  366. config.API_GPS_TRACK,
  367. {
  368. macid: deviceInfo.mac_id,
  369. location_type: this.isLocationType,
  370. from: parseInt(this.trackDialogFrom.startTime / 1000),
  371. to: parseInt(this.trackDialogFrom.endTime / 1000)
  372. },
  373. (resp) => {
  374. console.log('1111');
  375. console.log(resp);
  376. uni.hideLoading();
  377. if (resp.data.code === 200) {
  378. if (!resp.data.data.points || resp.data.data.points.length === 0) {
  379. common.simpleToast('当前未有轨迹');
  380. return;
  381. }
  382. this.calculateMileage(resp.data.data.points);
  383. var points = [];
  384. var trackMarker = [];
  385. var trackStopList = [];
  386. var n = 1;
  387. this.setData({
  388. totalTrackValue: resp.data.data.points.length
  389. });
  390. var mileage = 0;
  391. resp.data.data.points.forEach((p, i) => {
  392. //移动坐标点
  393. if (resp.data.data.points.length - 1 > i) {
  394. mileage = this.getCurrentMil(mileage, i, resp.data.data.points);
  395. }
  396. points.push({
  397. latitude: parseFloat(p.latitude),
  398. longitude: parseFloat(p.longitude),
  399. time: p.time,
  400. speed: p.speed,
  401. voltage: p.voltage,
  402. time: p.time,
  403. mileage: (mileage / 1000).toFixed(2),
  404. stop_time: p.stop_time
  405. });
  406. //起点
  407. if (i === 0) {
  408. trackStopList.push({
  409. name: '起点',
  410. latitude: parseFloat(p.latitude),
  411. longitude: parseFloat(p.longitude),
  412. time: p.time,
  413. end_time: common.formatDateTime(new Date(p.time).getTime() + p.stop_time * 1000),
  414. stop_time: p.stop_time,
  415. format_stop_time: common.formatSeconds(p.stop_time),
  416. address: ''
  417. });
  418. //mark弹出框坐标
  419. trackMarker.push({
  420. id: 0,
  421. latitude: p.latitude,
  422. longitude: p.longitude,
  423. name: '',
  424. iconPath: '/static/resource/images/start_point.png',
  425. width: 28,
  426. height: 35,
  427. zIndex: 2,
  428. callout: {
  429. content:
  430. '\u8D77\u70B9\n\u505C\u7559: ' +
  431. common.formatSeconds(p.stop_time) +
  432. '\n' +
  433. '开始: ' +
  434. p.time +
  435. '\n' +
  436. '结束: ' +
  437. common.formatDateTime(new Date(p.time).getTime() + p.stop_time * 1000) +
  438. '\n',
  439. padding: 10,
  440. borderRadius: 4,
  441. boxShadow: '4px 8px 16px 0 rgba(0,0,0,0.3)',
  442. display: 'BYCLICK'
  443. }
  444. });
  445. const me = this;
  446. const pData = {
  447. lng: parseFloat(p.longitude),
  448. lat: parseFloat(p.latitude),
  449. pi: 'wx_deviceLocal'
  450. };
  451. http.postApi(config.API_MAP_REGEO, pData, function (resp) {
  452. if (resp.data.code === 200) {
  453. var jsonData = resp.data.data.data;
  454. if (jsonData.code === 0) {
  455. const address = jsonData.address;
  456. let ps = '';
  457. let tmp_addr = '地址: ' + address;
  458. while (tmp_addr.length > 15) {
  459. ps += tmp_addr.substring(0, 15) + '\n';
  460. tmp_addr = tmp_addr.substring(15);
  461. }
  462. ps += tmp_addr;
  463. trackMarker[0].callout.content += ps;
  464. trackStopList[0].address = address;
  465. me.setData({
  466. trackMarker: trackMarker,
  467. trackStopList: trackStopList
  468. });
  469. me.setMarkers();
  470. }
  471. }
  472. });
  473. // qqmapsdk.reverseGeocoder({
  474. // location: {
  475. // latitude: parseFloat(p.latitude),
  476. // longitude: parseFloat(p.longitude)
  477. // },
  478. // success: (res) => {
  479. // console.log(res)
  480. // const formatted_addresses = res.result.formatted_addresses
  481. // const address = res.result.address + formatted_addresses.recommend
  482. // let ps = '';
  483. // let tmp_addr = '地址: ' + address
  484. // while (tmp_addr.length > 15) {
  485. // ps += tmp_addr.substring(0, 15) + "\n";
  486. // tmp_addr = tmp_addr.substring(15);
  487. // }
  488. // ps += tmp_addr
  489. // trackMarker[0].callout.content += ps
  490. // trackStopList[0].address = address
  491. // this.setData({
  492. // trackMarker: trackMarker,
  493. // trackStopList: trackStopList,
  494. // })
  495. // this.setMarkers()
  496. // }
  497. // })
  498. } else if (p.stop_time > 300 && i !== resp.data.data.points.length - 1) {
  499. //地图设置mark停留点
  500. trackStopList.push({
  501. name: 'P' + n,
  502. latitude: parseFloat(p.latitude),
  503. longitude: parseFloat(p.longitude),
  504. time: p.time,
  505. end_time: common.formatDateTime(new Date(p.time).getTime() + p.stop_time * 1000),
  506. stop_time: p.stop_time,
  507. format_stop_time: common.formatSeconds(p.stop_time),
  508. address: ''
  509. });
  510. //mark弹出框
  511. trackMarker.push({
  512. id: i,
  513. latitude: parseFloat(p.latitude),
  514. longitude: parseFloat(p.longitude),
  515. name: '',
  516. iconPath: '/static/resource/images/p-stop.png',
  517. width: 28,
  518. height: 35,
  519. zIndex: 1,
  520. callout: {
  521. content:
  522. 'P' +
  523. n +
  524. '\n' +
  525. '停留: ' +
  526. common.formatSeconds(p.stop_time) +
  527. '\n' +
  528. '开始: ' +
  529. p.time +
  530. '\n' +
  531. '结束: ' +
  532. common.formatDateTime(new Date(p.time).getTime() + p.stop_time * 1000) +
  533. '\n',
  534. padding: 10,
  535. borderRadius: 4,
  536. boxShadow: '4px 8px 16px 0 rgba(0,0,0,0.3)',
  537. display: 'BYCLICK'
  538. }
  539. });
  540. var i = n;
  541. qqmapsdk.reverseGeocoder({
  542. location: {
  543. latitude: parseFloat(p.latitude),
  544. longitude: parseFloat(p.longitude)
  545. },
  546. success: (res) => {
  547. console.log(res);
  548. const formatted_addresses = res.result.formatted_addresses;
  549. const address = res.result.address + formatted_addresses.recommend;
  550. let ps = '';
  551. let tmp_addr = '地址: ' + address;
  552. while (tmp_addr.length > 15) {
  553. ps += tmp_addr.substring(0, 15) + '\n';
  554. tmp_addr = tmp_addr.substring(15);
  555. }
  556. ps += tmp_addr;
  557. trackMarker[i].callout.content += ps;
  558. trackStopList[i].address = address;
  559. this.setData({
  560. trackMarker: trackMarker,
  561. trackStopList: trackStopList
  562. });
  563. this.setMarkers();
  564. }
  565. });
  566. n++;
  567. }
  568. });
  569. //设置终点
  570. trackStopList.push({
  571. name: '终点',
  572. latitude: parseFloat(points[points.length - 1].latitude),
  573. longitude: parseFloat(points[points.length - 1].longitude),
  574. time: points[points.length - 1].time,
  575. end_time: common.formatDateTime(new Date(points[points.length - 1].time).getTime() + points[points.length - 1].stop_time * 1000),
  576. stop_time: points[points.length - 1].stop_time,
  577. format_stop_time: common.formatSeconds(points[points.length - 1].stop_time),
  578. address: ''
  579. });
  580. trackMarker.push({
  581. id: points.length - 1,
  582. latitude: points[points.length - 1].latitude,
  583. longitude: points[points.length - 1].longitude,
  584. name: '',
  585. iconPath: '/static/resource/images/end_point.png',
  586. width: 28,
  587. height: 35,
  588. zIndex: 2,
  589. callout: {
  590. content:
  591. '\u7EC8\u70B9\n\u505C\u7559: ' +
  592. common.formatSeconds(points[points.length - 1].stop_time) +
  593. '\n' +
  594. '开始: ' +
  595. points[points.length - 1].time +
  596. '\n' +
  597. '结束: ' +
  598. common.formatDateTime(new Date(points[points.length - 1].time).getTime() + points[points.length - 1].stop_time * 1000) +
  599. '\n',
  600. padding: 10,
  601. borderRadius: 4,
  602. boxShadow: '4px 8px 16px 0 rgba(0,0,0,0.3)',
  603. display: 'BYCLICK'
  604. }
  605. });
  606. qqmapsdk.reverseGeocoder({
  607. location: {
  608. latitude: parseFloat(points[points.length - 1].latitude),
  609. longitude: parseFloat(points[points.length - 1].longitude)
  610. },
  611. success: (res) => {
  612. console.log(res);
  613. const formatted_addresses = res.result.formatted_addresses;
  614. const address = res.result.address + formatted_addresses.recommend;
  615. let ps = '';
  616. let tmp_addr = '地址: ' + address;
  617. while (tmp_addr.length > 15) {
  618. ps += tmp_addr.substring(0, 15) + '\n';
  619. tmp_addr = tmp_addr.substring(15);
  620. }
  621. ps += tmp_addr;
  622. trackMarker[n].callout.content += ps;
  623. trackStopList[n].address = address;
  624. this.setData({
  625. trackMarker: trackMarker,
  626. trackStopList: trackStopList
  627. });
  628. this.setMarkers();
  629. }
  630. });
  631. var deviceMarker = this.deviceMarker;
  632. //deviceMarker[0].callout.display = 'BYCLICK'
  633. this.setData({
  634. trackPoints: points,
  635. trackMarker: trackMarker,
  636. deviceMarker: deviceMarker,
  637. trackStopList: trackStopList,
  638. nowPlayIndex: 0,
  639. playMarker: []
  640. });
  641. this.setMarkers();
  642. this.setPolylines();
  643. // this.mapCtx.scale = 8
  644. var map = uni.createMapContext('myMap');
  645. map.includePoints({
  646. points: points,
  647. padding: [10, 10, 10, 10]
  648. });
  649. this.setData({
  650. scale: 13
  651. });
  652. } else {
  653. common.simpleToast(resp.data.msg);
  654. }
  655. }
  656. );
  657. },
  658. bindTrackDialogClose() {
  659. this.setData({
  660. trackDialogShow: false
  661. });
  662. },
  663. bindTrackStartTimeSelect() {
  664. this.setData({
  665. selectTime: this.trackDialogFrom.startTime,
  666. selectTimeType: 'track_start'
  667. });
  668. this.bindTimeSelectOpen();
  669. },
  670. bindTrackEndTimeSelect() {
  671. this.setData({
  672. selectTime: this.trackDialogFrom.endTime,
  673. selectTimeType: 'track_end'
  674. });
  675. this.bindTimeSelectOpen();
  676. },
  677. bindTrackTimeSelectToday() {
  678. this.setData({
  679. trackDialogFrom: Object.assign(this.trackDialogFrom, {
  680. startTime: new Date(new Date().toLocaleDateString()).getTime(),
  681. formatStartTime: common.formatDateTime(new Date(new Date().toLocaleDateString()).getTime()),
  682. endTime: new Date().getTime(),
  683. formatEndTime: common.formatDateTime(new Date().getTime())
  684. })
  685. });
  686. this.bindTrackDialogConfirm();
  687. },
  688. bindTrackTimeSelectYesterday() {
  689. this.setData({
  690. trackDialogFrom: Object.assign(this.trackDialogFrom, {
  691. startTime: new Date(new Date().toLocaleDateString()).getTime() - 86400 * 1000,
  692. formatStartTime: common.formatDateTime(new Date(new Date().toLocaleDateString()).getTime() - 86400 * 1000),
  693. endTime: new Date(new Date().toLocaleDateString()).getTime() - 1,
  694. formatEndTime: common.formatDateTime(new Date(new Date().toLocaleDateString()).getTime() - 1)
  695. })
  696. });
  697. this.bindTrackDialogConfirm();
  698. },
  699. bindTrackTimeSelectLastday() {
  700. this.setData({
  701. trackDialogFrom: Object.assign(this.trackDialogFrom, {
  702. startTime: new Date(new Date().toLocaleDateString()).getTime() - 2880 * 60 * 1000,
  703. formatStartTime: common.formatDateTime(new Date(new Date().toLocaleDateString()).getTime() - 2880 * 60 * 1000),
  704. endTime: new Date(new Date().toLocaleDateString()).getTime() - 86400 * 1000 - 1,
  705. formatEndTime: common.formatDateTime(new Date(new Date().toLocaleDateString()).getTime() - 86400 * 1000 - 1)
  706. })
  707. });
  708. this.bindTrackDialogConfirm();
  709. },
  710. bindTimeSelectConfirm(event) {
  711. switch (this.selectTimeType) {
  712. case 'track_start':
  713. this.setData({
  714. trackDialogFrom: Object.assign(this.trackDialogFrom, {
  715. startTime: event.detail,
  716. formatStartTime: common.formatDateTime(event.detail)
  717. }),
  718. selectTimeType: ''
  719. });
  720. break;
  721. case 'track_end':
  722. this.setData({
  723. trackDialogFrom: Object.assign(this.trackDialogFrom, {
  724. endTime: event.detail,
  725. formatEndTime: common.formatDateTime(event.detail)
  726. }),
  727. selectTimeType: ''
  728. });
  729. break;
  730. }
  731. this.bindTimeSelectClose();
  732. },
  733. bindTimeSelectOpen() {
  734. this.setData({
  735. timeSelectShow: true
  736. });
  737. },
  738. bindTimeSelectClose() {
  739. this.setData({
  740. timeSelectShow: false
  741. });
  742. },
  743. bindStopPopupOpen() {
  744. this.setData({
  745. trackStopPopupShow: true
  746. });
  747. },
  748. bindStopPopupClose() {
  749. this.setData({
  750. trackStopPopupShow: false
  751. });
  752. },
  753. MoveToStop(event) {
  754. var map = uni.createMapContext('myMap');
  755. this.setData({
  756. latitude: event.currentTarget.dataset.p.latitude,
  757. longitude: event.currentTarget.dataset.p.longitude
  758. });
  759. /*map.moveToLocation({
  760. latitude: event.currentTarget.dataset.p.latitude,
  761. longitude: event.currentTarget.dataset.p.longitude
  762. })*/
  763. },
  764. bindAlarmPopupOpen() {
  765. this.setData({
  766. alarmPopupShow: true
  767. });
  768. },
  769. bindAlarmPopupClose() {
  770. this.setData({
  771. alarmPopupShow: false
  772. });
  773. this.setData({
  774. alarmMarker: []
  775. });
  776. this.setMarkers();
  777. },
  778. MoveToAlarm(event) {
  779. var map = uni.createMapContext('myMap');
  780. var alarmMarker = [
  781. {
  782. id: 0,
  783. latitude: event.currentTarget.dataset.p.latitude,
  784. longitude: event.currentTarget.dataset.p.longitude,
  785. name: '',
  786. iconPath: '/static/resource/images/alarm.png',
  787. width: 28,
  788. height: 35,
  789. zIndex: 10,
  790. callout: {
  791. content:
  792. event.currentTarget.dataset.p.alarm_desc +
  793. '\n' +
  794. '时间: ' +
  795. event.currentTarget.dataset.p.formatTime +
  796. '\n' +
  797. '速度: ' +
  798. event.currentTarget.dataset.p.speed +
  799. '公里/小时\n' +
  800. event.currentTarget.dataset.p.ps +
  801. '\n',
  802. padding: 10,
  803. borderRadius: 4,
  804. boxShadow: '4px 8px 16px 0 rgba(0,0,0,0.3)',
  805. display: 'ALWAYS'
  806. }
  807. }
  808. ];
  809. this.setData({
  810. alarmMarker: alarmMarker,
  811. latitude: event.currentTarget.dataset.p.latitude,
  812. longitude: event.currentTarget.dataset.p.longitude
  813. });
  814. this.setMarkers();
  815. },
  816. playLoop() {
  817. if (this.nowPlayIndex >= this.trackPoints.length - 1) {
  818. this.setData({
  819. inPlay: false
  820. });
  821. clearInterval(this.playTimer);
  822. return;
  823. }
  824. this.setData({
  825. showInfo: false
  826. });
  827. var map = uni.createMapContext('myMap');
  828. var leng = Math.sqrt(
  829. Math.pow(Math.abs(this.trackPoints[this.nowPlayIndex + 1].longitude - this.trackPoints[this.nowPlayIndex].longitude) * 111, 2) +
  830. Math.pow(
  831. Math.abs(this.trackPoints[this.nowPlayIndex + 1].latitude - this.trackPoints[this.nowPlayIndex].latitude) *
  832. 111 *
  833. Math.cos(((2 * Math.PI) / 360) * this.trackPoints[this.nowPlayIndex].latitude),
  834. 2
  835. )
  836. );
  837. while (leng < 0.1 && this.nowPlayIndex < this.trackPoints.length - 1) {
  838. leng += Math.sqrt(
  839. Math.pow(Math.abs(this.trackPoints[this.nowPlayIndex + 1].longitude - this.trackPoints[this.nowPlayIndex].longitude) * 111, 2) +
  840. Math.pow(
  841. Math.abs(this.trackPoints[this.nowPlayIndex + 1].latitude - this.trackPoints[this.nowPlayIndex].latitude) *
  842. 111 *
  843. Math.cos(((2 * Math.PI) / 360) * this.trackPoints[this.nowPlayIndex].latitude),
  844. 2
  845. )
  846. );
  847. this.nowPlayIndex = this.nowPlayIndex + 1;
  848. }
  849. var rotate =
  850. (Math.atan(
  851. (this.trackPoints[this.nowPlayIndex + 1].longitude - this.trackPoints[this.nowPlayIndex].longitude) /
  852. (this.trackPoints[this.nowPlayIndex + 1].latitude - this.trackPoints[this.nowPlayIndex].latitude) /
  853. Math.cos(((2 * Math.PI) / 360) * this.trackPoints[this.nowPlayIndex].latitude)
  854. ) *
  855. 180) /
  856. Math.PI;
  857. if (rotate === NaN) {
  858. if (this.trackPoints[this.nowPlayIndex + 1].longitude - this.trackPoints[this.nowPlayIndex].longitude > 0) {
  859. rotate = 90;
  860. } else {
  861. rotate = 270;
  862. }
  863. } else if (this.trackPoints[this.nowPlayIndex + 1].latitude - this.trackPoints[this.nowPlayIndex].latitude < 0) {
  864. rotate = 180 + rotate;
  865. } else if (this.trackPoints[this.nowPlayIndex + 1].longitude - this.trackPoints[this.nowPlayIndex].longitude < 0) {
  866. rotate = 360 + rotate;
  867. }
  868. /*var r = this.data.playMarkerRotate - rotate
  869. if (r > 0) {
  870. r = 360 + r
  871. }
  872. map.translateMarker({
  873. markerId: -1,
  874. destination: {
  875. latitude: this.data.trackPoints[this.data.nowPlayIndex].latitude,
  876. longitude: this.data.trackPoints[this.data.nowPlayIndex].longitude,
  877. },
  878. autoRotate: true,
  879. rotate: r,
  880. duration: 0
  881. })*/
  882. //this.setPolylines()
  883. //if (this.data.playMarker.length == 0) {
  884. var playMarker = [
  885. {
  886. id: -1,
  887. latitude: this.trackPoints[this.nowPlayIndex].latitude,
  888. longitude: this.trackPoints[this.nowPlayIndex].longitude,
  889. //rotate: rotate,
  890. name: '',
  891. iconPath: '/static/resource/images/1.gif',
  892. width: 35,
  893. height: 35,
  894. zIndex: 20,
  895. callout: {
  896. content:
  897. '电压: ' +
  898. this.trackPoints[this.nowPlayIndex].voltage +
  899. '\n' +
  900. '速度: ' +
  901. this.trackPoints[this.nowPlayIndex].speed +
  902. 'km/小时\n' +
  903. '时间: ' +
  904. this.trackPoints[this.nowPlayIndex].time +
  905. '\n' +
  906. '里程: ' +
  907. this.trackPoints[this.nowPlayIndex].mileage +
  908. '公里\n',
  909. padding: 10,
  910. borderRadius: 4,
  911. boxShadow: '4px 8px 16px 0 rgba(0,0,0,0.3)',
  912. display: 'ALWAYS'
  913. }
  914. //anchor: { x: .5, y: .5 }
  915. }
  916. ];
  917. this.playMarker = playMarker;
  918. this.setMarkers();
  919. /*} else {
  920. map.translateMarker({
  921. markerId: -1,
  922. destination: {
  923. latitude: this.data.trackPoints[this.data.nowPlayIndex].latitude,
  924. longitude: this.data.trackPoints[this.data.nowPlayIndex].longitude,
  925. },
  926. autoRotate: false,
  927. rotate: 0,
  928. duration: 100
  929. })
  930. }*/
  931. this.setData({
  932. latitude: this.trackPoints[this.nowPlayIndex].latitude,
  933. longitude: this.trackPoints[this.nowPlayIndex].longitude,
  934. nowPlayIndex: this.nowPlayIndex + 1
  935. //playMarkerRotate: rotate,
  936. });
  937. },
  938. bindPlay() {
  939. if (this.inPlay) {
  940. this.setData({
  941. inPlay: false
  942. });
  943. const me = this;
  944. clearInterval(this.playTimer);
  945. if (me.playMarker.length > 0) {
  946. const pData = {
  947. lng: me.playMarker[0].longitude,
  948. lat: me.playMarker[0].latitude,
  949. pi: 'wx_deviceLocal'
  950. };
  951. const me = this;
  952. http.postApi(config.API_MAP_REGEO, pData, function (resp) {
  953. if (resp.data.code === 200) {
  954. var jsonData = resp.data.data.data;
  955. if (jsonData.code === 0) {
  956. const address = jsonData.address;
  957. var ps = '';
  958. let tmp_addr = '地址: ' + address;
  959. while (tmp_addr.length > 15) {
  960. ps += tmp_addr.substring(0, 15) + '\n';
  961. tmp_addr = tmp_addr.substring(15);
  962. }
  963. ps += tmp_addr;
  964. var playMark = me.playMarker;
  965. playMark[0].callout.content += ps;
  966. me.setData({
  967. playMarker: playMark
  968. });
  969. me.setMarkers();
  970. }
  971. }
  972. });
  973. // qqmapsdk.reverseGeocoder({
  974. // location: {
  975. // latitude: me.data.playMarker[0].latitude,
  976. // longitude: me.data.playMarker[0].longitude
  977. // },
  978. // success: function (res) {
  979. // const formatted_addresses = res.result.formatted_addresses
  980. // const address = res.result.address
  981. // let ps = '';
  982. // let tmp_addr = '地址: ' + address
  983. // while (tmp_addr.length > 15) {
  984. // ps += tmp_addr.substring(0, 15) + "\n";
  985. // tmp_addr = tmp_addr.substring(15);
  986. // }
  987. // ps += tmp_addr
  988. // var playMark = me.data.playMarker
  989. // playMark[0].callout.content += ps
  990. // me.setData({
  991. // playMarker: playMark
  992. // })
  993. // me.setMarkers()
  994. // }
  995. // })
  996. }
  997. } else {
  998. if (this.nowPlayIndex >= this.trackPoints.length - 1) {
  999. this.setData({
  1000. nowPlayIndex: 0
  1001. });
  1002. }
  1003. this.setData({
  1004. inPlay: true
  1005. });
  1006. this.playTimer = setInterval(this.playLoop, this.speedTime);
  1007. }
  1008. },
  1009. // bindGPSLocation(){
  1010. // this.setData({
  1011. // isShowGPS:true
  1012. // })
  1013. // this.locationLoop(true)
  1014. // },
  1015. locationLoop(init = false) {
  1016. const me = this;
  1017. const deviceInfo = storage.getSelectedDeviceInfo();
  1018. if (deviceInfo) {
  1019. //common.loading()
  1020. http.postApi(
  1021. config.API_GPS_INFO,
  1022. {
  1023. macid: deviceInfo.mac_id
  1024. },
  1025. (resp) => {
  1026. //wx.hideLoading()
  1027. if (resp.data.code === 200) {
  1028. let status;
  1029. let stat = '';
  1030. if (parseInt(resp.data.data.info.online) === 1) {
  1031. if (parseInt(resp.data.data.info.speed) === 0) {
  1032. status = '静止(' + common.formatSeconds(resp.data.data.info.heart_time - resp.data.data.info.gps_time, false) + ')';
  1033. stat = 'static';
  1034. } else {
  1035. status = '行驶(' + resp.data.data.info.speed + 'Km/h)';
  1036. stat = 'running';
  1037. }
  1038. } else {
  1039. status =
  1040. '离线(' +
  1041. common.formatSeconds(
  1042. new Date().getTime() / 1000 -
  1043. (resp.data.data.info.heart_time === undefined ? resp.data.data.info.gps_time : resp.data.data.info.heart_time),
  1044. false
  1045. ) +
  1046. ')';
  1047. stat = 'offline';
  1048. }
  1049. if (init) {
  1050. this.setData({
  1051. longitude: resp.data.data.info.longitude,
  1052. latitude: resp.data.data.info.latitude
  1053. });
  1054. }
  1055. var device_info = resp.data.data.info;
  1056. this.setData({
  1057. locationType: device_info.signalType
  1058. });
  1059. this.setData({
  1060. macid: deviceInfo.mac_id,
  1061. deviceInfo: resp.data.data.info,
  1062. gps: resp.data.data.info.gpscount,
  1063. gsm: parseInt(resp.data.data.info.online) === 0 ? 0 : resp.data.data.info.gsmlevel <= 15 ? 3 : resp.data.data.info.gsmlevel > 18 ? 5 : 4,
  1064. status: status,
  1065. deviceMarker: [
  1066. {
  1067. id: 1,
  1068. latitude: resp.data.data.info.latitude,
  1069. longitude: resp.data.data.info.longitude,
  1070. name: '',
  1071. iconPath: this.iconList[resp.data.data.info.icon] ? this.iconList[resp.data.data.info.icon][stat] : '/static/resource/images/weizhi2.png',
  1072. width: 35,
  1073. height: 35,
  1074. zIndex: 10
  1075. }
  1076. ],
  1077. circles: [
  1078. {
  1079. latitude: resp.data.data.info.latitude,
  1080. longitude: resp.data.data.info.longitude,
  1081. color: '#6495ED1F',
  1082. fillColor: '#6495ED1F',
  1083. radius: 1000,
  1084. strokeWidth: 1
  1085. }
  1086. ]
  1087. });
  1088. this.setMarkers();
  1089. if (
  1090. this.trace &&
  1091. (this.tracePoints.length == 0 ||
  1092. this.tracePoints[this.tracePoints.length - 1].latitude != resp.data.data.info.latitude ||
  1093. this.tracePoints[this.tracePoints.length - 1].longitude != resp.data.data.info.longitude)
  1094. ) {
  1095. this.tracePoints.push({
  1096. latitude: resp.data.data.info.latitude,
  1097. longitude: resp.data.data.info.longitude
  1098. });
  1099. this.setPolylines();
  1100. this.setData({
  1101. latitude: resp.data.data.info.latitude,
  1102. longitude: resp.data.data.info.longitude
  1103. });
  1104. }
  1105. console.log(resp.data.data.info);
  1106. console.log(this.batteryWidth);
  1107. // qqmapsdk.reverseGeocoder({
  1108. // location: {
  1109. // latitude: resp.data.data.info.latitude,
  1110. // longitude: resp.data.data.info.longitude
  1111. // },
  1112. // success: function (res) {
  1113. // console.log(res)
  1114. // const formatted_addresses = res.result.formatted_addresses
  1115. // const address = res.result.address //+ formatted_addresses.recommend
  1116. // console.log("location")
  1117. // console.log(address)
  1118. // me.setData({
  1119. // address: address,
  1120. // locationAdress: address
  1121. // })
  1122. // }
  1123. // })
  1124. const pData = {
  1125. lng: resp.data.data.info.longitude,
  1126. lat: resp.data.data.info.latitude,
  1127. pi: 'wx_deviceLocal'
  1128. };
  1129. const me = this;
  1130. http.postApi(config.API_MAP_REGEO, pData, function (resp) {
  1131. if (resp.data.code === 200) {
  1132. var jsonData = resp.data.data.data;
  1133. if (jsonData.code === 0) {
  1134. me.setData({
  1135. address: jsonData.address,
  1136. locationAdress: jsonData.address
  1137. });
  1138. }
  1139. }
  1140. });
  1141. } else {
  1142. common.simpleToast(resp.data.msg);
  1143. clearInterval(this.locationTimer);
  1144. setTimeout(function () {
  1145. uni.navigateBack({
  1146. delta: 1
  1147. });
  1148. }, 1500);
  1149. }
  1150. }
  1151. );
  1152. }
  1153. },
  1154. isEmptyObject(obj) {
  1155. for (var key in obj) {
  1156. return false;
  1157. }
  1158. return true;
  1159. },
  1160. loadLastGpsInfo() {
  1161. var init = true;
  1162. const me = this;
  1163. console.log('xxxxx');
  1164. const deviceInfo = storage.getSelectedDeviceInfo();
  1165. if (deviceInfo) {
  1166. http.postApi(
  1167. config.API_GPS_INFO,
  1168. {
  1169. macid: deviceInfo.mac_id
  1170. },
  1171. (resp) => {
  1172. if (resp.data.code === 200) {
  1173. console.log('11111');
  1174. if (this.isEmptyObject(resp.data.data.info.last_location)) {
  1175. common.simpleToast('当前设备没有GPS坐标');
  1176. return;
  1177. }
  1178. // var last_location = resp.data.data.info.last_location
  1179. // last_location.lng = 121.19023414159073
  1180. // last_location.lat = 31.390001627411883
  1181. // resp.data.data.info.last_location = last_location
  1182. let status;
  1183. let stat = '';
  1184. if (parseInt(resp.data.data.info.online) === 1) {
  1185. if (parseInt(resp.data.data.info.speed) === 0) {
  1186. status = '静止(' + common.formatSeconds(resp.data.data.info.heart_time - resp.data.data.info.gps_time, false) + ')';
  1187. stat = 'static';
  1188. } else {
  1189. status = '行驶(' + resp.data.data.info.speed + 'Km/h)';
  1190. stat = 'running';
  1191. }
  1192. } else {
  1193. status =
  1194. '离线(' +
  1195. common.formatSeconds(
  1196. new Date().getTime() / 1000 -
  1197. (resp.data.data.info.heart_time === undefined ? resp.data.data.info.gps_time : resp.data.data.info.heart_time),
  1198. false
  1199. ) +
  1200. ')';
  1201. stat = 'offline';
  1202. }
  1203. if (init) {
  1204. this.setData({
  1205. longitude: resp.data.data.info.last_location.lng,
  1206. latitude: resp.data.data.info.last_location.lat
  1207. });
  1208. }
  1209. var device_info = resp.data.data.info;
  1210. device_info.signalType = '0';
  1211. this.setData({
  1212. locationGpsType: device_info.signalType
  1213. });
  1214. var device_marker = {
  1215. id: 2,
  1216. latitude: resp.data.data.info.last_location.lat,
  1217. longitude: resp.data.data.info.last_location.lng,
  1218. name: '',
  1219. iconPath: this.iconList[resp.data.data.info.icon] ? this.iconList[resp.data.data.info.icon][stat] : '/static/resource/images/weizhi2.png',
  1220. width: 35,
  1221. height: 35,
  1222. zIndex: 10
  1223. };
  1224. // this.setData({
  1225. // marker: this.data.marker.concat(device_marker)
  1226. // })
  1227. this.setData({
  1228. gpsMarker: [device_marker]
  1229. });
  1230. this.setData({
  1231. marker: this.gpsMarker.concat(this.trackMarker, this.alarmMarker, this.playMarker, this.deviceMarker)
  1232. });
  1233. // this.setData({
  1234. // marker: this.data.deviceMarker.concat(this.data.trackMarker, this.data.alarmMarker, this.data.playMarker)
  1235. // })
  1236. console.log('marker');
  1237. console.log(this.marker);
  1238. //this.data.deviceMarker.concat(this.data.trackMarker, this.data.alarmMarker, this.data.playMarker)
  1239. this.setData({
  1240. macid: deviceInfo.mac_id,
  1241. deviceInfo: device_info,
  1242. gps: resp.data.data.info.gpscount,
  1243. gsm: parseInt(resp.data.data.info.online) === 0 ? 0 : resp.data.data.info.gsmlevel <= 15 ? 3 : resp.data.data.info.gsmlevel > 18 ? 5 : 4,
  1244. status: status,
  1245. deviceMarker: [device_marker],
  1246. circles: [
  1247. {
  1248. latitude: resp.data.data.info.last_location.lat,
  1249. longitude: resp.data.data.info.last_location.lng,
  1250. color: '#6495ED1F',
  1251. fillColor: '#6495ED1F',
  1252. radius: 1000,
  1253. strokeWidth: 1
  1254. }
  1255. ]
  1256. });
  1257. //this.setMarkers()
  1258. // this.setData({
  1259. // marker: this.data.deviceMarker.concat(this.data.deviceMarker)
  1260. // })
  1261. console.log(resp.data.data.info);
  1262. this.setData({
  1263. batteryWidth: parseInt((this.deviceInfo.quantity / 100) * 37)
  1264. });
  1265. console.log(this.batteryWidth);
  1266. const me = this;
  1267. const pData = {
  1268. lng: resp.data.data.info.last_location.lng,
  1269. lat: resp.data.data.info.last_location.lat,
  1270. pi: 'wx_deviceLocal'
  1271. };
  1272. http.postApi(config.API_MAP_REGEO, pData, function (resp) {
  1273. if (resp.data.code === 200) {
  1274. var jsonData = resp.data.data.data;
  1275. if (jsonData.code === 0) {
  1276. const address = jsonData.address;
  1277. me.setData({
  1278. address: address,
  1279. locationGpsAdress: address
  1280. });
  1281. }
  1282. }
  1283. });
  1284. // qqmapsdk.reverseGeocoder({
  1285. // location: {
  1286. // latitude: resp.data.data.info.last_location.lat,
  1287. // longitude: resp.data.data.info.last_location.lng
  1288. // },
  1289. // success: function (res) {
  1290. // console.log(res)
  1291. // const formatted_addresses = res.result.formatted_addresses
  1292. // const address = res.result.address //+ formatted_addresses.recommend
  1293. // console.log("last_location")
  1294. // console.log(address)
  1295. // me.setData({
  1296. // address: address,
  1297. // locationGpsAdress: address
  1298. // })
  1299. // }
  1300. // })
  1301. } else {
  1302. common.simpleToast(resp.data.msg);
  1303. clearInterval(this.locationTimer);
  1304. setTimeout(function () {
  1305. uni.navigateBack({
  1306. delta: 1
  1307. });
  1308. }, 1500);
  1309. }
  1310. }
  1311. );
  1312. }
  1313. },
  1314. bindMarkertap(e) {
  1315. if (e.markerId == 1 || e.markerId == 2) {
  1316. if (e.markerId == 1) {
  1317. var deviceInfo = this.deviceInfo;
  1318. deviceInfo.signalType = this.locationType;
  1319. this.setData({
  1320. deviceInfo: deviceInfo,
  1321. address: this.locationAdress
  1322. });
  1323. }
  1324. if (e.markerId == 2) {
  1325. var deviceInfo = this.deviceInfo;
  1326. deviceInfo.signalType = this.locationGpsType;
  1327. this.setData({
  1328. deviceInfo: deviceInfo,
  1329. address: this.locationGpsAdress
  1330. });
  1331. }
  1332. this.setData({
  1333. showInfo: !this.showInfo
  1334. });
  1335. }
  1336. },
  1337. bindTapMap(e) {
  1338. this.setData({
  1339. showInfo: false
  1340. });
  1341. if (this.selectFence != null) {
  1342. var fence = this.selectFence;
  1343. fence.latitude = e.detail.latitude;
  1344. fence.longitude = e.detail.longitude;
  1345. this.setData({
  1346. selectFence: fence,
  1347. circles: [
  1348. {
  1349. latitude: fence.latitude,
  1350. longitude: fence.longitude,
  1351. radius: parseInt(fence.radius),
  1352. color: '#6495ED1F',
  1353. fillColor: '#6495ED1F',
  1354. strokeWidth: 1
  1355. }
  1356. ]
  1357. });
  1358. }
  1359. },
  1360. bindSendCommand: function (e) {
  1361. this.sendCommand(e.currentTarget.dataset.cmd);
  1362. },
  1363. sendCommand: function (cmd) {
  1364. uni.showModal({
  1365. content: '确定发送指令吗?',
  1366. showCancel: true,
  1367. cancelText: '取消',
  1368. confirmText: '确定',
  1369. success: (res) => {
  1370. console.log(res);
  1371. if (res.confirm) {
  1372. common.loading();
  1373. http.postApi(
  1374. config.API_BATTERY_SEND_COMMAND,
  1375. {
  1376. macid: this.macid,
  1377. cmd: cmd
  1378. },
  1379. function (resp) {
  1380. if (resp.data.code === 200) {
  1381. uni.hideLoading();
  1382. common.simpleToast('操作成功');
  1383. } else {
  1384. common.simpleToast(resp.data.msg);
  1385. }
  1386. }
  1387. );
  1388. }
  1389. },
  1390. fail: function (res) {},
  1391. complete: function (res) {}
  1392. });
  1393. },
  1394. bindTrace() {
  1395. if (this.trace) {
  1396. this.setData({
  1397. trace: false,
  1398. tracePoints: []
  1399. });
  1400. this.setPolylines();
  1401. clearInterval(this.traceTimer);
  1402. } else {
  1403. this.setData({
  1404. trace: true
  1405. });
  1406. this.traceTimer = setInterval(() => {
  1407. this.setData({
  1408. traceTime: this.traceTime + 1
  1409. });
  1410. }, 1000);
  1411. }
  1412. },
  1413. bindNavigate() {
  1414. //使用微信内置地图查看标记点位置,并进行导航
  1415. /*
  1416. console.log(this.data.longitude);
  1417. console.log(this.data.latitude);
  1418. console.log(this.data.longitude_my);
  1419. console.log(this.data.latitude_my);
  1420. */
  1421. const latitude = this.latitude;
  1422. const longitude = this.longitude;
  1423. uni.openLocation({
  1424. latitude,
  1425. //要去的纬度-地址
  1426. longitude,
  1427. //要去的经度-地址
  1428. scale: 11
  1429. });
  1430. },
  1431. bindCloseTrack() {
  1432. this.setData({
  1433. trackPoints: [],
  1434. trackMarker: [],
  1435. trackStopList: [],
  1436. nowPlayIndex: 0,
  1437. playMarker: []
  1438. });
  1439. this.setMarkers();
  1440. this.setPolylines();
  1441. },
  1442. bindFencePopupOpen() {
  1443. this.setData({
  1444. fencePopupShow: true
  1445. });
  1446. },
  1447. bindFencePopupClose() {
  1448. this.setData({
  1449. fencePopupShow: false
  1450. });
  1451. },
  1452. MoveToFence(event) {
  1453. var map = uni.createMapContext('myMap');
  1454. const fence = Object.assign({}, event.currentTarget.dataset.p);
  1455. this.setData({
  1456. selectFence: fence,
  1457. circles: [
  1458. {
  1459. latitude: fence.latitude,
  1460. longitude: fence.longitude,
  1461. radius: parseInt(fence.radius),
  1462. color: '#6495ED1F',
  1463. fillColor: '#6495ED1F',
  1464. strokeWidth: 1
  1465. }
  1466. ],
  1467. fencePopupShow: false,
  1468. latitude: fence.latitude,
  1469. longitude: fence.longitude
  1470. });
  1471. /*map.moveToLocation({
  1472. latitude: event.currentTarget.dataset.p.latitude,
  1473. longitude: event.currentTarget.dataset.p.longitude
  1474. })*/
  1475. },
  1476. addFence() {
  1477. var map = uni.createMapContext('myMap');
  1478. map.getCenterLocation({
  1479. success: (res) => {
  1480. const fence = {
  1481. name: '',
  1482. type: '0',
  1483. latitude: res.latitude,
  1484. longitude: res.longitude,
  1485. radius: 100
  1486. };
  1487. this.setData({
  1488. selectFence: fence,
  1489. circles: [
  1490. {
  1491. latitude: fence.latitude,
  1492. longitude: fence.longitude,
  1493. radius: parseInt(fence.radius),
  1494. color: '#6495ED1F',
  1495. fillColor: '#6495ED1F',
  1496. strokeWidth: 1
  1497. }
  1498. ],
  1499. fencePopupShow: false
  1500. });
  1501. }
  1502. });
  1503. },
  1504. loadFenceList() {
  1505. common.loading();
  1506. const deviceInfo = storage.getSelectedDeviceInfo();
  1507. http.postApi(
  1508. config.API_FENCE_LIST,
  1509. {
  1510. macid: deviceInfo.mac_id
  1511. },
  1512. (resp) => {
  1513. uni.hideLoading();
  1514. if (resp.data.code === 200) {
  1515. var fenceList = resp.data.data.list;
  1516. this.setData({
  1517. fenceList: fenceList
  1518. });
  1519. } else {
  1520. common.simpleToast(resp.data.msg);
  1521. }
  1522. }
  1523. );
  1524. },
  1525. bindFenceClose() {
  1526. this.setData({
  1527. selectFence: null,
  1528. circles: [],
  1529. fencePopupShow: true
  1530. });
  1531. },
  1532. onFenceNameChange(e) {
  1533. var fence = this.selectFence;
  1534. fence.name = e.detail.value;
  1535. this.setData({
  1536. selectFence: fence
  1537. });
  1538. },
  1539. onFenceTypeChange(e) {
  1540. var fence = this.selectFence;
  1541. fence.type = e.detail;
  1542. this.setData({
  1543. selectFence: fence
  1544. });
  1545. },
  1546. onFenceRadiusDrag(e) {
  1547. var fence = this.selectFence;
  1548. fence.radius = e.detail.value;
  1549. this.setData({
  1550. selectFence: fence
  1551. /*circles: [{
  1552. latitude: fence.latitude,
  1553. longitude: fence.longitude,
  1554. radius: parseInt(fence.radius),
  1555. color: '#6495EDBB',
  1556. fillColor: '#6495ED1F',
  1557. strokeWidth: 1
  1558. }],*/
  1559. });
  1560. },
  1561. onFenceRadiusChange(e) {
  1562. var fence = this.selectFence;
  1563. fence.radius = e.detail.value;
  1564. // this.setData({circles:[]})
  1565. var startSlide = new Date().getTime();
  1566. if (startSlide - this.endSlide > 100) {
  1567. this.setData({
  1568. endSlide: startSlide
  1569. });
  1570. this.setData({
  1571. selectFence: fence,
  1572. circles: [
  1573. {
  1574. latitude: fence.latitude,
  1575. longitude: fence.longitude,
  1576. radius: parseInt(fence.radius),
  1577. color: '#6495ED1F',
  1578. fillColor: '#6495ED1F',
  1579. strokeWidth: 1
  1580. }
  1581. ]
  1582. });
  1583. }
  1584. },
  1585. onFenceRadiusMinus() {
  1586. var fence = this.selectFence;
  1587. if (fence.radius > 1) {
  1588. fence.radius = parseInt(fence.radius) - 100;
  1589. this.setData({
  1590. selectFence: fence,
  1591. circles: [
  1592. {
  1593. latitude: fence.latitude,
  1594. longitude: fence.longitude,
  1595. radius: parseInt(fence.radius),
  1596. color: '#6495ED1F',
  1597. fillColor: '#6495ED1F',
  1598. strokeWidth: 1
  1599. }
  1600. ]
  1601. });
  1602. }
  1603. },
  1604. onFenceRadiusPlus() {
  1605. var fence = this.selectFence;
  1606. if (fence.radius < 10000) {
  1607. fence.radius = parseInt(fence.radius) + 100;
  1608. this.setData({
  1609. selectFence: fence,
  1610. circles: [
  1611. {
  1612. latitude: fence.latitude,
  1613. longitude: fence.longitude,
  1614. radius: parseInt(fence.radius),
  1615. color: '#6495ED1F',
  1616. fillColor: '#6495ED1F',
  1617. strokeWidth: 1
  1618. }
  1619. ]
  1620. });
  1621. }
  1622. },
  1623. bindFenceSave() {
  1624. var fence = this.selectFence;
  1625. if (!fence.name) {
  1626. common.simpleToast('请输入围栏名称');
  1627. return;
  1628. }
  1629. if (fence != null) {
  1630. common.loading();
  1631. const deviceInfo = storage.getSelectedDeviceInfo();
  1632. if (fence.id) {
  1633. http.postApi(
  1634. config.API_FENCE_EDIT,
  1635. Object.assign(
  1636. {
  1637. macid: deviceInfo.mac_id
  1638. },
  1639. fence
  1640. ),
  1641. (resp) => {
  1642. uni.hideLoading();
  1643. if (resp.data.code === 200) {
  1644. this.loadFenceList();
  1645. } else {
  1646. common.simpleToast(resp.data.msg);
  1647. }
  1648. this.setData({
  1649. selectFence: null,
  1650. circles: [],
  1651. fencePopupShow: true
  1652. });
  1653. }
  1654. );
  1655. } else {
  1656. http.postApi(
  1657. config.API_FENCE_ADD,
  1658. Object.assign(
  1659. {
  1660. macid: deviceInfo.mac_id
  1661. },
  1662. fence
  1663. ),
  1664. (resp) => {
  1665. uni.hideLoading();
  1666. if (resp.data.code === 200) {
  1667. this.loadFenceList();
  1668. } else {
  1669. common.simpleToast(resp.data.msg);
  1670. }
  1671. this.setData({
  1672. selectFence: null,
  1673. circles: [],
  1674. fencePopupShow: true
  1675. });
  1676. }
  1677. );
  1678. }
  1679. }
  1680. },
  1681. delFence() {
  1682. var fence = this.selectFence;
  1683. if (fence != null && fence.id) {
  1684. common.loading();
  1685. const deviceInfo = storage.getSelectedDeviceInfo();
  1686. http.postApi(
  1687. config.API_FENCE_DEL,
  1688. {
  1689. macid: deviceInfo.mac_id,
  1690. id: fence.id
  1691. },
  1692. (resp) => {
  1693. uni.hideLoading();
  1694. if (resp.data.code === 200) {
  1695. this.loadFenceList();
  1696. } else {
  1697. common.simpleToast(resp.data.msg);
  1698. }
  1699. this.setData({
  1700. selectFence: null,
  1701. circles: [],
  1702. fencePopupShow: true
  1703. });
  1704. }
  1705. );
  1706. }
  1707. },
  1708. moveToLocation: function () {
  1709. //console.log('move to')
  1710. this.mapCtx.moveToLocation();
  1711. //this.setData({ showShopInfo: false, scale: 14 })
  1712. },
  1713. mapChange: function (e) {
  1714. this.setData({
  1715. mapParams: e.detail.mapParams
  1716. });
  1717. }
  1718. }
  1719. };