jczl.vue 83 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547
  1. <template>
  2. <div style="background-color: #32435A">
  3. <div class="map">
  4. <!-- <img src="@/assets/images/sprh-map.png"/>-->
  5. <supermap ref="supermap" style="height: 100%;width: 100%;position: absolute;z-index: 0;"
  6. :yxtSltProps="sltProps"></supermap>
  7. </div>
  8. <!-- 阴影背景 -->
  9. <div class="bj_left"><img src="@/assets/images/sprhbj-left.png"/></div>
  10. <div class="bj_right"><img src="@/assets/images/sprhbj-right.png"/></div>
  11. <div class="bj_bottom"><img src="@/assets/images/sprhbj-bottom.png"/></div>
  12. <!--头部开始-->
  13. <div class="header">
  14. <h1>城市运行一网统管指挥中心</h1>
  15. <div class="map_tab">
  16. <button @click="sltHandle" :class="{ 'on': btnOne }">矢量图</button>
  17. <button @click="yxtHandle" :class="{ 'on': btnTwo }">影像图</button>
  18. </div>
  19. </div>
  20. <!--头部结束-->
  21. <!-- 中间开始 -->
  22. <!-- 中间结束 -->
  23. <!--左侧开始-->
  24. <div class="left_con">
  25. <div class="top_txt">
  26. <b>汽开区</b>
  27. <span>小雨</span>
  28. <span>9~16℃</span>
  29. </div>
  30. <!-- 便民服务 -->
  31. <div class="qkq_bmfw">
  32. <div class="qkq_tit">便民服务</div>
  33. <div class="jczl_tit">
  34. <span>累计发布<u>181</u>次</span>
  35. <span>累计服务<u>149</u>次</span>
  36. <span>当年服务<u>47</u>次</span>
  37. </div>
  38. <div id="jczl-bmfw" style="margin: 20px auto 0px auto; width: 350px; height: 180px"></div>
  39. </div>
  40. <!-- 便民服务 -->
  41. <!-- 就业服务 -->
  42. <div class="qkq_bmfw">
  43. <div class="qkq_tit ">就业服务</div>
  44. <div class="jczl_tit">
  45. <span>累计专场招聘<u>366</u>次</span>
  46. <span>累计提供岗位<u>294</u>个</span>
  47. </div>
  48. <div class="jczl_tit">
  49. <span>累计服务<u>745</u>次</span>
  50. <span>当年服务<u>366</u>次</span>
  51. </div>
  52. </div>
  53. <div
  54. id="sprh-zpfw"
  55. style="margin: 10px auto ; width: 350px; height: 150px"
  56. ></div>
  57. <!-- 就业服务 -->
  58. <!-- 便民招聘 -->
  59. <div class="qkq_bmfw">
  60. <div class="qkq_tit ">便民招聘</div>
  61. <div class="jczl_tit">
  62. <span>发布招聘<u>245</u>次</span>
  63. <span>提供就业岗位<u>188</u>个</span>
  64. </div>
  65. <div class="jczl_tit">
  66. <span>累计服务<u>421</u>次</span>
  67. <span>当年服务<u>166</u>次</span>
  68. </div>
  69. </div>
  70. <div
  71. id="sprh-ymcxfw"
  72. style="margin: 10px auto; width: 350px; height: 150px"
  73. ></div>
  74. <!-- 便民招聘 -->
  75. </div>
  76. <!--左侧结束-->
  77. <!--右侧开始-->
  78. <div class="right_con">
  79. <div class="top_txt">
  80. <span>{{ currentTime }}</span>
  81. <!-- <span>星期六</span>-->
  82. <!-- <b>11:16:58</b>-->
  83. </div>
  84. <div class="qkq_mssq">
  85. <div class="qkq_mssq_div">
  86. <img src="../../assets/images/qkq_icon22.png"/>
  87. <div class="qkq_mssq_txt">
  88. <p>240</p>
  89. <span>诉求已上报</span>
  90. </div>
  91. </div>
  92. <div class="qkq_mssq_div">
  93. <img src="../../assets/images/qkq_icon.png"/>
  94. <div class="qkq_mssq_txt">
  95. <p>240</p>
  96. <span>诉求已处理</span>
  97. </div>
  98. </div>
  99. </div>
  100. <!-- 居民总数 -->
  101. <div class="qkq_bmfw">
  102. <div class="qkq_tit ">居民总数</div>
  103. <div class="qkq_jmzs">
  104. <span>居民总数</span>
  105. <b>238514</b>
  106. <span>人</span>
  107. </div>
  108. <div
  109. id="sprh-jmzs"
  110. style="margin: 10px auto; width: 350px; height: 150px"
  111. ></div>
  112. </div>
  113. <!-- 居民总数 -->
  114. <!-- 特殊人群 -->
  115. <div class="qkq_bmfw">
  116. <div class="qkq_tit ">特殊人群</div>
  117. <div class="tsrq_scro">
  118. <div
  119. id="sprh-tsrq"
  120. style="margin: 10px auto; width: 350px; height: 800px"
  121. ></div>
  122. </div>
  123. </div>
  124. <!-- 特殊人群 -->
  125. <!-- 辖区企业 -->
  126. <div class="qkq_bmfw">
  127. <div class="qkq_tit ">辖区企业</div>
  128. <div class="xqqy_div">
  129. <div class="xqqy_tit">
  130. <p>
  131. <span>汽开区</span>
  132. <span><b>3266</b><i>家企业</i></span>
  133. </p>
  134. <p>
  135. <span>XXXX社区</span>
  136. <span><b>3266</b><i>家企业</i></span>
  137. </p>
  138. <p>
  139. <span>XXXX社区</span>
  140. <span><b>3266</b><i>家企业</i></span>
  141. </p>
  142. <p>
  143. <span>XXXX社区</span>
  144. <span><b>3266</b><i>家企业</i></span>
  145. </p>
  146. <p>
  147. <span>XXXX社区</span>
  148. <span><b>3266</b><i>家企业</i></span>
  149. </p>
  150. <p>
  151. <span>XXXX社区</span>
  152. <span><b>3266</b><i>家企业</i></span>
  153. </p>
  154. </div>
  155. </div>
  156. </div>
  157. <!-- 辖区企业 -->
  158. <!-- 民生诉求 -->
  159. <!-- <div class="qkq_bmfw">
  160. <div class="qkq_tit ">民生诉求</div>
  161. <div class="mssq_div">
  162. </div>
  163. </div> -->
  164. <!-- 民生诉求 -->
  165. </div>
  166. <!--右侧结束-->
  167. <!-- 底部代码开始 -->
  168. <div class="bottom_con">
  169. <!-- 男女比例 -->
  170. <div class="qkq_bmfw">
  171. <div
  172. id="sprh-xbbl"
  173. style="margin: 10px auto; width: 350px; height: 260px"
  174. ></div>
  175. </div>
  176. <!-- 男女比例 -->
  177. <!-- 年龄比例 -->
  178. <div class="qkq_bmfw">
  179. <div
  180. id="sprh-nl"
  181. style="margin: 10px auto; width: 350px; height: 260px"
  182. ></div>
  183. </div>
  184. <!-- 年龄比例 -->
  185. <!-- 婚姻比例 -->
  186. <div class="qkq_bmfw">
  187. <div
  188. id="sprh-hy"
  189. style="margin: 10px auto; width: 350px; height: 260px"
  190. ></div>
  191. </div>
  192. <!-- 婚姻比例 -->
  193. </div>
  194. <!-- 底部代码结束 -->
  195. <!--底部开始-->
  196. <div class="footer">
  197. <div class="nav-bottom">
  198. <div class="nav-bottom-left">
  199. <div class="nav-li-left" @click="serviceFAW('jjyx')">
  200. <span>经济运行</span>
  201. </div>
  202. <div class="nav-li-left" @click="serviceFAW('csgl')">
  203. <span>城市管理</span>
  204. </div>
  205. <div class="nav-li-left" @click="serviceFAW('jtzl')">
  206. <span>交通治理</span>
  207. </div>
  208. <div class="nav-li-left on">
  209. <span>基层治理</span>
  210. </div>
  211. </div>
  212. <div class="nav-home-middle" @click="homePage('weather')">
  213. <img src="@/assets/images/home-btn.png"/>
  214. <a>返回首页</a>
  215. </div>
  216. <div class="nav-bottom-right">
  217. <div class="nav-li-right" @click="serviceFAW('yshj_new')">
  218. <span>营商环境</span>
  219. </div>
  220. <div class="nav-li-right" @click="serviceFAW('bjzshz')">
  221. <span>政务运行</span>
  222. </div>
  223. <div class="nav-li-right" @click="serviceFAW('aqyj')">
  224. <span>安全应急</span>
  225. </div>
  226. <div class="nav-li-right" @click="serviceFAW('fwyq')">
  227. <span>服务一汽</span>
  228. </div>
  229. </div>
  230. </div>
  231. </div>
  232. <!--底部开始-->
  233. </div>
  234. </template>
  235. <script>
  236. import * as echarts from 'echarts'
  237. import $ from 'jquery'
  238. import jQuery from 'jquery'
  239. import "@/assets/images/qkq_body.css";
  240. import "@/assets/images/qkq_index.css";
  241. import "@/assets/images/qkq_sprh.css";
  242. import supermap from "@/views/supermap/supermap";
  243. export default {
  244. name: "jczl",
  245. components: {supermap},
  246. data() {
  247. return {
  248. currentTime: '',
  249. sltProps: null,
  250. btnOne: true,
  251. btnTwo: false
  252. }
  253. },
  254. created() {
  255. },
  256. mounted() {
  257. this.regionTop();
  258. this.trend();
  259. this.matterUpTop();
  260. this.matterTop();
  261. this.tsrqqktj();
  262. this.xbbl();
  263. this.nl();
  264. this.hy();
  265. // 每秒刷新时间
  266. setInterval(() => {
  267. this.getCurrentTime();
  268. }, 1000);
  269. },
  270. methods: {
  271. sltHandle() {
  272. this.btnOne = true
  273. this.btnTwo = false
  274. this.$refs.supermap.getSupermap(null, null, null, "slt", null, null)
  275. },
  276. yxtHandle() {
  277. this.btnTwo = true
  278. this.btnOne = false
  279. this.$refs.supermap.getSupermap(null, null, null, "yxt", null, null)
  280. },
  281. homePage(route) {
  282. this.$router.push({path: route});
  283. },
  284. serviceFAW(route) {
  285. this.$router.push({path: route});
  286. },
  287. smalClick(val) {
  288. var node = $(val).next();
  289. if (node.is(":hidden")) {
  290. //如果node是隐藏的则显示node元素,否则隐藏
  291. node.show();
  292. } else {
  293. node.hide();
  294. }
  295. },
  296. regionTop() {
  297. //便民服务
  298. var myChart = echarts.init(document.getElementById('jczl-bmfw'));
  299. let valueData = [];
  300. let labelData = [];
  301. for (var i = 1; i <= 6; i++) {
  302. labelData.push("类型" + i);
  303. var lineNumber = Math.floor(Math.random() * 1000);
  304. valueData.push(lineNumber);
  305. }
  306. var option = {
  307. "backgroundColor": "rgba(0, 0, 0, 0)",
  308. title: {
  309. show: true,
  310. text: '',
  311. textStyle: {
  312. color: '#fff',
  313. fontSize: '12',
  314. },
  315. top: '0%',
  316. left: '20%',
  317. },
  318. tooltip: {
  319. trigger: 'axis',
  320. axisPointer: {
  321. type: 'shadow'
  322. }
  323. },
  324. grid: {
  325. top: '10%',
  326. left: '15%',
  327. right: '5%',
  328. buttom: '0',
  329. },
  330. xAxis: {
  331. type: 'category',
  332. axisLine: {
  333. lineStyle: {
  334. color: 'rgba(255,255,255,0.12)',
  335. },
  336. },
  337. axisLabel: {
  338. margin: 10,
  339. color: '#e2e9ff',
  340. textStyle: {
  341. fontSize: 12
  342. },
  343. },
  344. axisTick: {
  345. show: false,
  346. },
  347. data: labelData
  348. },
  349. yAxis: {
  350. name: '',
  351. nameTextStyle: {
  352. color: '#fff',
  353. },
  354. type: 'value',
  355. axisLine: {
  356. show: false,
  357. lineStyle: {
  358. color: 'rgba(255,255,255,0.12)'
  359. },
  360. },
  361. axisLabel: {
  362. formatter: '{value}',
  363. color: '#e2e9ff',
  364. },
  365. splitLine: {
  366. lineStyle: {
  367. color: 'rgba(255,255,255,0.12)'
  368. }
  369. },
  370. axisTick: {
  371. show: false,
  372. lineStyle: {
  373. color: '#fff',
  374. },
  375. },
  376. },
  377. // 切片
  378. series: [
  379. {
  380. type: 'lines',
  381. coordinateSystem: 'cartesian2d',
  382. data: valueData.map((item, index) => {
  383. return {
  384. coords: [
  385. [index, 0],
  386. [index, item - 4]
  387. ]
  388. };
  389. }),
  390. effect: {
  391. show: true,
  392. period: 3.5,// 周期 速度 2.5
  393. trailLength: 0.5, //控制拖尾长度
  394. symbolSize: 25, // ⭐⭐星星大小
  395. symbol:
  396. 'path://M307.46000719101244,524.9919417770187 L320.064963732395,524.9919417770187 L323.95999229701675,510.4772043087195 L327.8550230764027,524.9919417770187 L340.45997740302056,524.9919417770187 L330.26237201075065,533.9624401818169 L334.15760211881354,548.4771776501146 L323.95999229701675,539.506434950185 L313.76238468998207,548.4771776501146 L317.6576159054294,533.9624401818169 L307.46000719101244,524.9919417770187 z',
  397. loop: true,
  398. color: '#ffffff' //流光颜色
  399. },
  400. lineStyle: {
  401. width: 0,
  402. opacity: 0.6,
  403. curveness: 0
  404. },
  405. z: 999
  406. },
  407. {
  408. type: 'bar',
  409. data: valueData,
  410. barWidth: '20px',
  411. itemStyle: {
  412. normal: {
  413. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
  414. offset: 0,
  415. color: 'rgba(0,244,255,1)' // 0% 处的颜色
  416. }, {
  417. offset: 1,
  418. color: 'rgba(0,77,167,1)' // 100% 处的颜色
  419. }], false),
  420. barBorderRadius: [30, 30, 30, 30],
  421. shadowColor: 'rgba(0,160,221,1)',
  422. shadowBlur: 4,
  423. }
  424. },
  425. }]
  426. };
  427. if (option) {
  428. myChart.setOption(option);
  429. }
  430. },
  431. trend() {
  432. //就业服务
  433. var myChart = echarts.init(document.getElementById('sprh-zpfw'));
  434. var monthData = [];
  435. var lineData = [];
  436. let data = []
  437. let arr1 = []
  438. let coords = {}
  439. for (var i = 1; i <= 12; i++) {
  440. let arr = []
  441. monthData.push(i + '月');
  442. var lineNumber = Math.floor(Math.random() * 10000);
  443. lineData.push(lineNumber);
  444. arr.push(i + "月")
  445. arr.push(lineNumber)
  446. arr1.push(arr)
  447. }
  448. this.$set(coords, "coords", arr1)
  449. data.push(coords)
  450. var img = [
  451. 'image://',
  452. 'image://',
  453. 'image://',
  454. 'image://',
  455. ]
  456. var option = {
  457. grid: {
  458. top: 10,
  459. bottom: 10,
  460. containLabel: true,
  461. },
  462. tooltip: {
  463. trigger: 'axis',
  464. axisPointer: {
  465. lineStyle: {
  466. color: {
  467. type: 'linear',
  468. x: 0,
  469. y: 0,
  470. x2: 0,
  471. y2: 1,
  472. colorStops: [
  473. {
  474. offset: 0,
  475. color: 'rgba(255,255,255,0)', // 0% 处的颜色
  476. },
  477. {
  478. offset: 0.5,
  479. color: 'rgba(255,255,255,1)', // 100% 处的颜色
  480. },
  481. {
  482. offset: 1,
  483. color: 'rgba(255,255,255,0)', // 100% 处的颜色
  484. },
  485. ],
  486. global: false, // 缺省为 false
  487. },
  488. },
  489. },
  490. },
  491. xAxis: [
  492. {
  493. type: 'category',
  494. boundaryGap: false,
  495. axisLabel: {
  496. formatter: '{value}',
  497. fontSize: 14,
  498. margin: 10,
  499. textStyle: {
  500. color: '#eaf7ff',
  501. },
  502. },
  503. axisLine: {
  504. lineStyle: {
  505. color: '#243753',
  506. },
  507. },
  508. splitLine: {
  509. show: true,
  510. lineStyle: {
  511. color: '#243753',
  512. },
  513. },
  514. axisTick: {
  515. show: false,
  516. },
  517. data: monthData,
  518. },
  519. ],
  520. yAxis: [
  521. {
  522. boundaryGap: false,
  523. type: 'value',
  524. axisLabel: {
  525. textStyle: {
  526. color: '#eaf7ff',
  527. },
  528. },
  529. nameTextStyle: {
  530. color: '#fff',
  531. fontSize: 12,
  532. lineHeight: 40,
  533. },
  534. splitLine: {
  535. lineStyle: {
  536. color: '#243753',
  537. },
  538. },
  539. axisLine: {
  540. show: true,
  541. lineStyle: {
  542. color: '#283352',
  543. },
  544. },
  545. axisTick: {
  546. show: false,
  547. },
  548. },
  549. ],
  550. series: [
  551. {
  552. symbolSize: 150,
  553. symbol: img[2],
  554. name: '招聘次数',
  555. type: 'line',
  556. smooth: true,
  557. showSymbol: true,
  558. zlevel: 3,
  559. itemStyle: {
  560. normal: {
  561. borderColor: '#a3c8d8',
  562. borderWidth: 5,
  563. color: '#eaf7ff',
  564. }
  565. },
  566. lineStyle: {
  567. normal: {
  568. width: 2,
  569. color: '#0ea8df',
  570. },
  571. },
  572. areaStyle: {
  573. normal: {
  574. color: new echarts.graphic.LinearGradient(
  575. 0,
  576. 0,
  577. 0,
  578. 1,
  579. [
  580. {
  581. offset: 0,
  582. color: 'rgba(88,255,255,0.2)',
  583. },
  584. {
  585. offset: 0.8,
  586. color: 'rgba(88,255,255,0)',
  587. },
  588. ],
  589. false
  590. ),
  591. },
  592. },
  593. data: lineData,
  594. },
  595. {
  596. name: '滑行的光点',
  597. type: 'lines',
  598. coordinateSystem: 'cartesian2d',
  599. symbolSize: 30,
  600. polyline: true,
  601. effect: {
  602. show: true,
  603. trailLength: 0,
  604. symbol: "arrow",
  605. period: 10, //光点滑动速度
  606. symbolSize: 150,
  607. symbol: img[0]
  608. },
  609. lineStyle: {
  610. normal: {
  611. width: 1,
  612. opacity: 0.6,
  613. curveness: 0.2
  614. }
  615. },
  616. data: data
  617. }
  618. ],
  619. };
  620. if (option) {
  621. myChart.setOption(option);
  622. }
  623. },
  624. matterUpTop() {
  625. // 便民招聘
  626. var myChart = echarts.init(document.getElementById('sprh-ymcxfw'));
  627. var monthData = [];
  628. var lineData = [];
  629. let data = []
  630. let arr1 = []
  631. let coords = {}
  632. for (var i = 1; i <= 12; i++) {
  633. let arr = []
  634. monthData.push(i + '月');
  635. var lineNumber = Math.floor(Math.random() * 10000) / 100;
  636. lineData.push(lineNumber);
  637. arr.push(i + "月")
  638. arr.push(lineNumber)
  639. arr1.push(arr)
  640. }
  641. this.$set(coords, "coords", arr1)
  642. data.push(coords)
  643. var img = [
  644. 'image://',
  645. 'image://',
  646. 'image://',
  647. 'image://',
  648. ]
  649. var option = {
  650. grid: {
  651. left: '15%',
  652. top: '5%',
  653. bottom: '30%',
  654. right: '5%',
  655. },
  656. tooltip: {
  657. trigger: 'axis',
  658. show: true,
  659. textStyle: {
  660. fontSize: 14,
  661. color: '#eaf7ff',
  662. },
  663. backgroundColor: 'rgba(50,50,50,0.7)',
  664. borderWidth: 0,
  665. },
  666. dataZoom: [
  667. {
  668. show: true,
  669. height: 4,
  670. xAxisIndex: [0],
  671. bottom: 43,
  672. start: 0,
  673. end: 80,
  674. handleIcon:
  675. 'path://M306.1,413c0,2.2-1.8,4-4,4h-59.8c-2.2,0-4-1.8-4-4V200.8c0-2.2,1.8-4,4-4h59.8c2.2,0,4,1.8,4,4V413z',
  676. handleSize: '110%',
  677. handleStyle: {
  678. color: 'rgba(255, 255, 255,0.5)',
  679. },
  680. textStyle: {
  681. color: '#fff',
  682. fontSize: 10,
  683. },
  684. fillerColor: 'rgba(36, 180, 223, 1.0)',
  685. borderColor: 'rgba(66, 130, 197,1)',
  686. backgroundColor: 'rgba(12, 67, 124,0.5)',
  687. showDataShadow: false,
  688. brushSelect: false,
  689. },
  690. {
  691. type: 'inside',
  692. },
  693. ],
  694. yAxis: {
  695. show: true,
  696. min: 0,
  697. max: 100,
  698. type: 'value',
  699. nameTextStyle: {
  700. color: 'rgba(255,255,255,0.7)',
  701. fontSize: 12,
  702. },
  703. axisLine: {
  704. show: true,
  705. lineStyle: {
  706. color: 'rgba(28, 158, 222, 1)',
  707. type: 'solid',
  708. },
  709. },
  710. axisTick: {
  711. show: true,
  712. lineStyle: {
  713. color: 'rgba(28, 158, 222, 1)',
  714. },
  715. },
  716. axisLabel: {
  717. formatter: '{value}%',
  718. color: '#eaf7ff',
  719. },
  720. splitLine: {
  721. show: true,
  722. lineStyle: {
  723. type: 'solid',
  724. color: 'rgba(0, 206, 209, 0.3)',
  725. width: 0.5,
  726. },
  727. },
  728. },
  729. xAxis: {
  730. show: true,
  731. type: 'category',
  732. boundaryGap: false,
  733. nameTextStyle: {
  734. fontSize: 14,
  735. },
  736. axisLine: {
  737. lineStyle: {
  738. color: '#eaf7ff',
  739. },
  740. },
  741. data: monthData,
  742. },
  743. series: [
  744. {
  745. type: 'line',
  746. smooth: true,
  747. symbolSize: 3,
  748. data: lineData,
  749. itemStyle: {
  750. normal: {
  751. width: 1,
  752. color: 'rgb(0, 255, 255)',
  753. },
  754. },
  755. lineStyle: {
  756. normal: {
  757. color: 'rgb(0, 146, 246)',
  758. width: 2,
  759. },
  760. },
  761. areaStyle: {
  762. normal: {
  763. color: new echarts.graphic.LinearGradient(
  764. 0,
  765. 0,
  766. 0,
  767. 1,
  768. [
  769. {
  770. offset: 0,
  771. color: 'rgba(0, 146, 246,0.2)',
  772. },
  773. {
  774. offset: 0.5,
  775. color: 'rgba(0, 146, 246,0.1)',
  776. },
  777. {
  778. offset: 1,
  779. color: 'rgba(0, 146, 246,0)',
  780. },
  781. ],
  782. false
  783. ),
  784. },
  785. },
  786. },
  787. {
  788. name: '滑行的光点',
  789. type: 'lines',
  790. coordinateSystem: 'cartesian2d',
  791. symbolSize: 30,
  792. polyline: true,
  793. effect: {
  794. show: true,
  795. trailLength: 0,
  796. symbol: "arrow",
  797. period: 10, //光点滑动速度
  798. symbolSize: 150,
  799. symbol: img[0]
  800. },
  801. lineStyle: {
  802. normal: {
  803. width: 1,
  804. opacity: 0.6,
  805. curveness: 0.2
  806. }
  807. },
  808. data: data
  809. }
  810. ],
  811. }
  812. if (option) {
  813. myChart.setOption(option);
  814. }
  815. },
  816. matterTop() {
  817. // 居民总数
  818. var myChart = echarts.init(document.getElementById('sprh-jmzs'));
  819. var data = ['前程街道办事处', '富民街道办事处', '东风街道办事处', '锦程街道办事处']
  820. let labelData = []
  821. let valueData = []
  822. for (var i = 0; i < data.length; i++) {
  823. labelData.push(data[i]);
  824. var lineNumber = Math.floor(Math.random() * 10000) / 100;
  825. valueData.push(lineNumber);
  826. }
  827. var option = {
  828. xAxis: {
  829. show: false,
  830. },
  831. tooltip: {
  832. show: true,
  833. },
  834. grid: {
  835. top: '5%',
  836. left: '10%',
  837. right: '5%',
  838. bottom: '0'
  839. },
  840. yAxis: [
  841. {
  842. splitLine: 'none',
  843. axisLine: 'none',
  844. axisLabel: {
  845. verticalAlign: 'bottom',
  846. align: 'left',
  847. padding: [0, 0, 5, 5],
  848. textStyle: {
  849. color: '#FFFFFF',
  850. fontSize: '14',
  851. },
  852. },
  853. data: labelData,
  854. },
  855. {
  856. axisLine: 'none',
  857. data: valueData,
  858. axisLabel: {
  859. show: true,
  860. verticalAlign: 'bottom',
  861. align: 'right',
  862. padding: [0, 0, 0, 0],
  863. textStyle: {
  864. color: '#fff',
  865. fontSize: '14',
  866. }
  867. },
  868. },
  869. ],
  870. series: [
  871. {
  872. type: 'bar',
  873. showBackground: true,
  874. data: valueData,
  875. barWidth: 8,
  876. itemStyle: {
  877. normal: {
  878. color: new echarts.graphic.LinearGradient(0, 0, 1, 0, [
  879. {
  880. offset: 0,
  881. color: 'rgba(28, 88, 177, 1.0)',
  882. },
  883. {
  884. offset: 1,
  885. color: 'rgba(17, 224, 255, 1.0)',
  886. },
  887. ]),
  888. },
  889. },
  890. },
  891. {
  892. type: 'lines',
  893. coordinateSystem: 'cartesian2d',
  894. data: valueData.map((item, index) => {
  895. return {
  896. coords: [
  897. [0, index],
  898. [item, index],
  899. ]
  900. };
  901. }),
  902. effect: {
  903. show: true,
  904. period: 2.5,
  905. trailLength: 0.5, //控制拖尾长度
  906. symbolSize: [15, 2],
  907. symbol: this.$store.state.common.echarts_baseStreamer,
  908. loop: true,
  909. color: '#fff' //流光颜色
  910. },
  911. lineStyle: {
  912. width: 0,
  913. opacity: 0.6,
  914. curveness: 0
  915. },
  916. z: 99
  917. },
  918. ],
  919. };
  920. if (option) {
  921. myChart.setOption(option);
  922. }
  923. },
  924. tsrqqktj() {
  925. // 特殊人群
  926. var myChart = echarts.init(document.getElementById('sprh-tsrq'));
  927. var data = ['社区矫正人员', '劳模', '志愿者', '失业人员', '信访人员', '残疾人', '低保人员', '精神病人', '释解安置人员', '吸毒人员', '重点稳控人员', '活跃分子', '闹访骨干', '吸毒人员未成年子女', '服刑人员未成年子女', '留守人员', '军烈属', '台胞侨胞', '老龄人', '失信被执行人', '社保人员', '医保人员']
  928. var valueData = [];
  929. let labelData = []
  930. for (var i = 0; i < data.length; i++) {
  931. labelData.push(data[i]);
  932. var lineNumber = Math.floor(Math.random() * 10000);
  933. valueData.push(lineNumber);
  934. }
  935. var option = {
  936. xAxis: {
  937. show: false,
  938. },
  939. tooltip: {
  940. show: true,
  941. },
  942. grid: {
  943. top: '1%',
  944. left: '10%',
  945. right: '5%',
  946. bottom: '0'
  947. },
  948. yAxis: [
  949. {
  950. splitLine: 'none',
  951. axisLine: 'none',
  952. axisLabel: {
  953. verticalAlign: 'bottom',
  954. align: 'left',
  955. padding: [0, 0, 5, 5],
  956. textStyle: {
  957. color: '#FFFFFF',
  958. fontSize: '14',
  959. },
  960. },
  961. data: labelData,
  962. },
  963. {
  964. axisLine: 'none',
  965. data: valueData,
  966. axisLabel: {
  967. show: true,
  968. verticalAlign: 'bottom',
  969. align: 'right',
  970. padding: [0, 0, 0, 0],
  971. textStyle: {
  972. color: '#fff',
  973. fontSize: '14',
  974. }
  975. },
  976. },
  977. ],
  978. series: [
  979. {
  980. type: 'bar',
  981. showBackground: true,
  982. data: valueData,
  983. barWidth: 8,
  984. itemStyle: {
  985. normal: {
  986. color: new echarts.graphic.LinearGradient(0, 0, 1, 0, [
  987. {
  988. offset: 0,
  989. color: 'rgba(28, 88, 177, 1.0)',
  990. },
  991. {
  992. offset: 1,
  993. color: 'rgba(17, 224, 255, 1.0)',
  994. },
  995. ]),
  996. },
  997. },
  998. },
  999. {
  1000. type: 'lines',
  1001. coordinateSystem: 'cartesian2d',
  1002. data: valueData.map((item, index) => {
  1003. return {
  1004. coords: [
  1005. [0, index],
  1006. [item, index],
  1007. ]
  1008. };
  1009. }),
  1010. effect: {
  1011. show: true,
  1012. period: 2.5,
  1013. trailLength: 0.5, //控制拖尾长度
  1014. symbolSize: [15, 2],
  1015. symbol: this.$store.state.common.echarts_baseStreamer,
  1016. loop: true,
  1017. color: '#fff' //流光颜色
  1018. },
  1019. lineStyle: {
  1020. width: 0,
  1021. opacity: 0.6,
  1022. curveness: 0
  1023. },
  1024. z: 99
  1025. },
  1026. ],
  1027. };
  1028. if (option) {
  1029. myChart.setOption(option);
  1030. }
  1031. },
  1032. xbbl() {
  1033. // 性别比例
  1034. var myChart = echarts.init(document.getElementById('sprh-xbbl'));
  1035. let index = 0;
  1036. const res = [{
  1037. "name": "男",
  1038. "value": 370
  1039. },
  1040. {
  1041. "name": "女",
  1042. "value": 263
  1043. }
  1044. ]
  1045. const border =
  1046. '';
  1047. const man =
  1048. '';
  1049. const woman =
  1050. '';
  1051. const color = ['#00FFFF', 'rgba(196,36,255,1)'];
  1052. function fun() {
  1053. var timer = setInterval(function () {
  1054. console.log(index)
  1055. myChart.dispatchAction({
  1056. type: 'hideTip',
  1057. seriesIndex: 0,
  1058. dataIndex: index
  1059. });
  1060. // 显示提示框
  1061. myChart.dispatchAction({
  1062. type: 'showTip',
  1063. seriesIndex: 0,
  1064. dataIndex: index
  1065. });
  1066. // 取消高亮指定的数据图形
  1067. myChart.dispatchAction({
  1068. type: 'downplay',
  1069. seriesIndex: 0,
  1070. dataIndex: index == 0 ? 2 : index - 1
  1071. });
  1072. myChart.dispatchAction({
  1073. type: 'highlight',
  1074. seriesIndex: 0,
  1075. dataIndex: index
  1076. });
  1077. index++;
  1078. if (index > 2) {
  1079. index = 0;
  1080. }
  1081. }, 3000)
  1082. }
  1083. fun()
  1084. var option = {
  1085. color,
  1086. graphic: {
  1087. elements: [{
  1088. type: 'image',
  1089. z: 3,
  1090. style: {
  1091. image: border,
  1092. width: 150,
  1093. height: 150
  1094. },
  1095. left: 'center',
  1096. top: 'center',
  1097. position: [50, 50]
  1098. },
  1099. {
  1100. type: 'image',
  1101. z: 3,
  1102. style: {
  1103. image: man,
  1104. width: 45,
  1105. height: 80
  1106. },
  1107. left: '36%',
  1108. top: 'center'
  1109. },
  1110. {
  1111. type: 'image',
  1112. z: 3,
  1113. style: {
  1114. image: woman,
  1115. width: 45,
  1116. height: 80
  1117. },
  1118. right: '36%',
  1119. top: 'center'
  1120. }
  1121. ]
  1122. },
  1123. tooltip: {
  1124. show: false
  1125. },
  1126. toolbox: {
  1127. show: false
  1128. },
  1129. series: [{
  1130. name: '',
  1131. type: 'pie',
  1132. radius: ['60%', '70%'],
  1133. clockwise: true,
  1134. avoidLabelOverlap: true,
  1135. hoverOffset: 30,
  1136. emphasis: {
  1137. itemStyle: {
  1138. borderColor: '#fd4300',
  1139. borderWidth: 4
  1140. }
  1141. },
  1142. itemStyle: {
  1143. normal: {
  1144. label: {
  1145. show: true,
  1146. fontSize: 12,
  1147. formatter(params) {
  1148. return params.name ?
  1149. params.name + '\n' + params.value + '人' :
  1150. '';
  1151. }
  1152. },
  1153. labelLine: {
  1154. width: 1,
  1155. length: 10,
  1156. length2: 12,
  1157. show: true,
  1158. color: '#00ffff'
  1159. }
  1160. }
  1161. },
  1162. data: res,
  1163. }]
  1164. };
  1165. if (option) {
  1166. myChart.setOption(option);
  1167. }
  1168. },
  1169. nl() {
  1170. // 年龄
  1171. var myChart = echarts.init(document.getElementById('sprh-nl'));
  1172. let timeOut4 = null
  1173. clearInterval(timeOut4)
  1174. myChart.clear();
  1175. var data = ['0-10岁', '11-20岁', '21-30岁', '31-40岁', '41-50岁', '51-60岁', '61-70岁', '71-80岁', '80岁以上']
  1176. var monthData = []
  1177. var lineData = []
  1178. for (var i = 0; i < data.length; i++) {
  1179. monthData.push(data[i]);
  1180. var lineNumber = Math.floor(Math.random() * 1000);
  1181. lineData.push(lineNumber);
  1182. }
  1183. var option = {
  1184. "backgroundColor": "rgba(0, 0, 0, 0)",
  1185. tooltip: {
  1186. trigger: 'axis',
  1187. axisPointer: {
  1188. type: 'shadow',
  1189. label: {
  1190. show: false
  1191. }
  1192. }
  1193. },
  1194. grid: {
  1195. left: '12%',
  1196. top: '15%',
  1197. bottom: '15%',
  1198. right: '5%'
  1199. },
  1200. xAxis: {
  1201. data: monthData,
  1202. axisTick: {
  1203. show: true
  1204. },
  1205. axisLine: {
  1206. lineStyle: {
  1207. color: 'rgba(255, 255, 255, 0.1)',
  1208. width: 1 //这里是为了突出显示加上的
  1209. }
  1210. },
  1211. axisLabel: {
  1212. textStyle: {
  1213. color: '#fff',
  1214. fontSize: 12
  1215. }
  1216. }
  1217. },
  1218. yAxis: [{
  1219. axisTick: {
  1220. show: false
  1221. },
  1222. axisLine: {
  1223. lineStyle: {
  1224. color: 'rgba(255, 129, 109, 0.1)',
  1225. width: 1 //这里是为了突出显示加上的
  1226. }
  1227. },
  1228. axisLabel: {
  1229. textStyle: {
  1230. color: '#fff'
  1231. }
  1232. },
  1233. splitArea: {
  1234. areaStyle: {
  1235. color: 'rgba(255,255,255,.5)'
  1236. }
  1237. },
  1238. splitLine: {
  1239. show: true,
  1240. lineStyle: {
  1241. color: 'rgba(255, 129, 109, 0.1)',
  1242. width: 0.5,
  1243. type: 'dashed'
  1244. }
  1245. }
  1246. }
  1247. ],
  1248. series: [{
  1249. type: "pictorialBar",
  1250. barCategoryGap: "0%",
  1251. symbol: "path://M0,10 L10,10 C5.5,10 5.5,5 5,0 C4.5,5 4.5,10 0,10 z",
  1252. label: {
  1253. show: true,
  1254. position: "top",
  1255. distance: 15,
  1256. fontSize: 15,
  1257. color: "#08DFFE",
  1258. fontWeight: "bolder",
  1259. },
  1260. itemStyle: {
  1261. normal: {
  1262. color: {
  1263. type: "linear",
  1264. x: 0,
  1265. y: 0,
  1266. x2: 0,
  1267. y2: 1,
  1268. colorStops: [{
  1269. offset: 0,
  1270. color: "#9A11FF"
  1271. }, {
  1272. offset: 1,
  1273. color: "#08DFFE"
  1274. }],
  1275. global: false
  1276. }
  1277. },
  1278. emphasis: {
  1279. opacity: 1
  1280. }
  1281. },
  1282. data: lineData
  1283. }]
  1284. };
  1285. if (option) {
  1286. myChart.setOption(option);
  1287. }
  1288. var currentIndex = -1;
  1289. timeOut4 = setInterval(() => {
  1290. var dataLen = option.series[0].data.length;
  1291. myChart.dispatchAction({
  1292. type: 'downplay',
  1293. seriesIndex: 0,
  1294. dataIndex: currentIndex
  1295. });
  1296. currentIndex = (currentIndex + 1) % dataLen;
  1297. myChart.dispatchAction({
  1298. type: 'highlight',
  1299. seriesIndex: 0,
  1300. dataIndex: currentIndex,
  1301. });
  1302. myChart.dispatchAction({
  1303. type: 'showTip',
  1304. seriesIndex: 0,
  1305. dataIndex: currentIndex
  1306. });
  1307. }, 1000)
  1308. },
  1309. hy() {
  1310. // 婚姻比例
  1311. var myChart = echarts.init(document.getElementById('sprh-hy'));
  1312. var data = [
  1313. {
  1314. value: 24572,
  1315. name: '已婚'
  1316. },
  1317. {
  1318. value: 12475,
  1319. name: '未婚'
  1320. },
  1321. {
  1322. value: 4251,
  1323. name: '离异'
  1324. },
  1325. ];
  1326. var arrName = getArrayValue(data, "name");
  1327. var arrValue = getArrayValue(data, "value");
  1328. var sumValue = eval(arrValue.join('+'));
  1329. var objData = array2obj(data, "name");
  1330. var optionData = getData(data)
  1331. function getArrayValue(array, key) {
  1332. var key = key || "value";
  1333. var res = [];
  1334. if (array) {
  1335. array.forEach(function (t) {
  1336. res.push(t[key]);
  1337. });
  1338. }
  1339. return res;
  1340. }
  1341. function array2obj(array, key) {
  1342. var resObj = {};
  1343. for (var i = 0; i < array.length; i++) {
  1344. resObj[array[i][key]] = array[i];
  1345. }
  1346. return resObj;
  1347. }
  1348. function getData(data) {
  1349. var res = {
  1350. series: [],
  1351. yAxis: []
  1352. };
  1353. for (let i = 0; i < data.length; i++) {
  1354. res.series.push({
  1355. name: '',
  1356. type: 'pie',
  1357. clockWise: false, //顺时加载
  1358. hoverAnimation: false, //鼠标移入变大
  1359. radius: [73 - i * 15 + '%', 68 - i * 15 + '%'],
  1360. center: ["30%", "55%"],
  1361. label: {
  1362. show: false
  1363. },
  1364. itemStyle: {
  1365. label: {
  1366. show: false,
  1367. },
  1368. labelLine: {
  1369. show: false
  1370. },
  1371. borderWidth: 5,
  1372. },
  1373. data: [
  1374. {
  1375. value: data[i].value,
  1376. name: data[i].name
  1377. },
  1378. {
  1379. value: sumValue - data[i].value,
  1380. name: '',
  1381. itemStyle: {
  1382. color: "rgba(0,0,0,0)",
  1383. borderWidth: 0
  1384. },
  1385. tooltip: {
  1386. show: false
  1387. },
  1388. hoverAnimation: false
  1389. }
  1390. ]
  1391. });
  1392. res.series.push({
  1393. name: '',
  1394. type: 'pie',
  1395. silent: true,
  1396. z: 1,
  1397. clockWise: false, //顺时加载
  1398. hoverAnimation: false, //鼠标移入变大
  1399. radius: [73 - i * 15 + '%', 68 - i * 15 + '%'],
  1400. center: ["30%", "55%"],
  1401. label: {
  1402. show: false
  1403. },
  1404. itemStyle: {
  1405. label: {
  1406. show: false,
  1407. },
  1408. labelLine: {
  1409. show: false
  1410. },
  1411. borderWidth: 5,
  1412. },
  1413. data: [
  1414. {
  1415. value: 7.5,
  1416. itemStyle: {
  1417. color: "rgb(3, 31, 62)",
  1418. borderWidth: 0
  1419. },
  1420. tooltip: {
  1421. show: false
  1422. },
  1423. hoverAnimation: false
  1424. },
  1425. {
  1426. value: 2.5,
  1427. name: '',
  1428. itemStyle: {
  1429. color: "rgba(0,0,0,0)",
  1430. borderWidth: 0
  1431. },
  1432. tooltip: {
  1433. show: false
  1434. },
  1435. hoverAnimation: false
  1436. }
  1437. ]
  1438. });
  1439. res.yAxis.push(data[i].value);
  1440. }
  1441. return res;
  1442. }
  1443. var option = {
  1444. legend: {
  1445. show: true,
  1446. icon: "circle",
  1447. top: "center",
  1448. top: '20%',
  1449. bottom: '53%',
  1450. left: "30%",
  1451. data: arrName,
  1452. width: 40,
  1453. padding: [0, 16],
  1454. itemGap: 25,
  1455. formatter: function (name) {
  1456. return "{title|" + name + "} {value|" + (objData[name].value) + "} {title|人}"
  1457. },
  1458. textStyle: {
  1459. rich: {
  1460. title: {
  1461. fontSize: 14,
  1462. lineHeight: 30,
  1463. color: "rgb(0, 178, 246)"
  1464. },
  1465. value: {
  1466. fontSize: 14,
  1467. lineHeight: 20,
  1468. color: "#fff"
  1469. }
  1470. }
  1471. },
  1472. },
  1473. tooltip: {
  1474. show: true,
  1475. trigger: "item",
  1476. formatter: "{b}:{c}人"
  1477. },
  1478. color: ['rgb(9,187,247)', 'rgb(184,254,165)', 'rgb(253,218,23)', 'rgb(252,152,12)'],
  1479. xAxis: [{
  1480. show: false
  1481. }],
  1482. series: optionData.series
  1483. };
  1484. if (option) {
  1485. myChart.setOption(option);
  1486. }
  1487. },
  1488. getCurrentTime() {
  1489. const now = new Date();
  1490. const year = now.getFullYear();
  1491. const month = now.getMonth() + 1;
  1492. const date = now.getDate();
  1493. const day = now.getDay();
  1494. const weekDays = ['星期日', '星期一', '星期二', '星期三', '星期四', '星期五', '星期六'];
  1495. const hour = now.getHours();
  1496. const minute = now.getMinutes();
  1497. const second = now.getSeconds();
  1498. const formattedMonth = month < 10 ? `0${month}` : month;
  1499. const formattedDate = date < 10 ? `0${date}` : date;
  1500. const formattedHour = hour < 10 ? `0${hour}` : hour;
  1501. const formattedMinute = minute < 10 ? `0${minute}` : minute;
  1502. const formattedSecond = second < 10 ? `0${second}` : second;
  1503. this.currentTime = `${year}年${formattedMonth}月${formattedDate}日 ${weekDays[day]} ${formattedHour}:${formattedMinute}:${formattedSecond}`;
  1504. },
  1505. },
  1506. };
  1507. </script>
  1508. <style scoped>
  1509. /* Your CSS styles here */
  1510. </style>