amap.js 33 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534
  1. (function () {
  2. var infoWindow;
  3. var lnglat;
  4. var mainMap;
  5. var getVehicleData;
  6. var vehicleMarker;
  7. var overlayData;
  8. var vehicleMarker;
  9. var circle;
  10. var userInfo;
  11. var page = {
  12. init: function ($page) {
  13. userInfo = renlian.storage.get('userinfo');
  14. //初始化顶部导航栏
  15. function init_nav(){
  16. var _html = '';
  17. _html += '<div class="my">';
  18. _html += '<i class="iconfont icon-people"></i>';
  19. _html += '</div>';
  20. /*
  21. _html += '\
  22. <div class="searchBox">\
  23. <i class="iconfont icon-search"></i>\
  24. <div class="search" >搜索应用</div>\
  25. </div>';
  26. */
  27. _html += '\
  28. <div class="f-page-title alarm">\
  29. <button id="alarm-110" type="button" class="lr-btn" style="font-size:16px;line-height:1;color:#0c86d8;">\
  30. 110丢失报警\
  31. </button>\
  32. </div>';
  33. _html += '<div class="chart">';
  34. _html += '<i class="iconfont icon-rank"></i>';
  35. _html += '</div>';
  36. _html += '<div class="message">';
  37. _html += '<i class="iconfont icon-community"></i>';
  38. _html += '<span class="red"></span>';
  39. _html += '</div>';
  40. // $page.parent().find('.f-page-header').addClass('lr-workspace-header').html(_html);
  41. $('.f-page-header').addClass('lr-workspace-header').html(_html);
  42. /*
  43. // 点击搜索框
  44. $page.parent().find('.searchBox').on('tap', function () {
  45. renlian.nav.go({ path: 'workspace/search', title: '', isBack: true, isHead: true });
  46. });
  47. */
  48. // 点击报警
  49. // $page.parent().find('.alarm').on('tap', function () {
  50. // renlian.nav.go({ path: 'baojingindex', title: '110丢失报警', isBack: true, isHead: true,type:'right' });
  51. // if(infoWindow){infoWindow.close( );}
  52. // });
  53. // // 点击图表
  54. // $page.parent().find('.chart').on('tap', function () {
  55. // renlian.nav.go({ path: 'tongji', title: '统计', isBack: true, isHead: true,type:'right' });
  56. // if(infoWindow){infoWindow.close( );}
  57. // });
  58. // // 点击消息图标
  59. // $page.parent().find('.message').on('tap', function () {
  60. // renlian.nav.go({ path: 'baojinginfo', title: '消息', isBack: true, isHead: true,type:'right' });
  61. // if(infoWindow){infoWindow.close( );}
  62. // });
  63. // $page.parent().find('.my').on('tap', function () {
  64. // renlian.nav.go({ path: 'my', title: '我的', isBack: true, isHead: true,type:'right' });
  65. // if(infoWindow){infoWindow.close( );}
  66. // });
  67. // // 注册扫描
  68. // $page.parent().find('.scanner').on('tap', function () {
  69. // renlian.code.scan(function (res) {
  70. // if (res.status === 'success') {
  71. // renlian.layer.toast(res.msg);
  72. // }
  73. // else {
  74. // renlian.layer.toast('扫描失败:' + res.msg);
  75. // }
  76. // });
  77. // });
  78. $('.lr-btn').on('tap', function () {
  79. renlian.nav.go({ path: 'baojingindex', title: '110丢失报警', isBack: true, isHead: true,type:'right' });
  80. if(infoWindow){infoWindow.close( );}
  81. });
  82. // 点击图表
  83. $('.chart').on('tap', function () {
  84. renlian.nav.go({ path: 'tongji', title: '统计', isBack: true, isHead: true,type:'right' });
  85. if(infoWindow){infoWindow.close( );}
  86. });
  87. // 点击消息图标
  88. $('.message').on('tap', function () {
  89. renlian.nav.go({ path: 'baojinginfo', title: '消息', isBack: true, isHead: true,type:'right' });
  90. if(infoWindow){infoWindow.close( );}
  91. });
  92. $('.my').on('tap', function () {
  93. renlian.nav.go({ path: 'my', title: '我的', isBack: true, isHead: true,type:'right' });
  94. if(infoWindow){infoWindow.close( );}
  95. });
  96. // 注册扫描
  97. $('.scanner').on('tap', function () {
  98. renlian.code.scan(function (res) {
  99. if (res.status === 'success') {
  100. renlian.layer.toast(res.msg);
  101. }
  102. else {
  103. renlian.layer.toast('扫描失败:' + res.msg);
  104. }
  105. });
  106. });
  107. }
  108. //获取手机GPS位置
  109. var locationFlag = true;
  110. function get_mobile_gps_location(onSuccess,onError){
  111. var onSuccess = function(position) {
  112. // alert('Latitude: ' + position.coords.latitude + '\n' +
  113. // 'Longitude: ' + position.coords.longitude + '\n' +
  114. // 'Altitude: ' + position.coords.altitude + '\n' +
  115. // 'Accuracy: ' + position.coords.accuracy + '\n' +
  116. // 'Altitude Accuracy: ' + position.coords.altitudeAccuracy + '\n' +
  117. // 'Heading: ' + position.coords.heading + '\n' +
  118. // 'Speed: ' + position.coords.speed + '\n' +
  119. // 'Timestamp: ' + position.timestamp + '\n');
  120. var lnglat = new AMap.LngLat(position.coords.longitude, position.coords.latitude);
  121. startEnd.start = lnglat;
  122. userMarker.setPosition(lnglat);
  123. userMarker.setMap(mainMap);
  124. if(locationFlag){
  125. if(latlngSign){
  126. mainMap.setFitView([vehicleMarker, userMarker]);
  127. }else{
  128. mainMap.setFitView([userMarker]);
  129. }
  130. locationFlag = false;
  131. }else{
  132. if(latlngSign){
  133. mainMap.setFitView([vehicleMarker]);
  134. }
  135. locationFlag = true;
  136. }
  137. };
  138. // onError Callback receives a PositionError object
  139. //
  140. function onError(error) {
  141. console.log('code: ' + error.code + '\n' +
  142. 'message: ' + error.message + '\n');
  143. }
  144. navigator.geolocation.getCurrentPosition(onSuccess, onError);
  145. }
  146. //上报客户端极光注册信息
  147. function update_jg_registrationid(){
  148. var onGetRegistrationID = function(data) {
  149. try {
  150. if (data.length == 0) {
  151. var t1 = window.setTimeout(getRegistrationID, 1000);
  152. }else{
  153. var post_data = {
  154. "regid":data,
  155. "uid":renlian.storage.get('userinfo').baseinfo.userId
  156. };
  157. renlian.httppost(config.webapi+'?s=api/update_jg_registrationid',post_data,function(res){
  158. });
  159. }
  160. } catch (exception) {
  161. }
  162. };
  163. var getRegistrationID = function() {
  164. window.JPush.getRegistrationID(onGetRegistrationID);
  165. };
  166. window.setTimeout(getRegistrationID, 1000);
  167. }
  168. renlian.layer.loading(true, "加载数据中");
  169. if(window.lrmui.isreal){
  170. //上报用户极光推注册信息
  171. update_jg_registrationid();
  172. //获取手机GPS位置信息
  173. get_mobile_gps_location();
  174. }
  175. init_nav();
  176. //地图
  177. var startEnd = {start: null, end: null};
  178. var fenceCenterVehicle = null;
  179. var routePageData = null;
  180. var userIcon = new AMap.Icon({size: new AMap.Size(23,23), image:'./images/location.png', imageSize:new AMap.Size(23,23)})
  181. var userMarker = new AMap.Marker({icon: userIcon, offset:new AMap.Pixel(-16, -28)});
  182. get_mobile_gps_location();
  183. //车辆信息初始化
  184. var timeInterval = 10000;
  185. //地图初始化
  186. if(!mainMap){
  187. mainMap = new AMap.Map('amapcontainer', {
  188. center: [120.202222,30.184811],
  189. zoom: 15
  190. });
  191. }
  192. mainMap.on('complete', function(){
  193. get_mobile_gps_location();
  194. getVehicleData(overlayData, true);
  195. renlian.layer.loading(false);
  196. });
  197. var bicycleIcon = new AMap.Icon({size: new AMap.Size(32,32), image:'./images/bicycle-2.png', imageSize:new AMap.Size(32,32)})
  198. if(!vehicleMarker){
  199. vehicleMarker = new AMap.Marker({icon:bicycleIcon, offset:new AMap.Pixel(0, -51)});
  200. }
  201. if(!circle){
  202. circle = new AMap.Circle({
  203. radius: 0,
  204. center: [0, 0],
  205. borderWeight: 3,
  206. strokeColor: "#FF33FF",
  207. strokeOpacity: 1,
  208. strokeWeight: 6,
  209. strokeOpacity: 0.2,
  210. fillOpacity: 0.2,
  211. strokeStyle: 'dashed',
  212. strokeDasharray: [10, 10],
  213. // 线样式还支持 'dashed'
  214. fillColor : '#1791fc',
  215. zIndex: 50,
  216. });
  217. }
  218. circle.setMap(mainMap);
  219. if(!overlayData){
  220. overlayData = {map:mainMap, vehicle:vehicleMarker, circle:circle};
  221. }
  222. var latlngSign = null;
  223. var defaultCenter = null;
  224. getVehicleData = function(t, first=false){
  225. var deviceNumber = renlian.storage.get('userinfo').baseinfo['deviceNumber'];
  226. var licensePlate = renlian.storage.get('userinfo').baseinfo.plate;
  227. var gpsNumber = renlian.storage.get('userinfo').baseinfo.gpsNumber;
  228. var mapData = null;
  229. renlian.httpget(config.webapi+"/?s=api/get_map_index_data", {deviceNumber:deviceNumber, licensePlate:licensePlate, gpsNumber:gpsNumber}, function (_res) {
  230. mapData = _res.data;
  231. console.log(mapData);
  232. if(!mapData){
  233. renlian.layer.warning('无地图数据,请检测网络或联系管理员!', function () { }, '提示', '关闭');
  234. return;
  235. }
  236. latlngSign = mapData.vehicleLocation.longitude;
  237. if(!latlngSign){
  238. first = false;
  239. t.map.setZoomAndCenter(15,startEnd.start);
  240. t.vehicle.setPosition(null);
  241. t.vehicle.setMap(null);
  242. }else{
  243. var vehiclePt = new AMap.LngLat(+mapData.vehicleLocation.longitude, +mapData.vehicleLocation.latitude);
  244. defaultCenter = vehiclePt;
  245. startEnd.end = vehiclePt;
  246. fenceCenterVehicle = vehiclePt;
  247. t.vehicle.setPosition(vehiclePt);
  248. t.vehicle.setMap(t.map);
  249. }
  250. if(first){
  251. t.map.setZoomAndCenter(15,vehiclePt);
  252. }
  253. if(!mapData.onlineTime){
  254. $('#battery').html('未获取');
  255. $('#battery').css({color:"gray"});
  256. }else{
  257. if(!mapData.battery){
  258. $('#battery').html('正常');
  259. $('#battery').css({color:"green"});
  260. }else{
  261. $('#battery').html(mapData.battery);
  262. $('#battery').css({color:"red"});
  263. }
  264. }
  265. $(".ract").off("click");
  266. vehicleInfoWin();
  267. //在线状态
  268. if(mapData.onlineTime){
  269. var routeTime = new Date(mapData.onlineTime*1000);
  270. routePageData = {speed: mapData.speed == null ? 0 : mapData.speed, lastTime:routeTime.Format("yyyy-MM-dd hh:mm:ss")};
  271. var interval = parseInt(new Date().getTime()/1000) - mapData.onlineTime;
  272. if(interval < 24*3600){
  273. $('#on-off-online').text('在线中');
  274. $('#on-off-online').css({color:"green"})
  275. }else{
  276. var day = parseInt(interval/24/3600);
  277. $('#on-off-online').text('离线'+day+'天');
  278. $('#on-off-online').css({color:"gray"})
  279. }
  280. }else{
  281. $('#on-off-online').text('未在线过');
  282. $('#on-off-online').css({color:"gray"})
  283. var routeTime = new Date(0);
  284. routePageData = {speed: mapData.speed == null ? 0 : mapData.speed, lastTime:routeTime.Format("yyyy-MM-dd hh:mm:ss")};
  285. }
  286. var fence = mapData.fenceShapeInfo;
  287. if(fence){
  288. fence = JSON.parse(fence);
  289. var fenceInfo = fence.fenceInfo;
  290. if(fenceInfo.type == 'circle'){
  291. t.circle.setCenter(new AMap.LngLat(fenceInfo.data.center.lng, fenceInfo.data.center.lat));
  292. t.circle.setRadius(parseInt(fenceInfo.data.radius));
  293. t.circle.setMap(t.map);
  294. }
  295. }
  296. if(mapData.lockStatus == 1){
  297. $('#lockStatus').removeClass('icon-jiesuo');
  298. $('#lockStatus').addClass('icon-suo');
  299. $('#lock-text').text('解锁');
  300. }else{
  301. $('#lock-text').text('锁车');
  302. }
  303. });
  304. };
  305. //定位
  306. $('#user-location').on('tap', function(){
  307. get_mobile_gps_location();
  308. });
  309. //锁车
  310. $('#car-lock').on('tap', function(){
  311. var lockStatus = $('#lockStatus');
  312. var postData = {
  313. deviceNumber: renlian.storage.get('userinfo').baseinfo.deviceNumber,
  314. lockStatus: lockStatus.hasClass('icon-jiesuo') ? 1 : 0
  315. }
  316. renlian.httppost(config.webapi+'?s=api/change_lock_status',postData,function(res){
  317. if(!res.success){
  318. // renlian.layer.toast('锁车失败');
  319. return;
  320. }
  321. if(lockStatus.hasClass('icon-jiesuo')){
  322. lockStatus.removeClass('icon-jiesuo');
  323. lockStatus.addClass('icon-suo');
  324. $('#lock-text').text('解锁');
  325. // renlian.layer.toast('车辆已锁定');
  326. }else{
  327. lockStatus.removeClass('icon-suo');
  328. lockStatus.addClass('icon-jiesuo');
  329. $('#lock-text').text('锁车');
  330. // renlian.layer.toast('车辆已解锁');
  331. }
  332. });
  333. });
  334. //test
  335. var geocoder;
  336. AMapUI.defineTpl("ui/overlay/SimpleInfoWindow/tpl/container.html", [], function() {
  337. return document.getElementById('my-infowin-tpl').innerHTML;
  338. });
  339. function vehicleInfoWin(){
  340. AMapUI.loadUI(['overlay/SimpleInfoWindow'], function(SimpleInfoWindow) {
  341. lnglat = vehicleMarker.getPosition();
  342. var address = '坐标未解析成功';
  343. if(!geocoder){
  344. geocoder = new AMap.Geocoder({
  345. city: "0571", //城市设为北京,默认:“全国”
  346. radius: 500 //范围,默认:500
  347. });
  348. }
  349. geocoder.getAddress(lnglat, function(status, result) {
  350. if (status === 'complete' && result.regeocode) {
  351. address = result.regeocode.formattedAddress;
  352. if(!infoWindow || userInfo.baseinfo.token != renlian.storage.get('userinfo').baseinfo.token){
  353. infoWindow = new SimpleInfoWindow({
  354. infoBody: '<span>'+address+'</span>',
  355. //基点指向marker的头部位置
  356. offset: new AMap.Pixel(50, -64)
  357. });
  358. }
  359. infoWindow.open(mainMap, lnglat);
  360. console.log(infoWindow.get$Container());
  361. infoWindow.get$Container().on('click', function(){
  362. renlian.nav.go({ path: 'amap/navigation', title: '导航', isBack: true, isHead: true, param: startEnd});
  363. if(infoWindow){
  364. infoWindow.close( );
  365. }
  366. });
  367. }else{
  368. // renlian.layer.toast(JSON.stringify(result));
  369. }
  370. });
  371. });
  372. }
  373. //坐标解析地址
  374. //实时路况图层
  375. var trafficLayer = new AMap.TileLayer.Traffic({
  376. zIndex: 10
  377. });
  378. var trafficLayerAble = false;
  379. trafficLayer.hide();
  380. trafficLayer.setMap(mainMap);
  381. var routeSituationToggle = function (){
  382. if (trafficLayerAble) {
  383. trafficLayer.hide();
  384. trafficLayerAble = false;
  385. $('#route-situation').html('<svg class="icon" aria-hidden="true"><use xlink:href="#icon-lukuang"></use></svg>');
  386. } else {
  387. trafficLayer.show();
  388. trafficLayerAble = true;
  389. $('#route-situation').html('<svg class="icon" aria-hidden="true"><use xlink:href="#icon-lukuang1"></use></svg>');
  390. }
  391. }
  392. $('#route-situation').on('tap', function () {
  393. routeSituationToggle();
  394. });
  395. //地图显示切换(卫星和常规)
  396. var satelliteLayer = new AMap.TileLayer.Satellite();
  397. var isSatelieteAble = false;
  398. renlian.mapLayerChange = function (){
  399. if (isSatelieteAble) {
  400. mainMap.remove(satelliteLayer);
  401. isSatelieteAble = false;
  402. $('#layer-change').html('<svg class="icon" aria-hidden="true"><use xlink:href="#icon-qiehuan1"></use></svg>');
  403. } else {
  404. mainMap.add(satelliteLayer);
  405. isSatelieteAble = true;
  406. $('#layer-change').html('<svg class="icon" aria-hidden="true"><use xlink:href="#icon-qiehuan"></use></svg>');
  407. }
  408. }
  409. $('#layer-change').on('tap', function () {
  410. renlian.mapLayerChange();
  411. });
  412. //轨迹页跳转
  413. $('#route-play').on('tap', function () {
  414. renlian.nav.go({ path: 'amap/route', title: '轨迹回放', isBack: true, isHead: true, param: {textData:routePageData, defaultCenter: defaultCenter || startEnd.start} });
  415. if(infoWindow){infoWindow.close( );}
  416. });
  417. //围栏页跳转
  418. $('#electric-fence').on('tap', function () {
  419. renlian.nav.go({ path: 'amap/fence', title: '围栏设置', isBack: true, isHead: true, param: {default: fenceCenterVehicle || startEnd.start} });
  420. if(infoWindow){infoWindow.close( );}
  421. });
  422. //保险页跳转
  423. $('.insurance-img').on('tap', function () {
  424. renlian.nav.go({ path: 'insure', title: '保险理赔', isBack: true, isHead: true, param: 'test' });
  425. if(infoWindow){infoWindow.close( );}
  426. });
  427. //定时刷新数据
  428. // var mainPageInterval = setInterval(function(){
  429. // if($('.f-page').length > 1){
  430. // // clearTimeout(mainPageInterval);
  431. // return;
  432. // }
  433. // getVehicleData(overlayData);
  434. // }, timeInterval);
  435. },
  436. reload: function ($page, pageinfo) {
  437. if(userInfo.baseinfo.token != renlian.storage.get('userinfo').baseinfo.token){
  438. vehicleMarker.setMap(null);
  439. infoWindow = null;
  440. getVehicleData(overlayData, true);
  441. }else{
  442. getVehicleData(overlayData);
  443. }
  444. if(infoWindow){
  445. infoWindow.open(mainMap, lnglat);
  446. }
  447. },
  448. destroy: function(pageinfo){
  449. console.log('destroy amap')
  450. }
  451. };
  452. return page;
  453. })();
  454. //icon.js
  455. !function(h){var t,l='<svg><symbol id="icon-suo" viewBox="0 0 1024 1024"><path d="M825.344 400.853H185.899a99.904 99.904 0 0 0-100.011 99.819v423.339a99.883 99.883 0 0 0 100.01 99.797h639.446a99.904 99.904 0 0 0 100.01-99.797V500.693c0-55.125-44.8-99.818-100.01-99.818z m-277.61 308.63v111.104a42.112 42.112 0 1 1-84.225 0V709.483a84.139 84.139 0 0 1-42.133-72.896 84.224 84.224 0 1 1 126.357 72.896zM298.111 401.216h-87.339v-99.37C210.773 130.858 342.784 0.703 505.6 0.703c162.859 0 294.87 130.133 294.87 301.141v99.35h-84.31V298.41c0-115.99-94.25-210.048-210.56-210.048-116.267 0-210.539 94.08-210.539 210.048l3.051 102.784z" ></path></symbol><symbol id="icon-yonghuzuguanli" viewBox="0 0 1024 1024"><path d="M218.764 556.218c32.581-13.963 58.181-18.618 58.181-30.254 0-20.946-20.945-30.255-44.218-44.219-30.254-18.618-72.145-58.181-72.145-132.654 0-65.164 34.909-109.382 88.436-132.655 13.964-6.981 41.891-16.29 30.255-44.218-6.982-18.618-46.546-13.963-72.146 0-60.509 30.255-102.4 95.418-102.4 174.546 0 72.145 34.91 125.672 88.437 160.581C69.818 558.545 0 663.273 0 805.236c0 16.291 13.964 30.255 30.255 30.255s30.254-13.964 30.254-30.255C58.182 663.273 146.62 588.8 218.764 556.218z m616.727-46.545c53.527-37.237 86.109-88.437 86.109-160.582 0-81.455-41.89-146.618-102.4-176.873-25.6-13.963-65.164-18.618-72.145 0-11.637 27.927 13.963 37.237 27.927 44.218 53.527 23.273 86.109 67.491 86.109 132.655 0 72.145-44.218 114.036-72.146 132.654-20.945 13.964-44.218 23.273-44.218 44.219 0 11.636 25.6 16.29 58.182 30.254C875.055 588.8 961.164 665.6 961.164 805.236c0 16.291 13.963 30.255 27.927 30.255 16.29 0 27.927-13.964 27.927-30.255 6.982-141.963-60.509-246.69-181.527-295.563z m-197.818 23.272c65.163-41.89 107.054-114.036 107.054-197.818 0-130.327-104.727-235.054-235.054-235.054S274.618 204.8 274.618 335.127c0 81.455 41.891 155.928 107.055 197.818-151.273 53.528-265.31 200.146-265.31 374.691 0 16.291 13.964 30.255 30.255 30.255 16.291 0 30.255-13.964 30.255-30.255 0-186.181 151.272-337.454 337.454-337.454s337.455 151.273 337.455 337.454c0 16.291 13.963 30.255 30.254 30.255 16.291 0 30.255-13.964 30.255-30.255-4.655-174.545-118.691-321.163-274.618-374.69zM512 512c-97.745 0-174.545-79.127-174.545-174.545 0-97.746 79.127-174.546 174.545-174.546 97.745 0 174.545 79.127 174.545 174.546S609.745 512 512 512z" ></path></symbol><symbol id="icon-lukuang" viewBox="0 0 1024 1024"><path d="M513.210571 422.651043c-46.612621 0-84.393085 37.784558-84.393085 84.397178s37.780465 84.397179 84.393085 84.397179 84.397179-37.784558 84.397179-84.397179-37.784558-84.397179-84.397179-84.397178z m210.988342-168.793335h-421.980777c-139.832745 0-253.190513 113.357767-253.190513 253.190513s113.357767 253.190513 253.190513 253.190513h421.980777c139.837862 0 253.195629-113.357767 253.19563-253.190513S864.035752 253.857708 724.198913 253.857708z m0 421.984871h-421.980777c-93.225241 0-168.794357-75.573209-168.794357-168.794358 0-93.225241 75.569116-168.794357 168.794357-168.794357h421.980777c93.225241 0 168.798451 75.569116 168.798451 168.794357 0 93.221148-75.573209 168.794357-168.798451 168.794358z m0-253.191536c-46.604434 0-84.393085 37.784558-84.393085 84.397178s37.788651 84.397179 84.393085 84.397179c46.612621 0 84.401272-37.784558 84.401272-84.397179s-37.788651-84.397179-84.401272-84.397178z m-421.980777 0c-46.612621 0-84.397179 37.784558-84.397179 84.397178s37.784558 84.397179 84.397179 84.397179 84.397179-37.784558 84.397179-84.397179-37.784558-84.397179-84.397179-84.397178z" fill="#666666" ></path></symbol><symbol id="icon-ziyuan" viewBox="0 0 1411 1024"><path d="M1126.84915 909.251735a420.939538 420.939538 0 1 0-831.153566 92.709546H1116.711339a429.020402 429.020402 0 0 0 10.137811-92.709546z" fill="#BAD4FF" ></path><path d="M822.861749 481.994431a255.061444 255.061444 0 1 0-232.8758 0A443.565957 443.565957 0 0 0 263.078279 909.251735a448.855249 448.855249 0 0 0 11.166285 97.558064 22.038719 22.038719 0 0 0 21.45102 17.190201H1116.711339a22.038719 22.038719 0 0 0 21.45102-17.190201A440.774385 440.774385 0 0 0 822.861749 481.994431zM495.072531 255.436396A210.984006 210.984006 0 1 1 705.321913 466.273478a211.130931 211.130931 0 0 1-210.249382-210.837082z m603.126284 724.486165H313.767334a390.67303 390.67303 0 0 1-6.611616-70.670826 398.900819 398.900819 0 1 1 797.654713 0 389.497632 389.497632 0 0 1-6.611616 70.670826z" fill="#2081D1" ></path><path d="M140.396075 847.690246H48.274229A281.214058 281.214058 0 0 1 44.160334 799.792763a295.318838 295.318838 0 0 1 295.024989-294.878064 23.067193 23.067193 0 0 0 9.843961-2.350797 22.038719 22.038719 0 0 0 1.469248-38.641221 22.920268 22.920268 0 0 0-11.019359-3.085421H338.009925a153.389486 153.389486 0 0 1-20.422547-305.456649 21.891794 21.891794 0 0 0 18.806374-24.683366 22.185644 22.185644 0 0 0-24.83029-18.953298 197.173075 197.173075 0 0 0-74.050097 364.667341A337.927029 337.927029 0 0 0 8.604534 874.577483 22.038719 22.038719 0 0 0 29.467855 891.767684h110.92822a22.038719 22.038719 0 0 0 0-44.077438zM1173.865085 476.411288a197.173075 197.173075 0 0 0-73.462398-364.520416 22.038719 22.038719 0 1 0-6.023917 44.077438A153.389486 153.389486 0 0 1 1072.633901 460.83726a22.038719 22.038719 0 1 0 0 44.077439 295.318838 295.318838 0 0 1 294.584214 294.878064 281.214058 281.214058 0 0 1-4.113894 47.897483h-91.681072a22.038719 22.038719 0 0 0 0 44.077438H1381.175971a22.038719 22.038719 0 0 0 21.45102-17.190201 337.927029 337.927029 0 0 0-228.761906-398.166195z" fill="#2081D1" ></path></symbol><symbol id="icon-lukuang1" viewBox="0 0 1026 1024"><path d="M513.001817 418.726663c-51.518351 0-93.270267 41.757033-93.270267 93.270267 0 51.518351 41.751916 93.275383 93.270267 93.275383 51.513234 0 93.269243-41.756009 93.269243-93.275383 0.001023-51.513234-41.754986-93.270267-93.269243-93.270267z" fill="#F9AE00" ></path><path d="M746.177484 232.181013H279.815917c-154.534586 0-279.815917 125.282355-279.815917 279.815917 0 154.539702 125.282355 279.822057 279.815917 279.822057h466.361567c154.545842 0 279.82615-125.282355 279.82615-279.822057 0-154.534586-125.280308-279.815917-279.82615-279.815917z m0 466.367707H279.815917c-103.026468 0-186.54565-83.524299-186.54565-186.550767S176.789449 325.45128 279.815917 325.45128h466.361567c103.031585 0 186.550767 83.519182 186.550766 186.54565S849.210092 698.54872 746.177484 698.54872z" fill="#8D8D8E" ></path><path d="M746.177484 418.726663c-51.508117 0-93.270267 41.757033-93.270267 93.270267 0 51.518351 41.763173 93.275383 93.270267 93.275383 51.513234 0 93.27436-41.756009 93.27436-93.275383 0.001023-51.513234-41.761126-93.270267-93.27436-93.270267z" fill="#6EBE6E" ></path><path d="M279.815917 418.726663c-51.513234 0-93.270267 41.757033-93.270267 93.270267 0 51.518351 41.757033 93.275383 93.270267 93.275383 51.518351 0 93.27436-41.756009 93.27436-93.275383 0-51.513234-41.756009-93.270267-93.27436-93.270267z" fill="#F1344C" ></path></symbol><symbol id="icon-qiehuan" viewBox="0 0 1040 1024"><path d="M690.238402 52.962084c39.422905 0 71.478903 32.852421 71.478903 73.171301v562.971029c0 40.31888-32.055998 73.171301-71.478903 73.171301H120.099572c-39.422905 0-71.478903-32.852421-71.478903-73.171301V126.232938c0-40.31888 32.055998-73.171301 71.478903-73.171301h570.13883m0-48.581761H120.099572C53.797414 4.479876 0.038907 58.935252 0.038907 126.232938v562.971029c0 67.198133 53.758507 121.753062 120.060665 121.753062h570.13883c66.302158 0 120.060665-54.455376 120.060665-121.753062V126.232938c0-67.297686-53.758507-121.753062-120.060665-121.753062z" fill="#7D7D7D" ></path><path d="M345.188431 217.522847h570.138829c66.302158 0 120.060665 54.455376 120.060665 121.753062v562.971029c0 67.198133-53.758507 121.753062-120.060665 121.753062H345.188431c-66.302158 0-120.060665-54.455376-120.060665-121.753062V339.176356c0-67.198133 53.758507-121.65351 120.060665-121.653509z" fill="#FFB734" ></path></symbol><symbol id="icon-qiehuan1" viewBox="0 0 1024 1024"><path d="M904.9 218.2H803.7v466.9c0 66.8-53.3 120.8-119.1 120.8H220.3v91.5c0 66.8 53.3 120.8 119.1 120.8h565.5c65.8 0 119.1-54.1 119.1-120.8V338.9c0-66.7-53.3-120.7-119.1-120.7z" fill="#FFB734" ></path><path d="M119.1 781.7c-52.4 0-95-43.4-95-96.7V126.6c0-53.3 42.6-96.7 95-96.7h565.5c52.4 0 95 43.4 95 96.7V685c0 53.3-42.6 96.7-95 96.7H119.1z" fill="#FFFFFF" ></path><path d="M684.6 54.1c39.1 0 70.9 32.5 70.9 72.6v558.4c0 40-31.8 72.6-70.9 72.6H119.1c-39.1 0-70.9-32.5-70.9-72.6V126.6c0-40 31.8-72.6 70.9-72.6h565.5m0-48.1H119.1C53.3 5.9 0 59.9 0 126.6V685c0 66.7 53.3 120.8 119.1 120.8h565.5c65.8 0 119.1-54 119.1-120.8V126.7c0-66.8-53.3-120.8-119.1-120.8z" fill="#7D7D7D" ></path></symbol><symbol id="icon-jiesuo" viewBox="0 0 1024 1024"><path d="M810.927 408.343H579.399v-0.486h-207.41V261.798c0-77.256 62.88-140.172 140.093-140.172 77.22 0 139.984 62.916 139.984 140.172l0.002 55.467h87.209v-59.172c0-125.435-101.887-227.433-227.248-227.433S284.663 132.658 284.663 258.093v149.764h-64.31c-31.009 0-56.14 25.146-56.14 56.177v410.059c0 31.079 25.131 56.226 56.14 56.226h583.346c31.016 0 56.088-25.146 56.088-56.226v-410.06c-0.004-28.562-21.288-52.116-48.86-55.69zM543.559 679.741v89.545c0 4.004-3.308 7.369-7.373 7.369H487.93c-4.115 0-7.426-3.371-7.426-7.369v-89.545c-22.674-11.596-38.381-34.853-38.381-62.115 0-38.568 31.302-69.939 69.851-69.939 38.608 0 69.909 31.371 69.909 69.939 0.053 27.263-15.651 50.52-38.324 62.115z" fill="#5A5B5B" ></path></symbol><symbol id="icon-guijichaxun" viewBox="0 0 1024 1024"><path d="M693.76 716.8H215.04c-52.736 0-95.232-42.496-95.232-95.232s42.496-95.232 95.232-95.232h186.368c84.48 0 153.6-68.608 153.6-153.6s-68.608-153.6-153.6-153.6H299.52c2.048 9.216 3.072 18.944 3.072 29.184s-1.024 19.968-3.072 29.184h101.888c52.736 0 95.232 42.496 95.232 95.232s-42.496 95.232-95.232 95.232H215.04c-84.48 0-153.6 68.608-153.6 153.6s68.608 153.6 153.6 153.6h478.72c-2.048-9.216-3.072-18.944-3.072-29.184s1.024-19.968 3.072-29.184zM840.704 654.336c-50.176 0-91.136 40.96-91.136 91.136s40.96 91.136 91.136 91.136 91.136-40.96 91.136-91.136-40.96-91.136-91.136-91.136zM123.392 161.792C87.552 174.08 61.44 208.384 61.44 248.32c0 50.176 40.96 91.136 91.136 91.136s91.136-40.96 91.136-91.136c0-39.936-26.112-74.24-61.952-86.528 0 0-26.112-9.728-58.368 0z" fill="#2C7DFA" ></path></symbol><symbol id="icon-dianziweilan" viewBox="0 0 1024 1024"><path d="M982.22 585.165A475.136 475.136 0 0 1 585.166 987.29V1024H438.784v-36.71A475.085 475.085 0 0 1 41.728 585.114H0V438.886h43.469A475.34 475.34 0 0 1 438.784 48.794V0h146.33v48.947A475.443 475.443 0 0 1 980.48 438.784H1024v146.33h-41.78z m-506.777 393.42h73.114v-73.164h-73.114v73.216zM45.363 475.444v73.114h73.216v-73.114H45.363z m503.194-430.08h-73.114v73.216h73.114V45.363z m33.28 77.415v40.14H442.163V122.88a401.869 401.869 0 0 0-324.71 319.488h45.21v139.725h-47.105a401.613 401.613 0 0 0 326.605 331.213v-51.764h139.674v51.712A401.715 401.715 0 0 0 908.39 582.093h-47.052V442.419h45.21A401.92 401.92 0 0 0 581.836 122.88v-0.051z m396.8 352.665v73.114H905.42v-73.114h73.216zM284.416 512a227.533 227.533 0 1 1 455.066 0 227.533 227.533 0 0 1-455.066 0z" fill="" ></path></symbol></svg>',c=(t=document.getElementsByTagName("script"))[t.length-1].getAttribute("data-injectcss");if(c&&!h.__iconfont__svg__cssinject__){h.__iconfont__svg__cssinject__=!0;try{document.write("<style>.svgfont {display: inline-block;width: 1em;height: 1em;fill: currentColor;vertical-align: -0.1em;font-size:16px;}</style>")}catch(t){console&&console.log(t)}}!function(t){if(document.addEventListener)if(~["complete","loaded","interactive"].indexOf(document.readyState))setTimeout(t,0);else{var c=function(){document.removeEventListener("DOMContentLoaded",c,!1),t()};document.addEventListener("DOMContentLoaded",c,!1)}else document.attachEvent&&(e=t,i=h.document,a=!1,o=function(){a||(a=!0,e())},(l=function(){try{i.documentElement.doScroll("left")}catch(t){return void setTimeout(l,50)}o()})(),i.onreadystatechange=function(){"complete"==i.readyState&&(i.onreadystatechange=null,o())});var e,i,a,o,l}(function(){var t,c,e,i,a,o;(t=document.createElement("div")).innerHTML=l,l=null,(c=t.getElementsByTagName("svg")[0])&&(c.setAttribute("aria-hidden","true"),c.style.position="absolute",c.style.width=0,c.style.height=0,c.style.overflow="hidden",e=c,(i=document.body).firstChild?(a=e,(o=i.firstChild).parentNode.insertBefore(a,o)):i.appendChild(e))})}(window);