jczl.vue 82 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508
  1. <template>
  2. <div>
  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>66</u>次</span>
  35. <span>累计服务<u>66</u>次</span>
  36. <span>当年服务<u>166</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>66</u>次</span>
  46. <span>累计提供岗位<u>66</u>个</span>
  47. </div>
  48. <div class="jczl_tit">
  49. <span>累计服务<u>66</u>次</span>
  50. <span>当年服务<u>166</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>66</u>次</span>
  63. <span>提供就业岗位<u>66</u>个</span>
  64. </div>
  65. <div class="jczl_tit">
  66. <span>累计服务<u>66</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: 190px"
  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: 190px"
  182. ></div>
  183. </div>
  184. <!-- 婚姻比例 -->
  185. <div class="qkq_bmfw">
  186. <div
  187. id="sprh-hy"
  188. style="margin: 10px auto; width: 350px; height: 190px"
  189. ></div>
  190. </div>
  191. <!-- 婚姻比例 -->
  192. </div>
  193. <!-- 底部代码结束 -->
  194. <!--底部开始-->
  195. <div class="footer">
  196. <div class="nav-bottom">
  197. <div class="nav-bottom-left">
  198. <div class="nav-li-left">
  199. <span>经济运行</span>
  200. </div>
  201. <div class="nav-li-left">
  202. <span>城市管理</span>
  203. </div>
  204. <div class="nav-li-left" @click="serviceFAW('jtzl')">
  205. <span>交通治理</span>
  206. </div>
  207. <div class="nav-li-left on">
  208. <span>基层治理</span>
  209. </div>
  210. </div>
  211. <div class="nav-home-middle" @click="homePage('weather')">
  212. <img src="@/assets/images/home-btn.png"/>
  213. <a>返回首页</a>
  214. </div>
  215. <div class="nav-bottom-right">
  216. <div class="nav-li-right">
  217. <span>营商环境</span>
  218. </div>
  219. <div class="nav-li-right" @click="serviceFAW('yshj')">
  220. <span>政务运行</span>
  221. </div>
  222. <div class="nav-li-right" @click="serviceFAW('sprh')">
  223. <span>安全应急</span>
  224. </div>
  225. <div class="nav-li-right">
  226. <span>服务一汽</span>
  227. </div>
  228. </div>
  229. </div>
  230. </div>
  231. <!--底部开始-->
  232. </div>
  233. </template>
  234. <script>
  235. import * as echarts from 'echarts'
  236. import $ from 'jquery'
  237. import jQuery from 'jquery'
  238. import "@/assets/images/qkq_body.css";
  239. import "@/assets/images/qkq_index.css";
  240. import "@/assets/images/qkq_sprh.css";
  241. import supermap from "@/views/supermap/supermap";
  242. export default {
  243. name: "jczl",
  244. components: {supermap},
  245. data() {
  246. return {
  247. currentTime: '',
  248. sltProps: null,
  249. btnOne: true,
  250. btnTwo: false
  251. }
  252. },
  253. created() {
  254. },
  255. mounted() {
  256. this.regionTop();
  257. this.trend();
  258. this.matterUpTop();
  259. this.matterTop();
  260. this.tsrqqktj();
  261. this.xbbl();
  262. this.nl();
  263. this.hy();
  264. // 每秒刷新时间
  265. setInterval(() => {
  266. this.getCurrentTime();
  267. }, 1000);
  268. },
  269. methods: {
  270. sltHandle() {
  271. this.btnOne = true
  272. this.btnTwo = false
  273. this.$refs.supermap.getSupermap(null, null, null, "slt", null, null)
  274. },
  275. yxtHandle() {
  276. this.btnTwo = true
  277. this.btnOne = false
  278. this.$refs.supermap.getSupermap(null, null, null, "yxt", null, null)
  279. },
  280. homePage(route) {
  281. this.$router.push({path: route});
  282. },
  283. serviceFAW(route) {
  284. this.$router.push({path: route});
  285. },
  286. smalClick(val) {
  287. var node = $(val).next();
  288. if (node.is(":hidden")) {
  289. //如果node是隐藏的则显示node元素,否则隐藏
  290. node.show();
  291. } else {
  292. node.hide();
  293. }
  294. },
  295. regionTop() {
  296. //便民服务
  297. var myChart = echarts.init(document.getElementById('jczl-bmfw'));
  298. let valueData = [];
  299. let labelData = [];
  300. for (var i = 1; i <= 6; i++) {
  301. labelData.push("类型" + i);
  302. var lineNumber = Math.floor(Math.random() * 1000);
  303. valueData.push(lineNumber);
  304. }
  305. var option = {
  306. "backgroundColor": "rgba(0, 0, 0, 0)",
  307. title: {
  308. show: true,
  309. text: '',
  310. textStyle: {
  311. color: '#fff',
  312. fontSize: '12',
  313. },
  314. top: '0%',
  315. left: '20%',
  316. },
  317. tooltip: {
  318. trigger: 'axis',
  319. axisPointer: {
  320. type: 'shadow'
  321. }
  322. },
  323. grid: {
  324. top: '10%',
  325. left: '15%',
  326. right: '5%',
  327. buttom: '0',
  328. },
  329. xAxis: {
  330. type: 'category',
  331. axisLine: {
  332. lineStyle: {
  333. color: 'rgba(255,255,255,0.12)',
  334. },
  335. },
  336. axisLabel: {
  337. margin: 10,
  338. color: '#e2e9ff',
  339. textStyle: {
  340. fontSize: 12
  341. },
  342. },
  343. axisTick: {
  344. show: false,
  345. },
  346. data: labelData
  347. },
  348. yAxis: {
  349. name: '',
  350. nameTextStyle: {
  351. color: '#fff',
  352. },
  353. type: 'value',
  354. axisLine: {
  355. show: false,
  356. lineStyle: {
  357. color: 'rgba(255,255,255,0.12)'
  358. },
  359. },
  360. axisLabel: {
  361. formatter: '{value}',
  362. color: '#e2e9ff',
  363. },
  364. splitLine: {
  365. lineStyle: {
  366. color: 'rgba(255,255,255,0.12)'
  367. }
  368. },
  369. axisTick: {
  370. show: false,
  371. lineStyle: {
  372. color: '#fff',
  373. },
  374. },
  375. },
  376. // 切片
  377. series: [
  378. {
  379. type: 'lines',
  380. coordinateSystem: 'cartesian2d',
  381. data: valueData.map((item, index) => {
  382. return {
  383. coords: [
  384. [index, 0],
  385. [index, item - 4]
  386. ]
  387. };
  388. }),
  389. effect: {
  390. show: true,
  391. period: 3.5,// 周期 速度 2.5
  392. trailLength: 0.5, //控制拖尾长度
  393. symbolSize: 25, // ⭐⭐星星大小
  394. symbol:
  395. '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',
  396. loop: true,
  397. color: '#ffffff' //流光颜色
  398. },
  399. lineStyle: {
  400. width: 0,
  401. opacity: 0.6,
  402. curveness: 0
  403. },
  404. z: 999
  405. },
  406. {
  407. type: 'bar',
  408. data: valueData,
  409. barWidth: '20px',
  410. itemStyle: {
  411. normal: {
  412. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
  413. offset: 0,
  414. color: 'rgba(0,244,255,1)' // 0% 处的颜色
  415. }, {
  416. offset: 1,
  417. color: 'rgba(0,77,167,1)' // 100% 处的颜色
  418. }], false),
  419. barBorderRadius: [30, 30, 30, 30],
  420. shadowColor: 'rgba(0,160,221,1)',
  421. shadowBlur: 4,
  422. }
  423. },
  424. }]
  425. };
  426. if (option) {
  427. myChart.setOption(option);
  428. }
  429. },
  430. trend() {
  431. //就业服务
  432. var myChart = echarts.init(document.getElementById('sprh-zpfw'));
  433. var monthData = [];
  434. var lineData = [];
  435. let data = []
  436. let arr1 = []
  437. let coords = {}
  438. for (var i = 1; i <= 12; i++) {
  439. let arr = []
  440. monthData.push(i + '月');
  441. var lineNumber = Math.floor(Math.random() * 10000);
  442. lineData.push(lineNumber);
  443. arr.push(i + "月")
  444. arr.push(lineNumber)
  445. arr1.push(arr)
  446. }
  447. this.$set(coords, "coords", arr1)
  448. data.push(coords)
  449. var img = [
  450. 'image://',
  451. 'image://',
  452. 'image://',
  453. 'image://',
  454. ]
  455. var option = {
  456. grid: {
  457. top: 10,
  458. bottom: 10,
  459. containLabel: true,
  460. },
  461. tooltip: {
  462. trigger: 'axis',
  463. axisPointer: {
  464. lineStyle: {
  465. color: {
  466. type: 'linear',
  467. x: 0,
  468. y: 0,
  469. x2: 0,
  470. y2: 1,
  471. colorStops: [
  472. {
  473. offset: 0,
  474. color: 'rgba(255,255,255,0)', // 0% 处的颜色
  475. },
  476. {
  477. offset: 0.5,
  478. color: 'rgba(255,255,255,1)', // 100% 处的颜色
  479. },
  480. {
  481. offset: 1,
  482. color: 'rgba(255,255,255,0)', // 100% 处的颜色
  483. },
  484. ],
  485. global: false, // 缺省为 false
  486. },
  487. },
  488. },
  489. },
  490. xAxis: [
  491. {
  492. type: 'category',
  493. boundaryGap: false,
  494. axisLabel: {
  495. formatter: '{value}',
  496. fontSize: 14,
  497. margin: 10,
  498. textStyle: {
  499. color: '#eaf7ff',
  500. },
  501. },
  502. axisLine: {
  503. lineStyle: {
  504. color: '#243753',
  505. },
  506. },
  507. splitLine: {
  508. show: true,
  509. lineStyle: {
  510. color: '#243753',
  511. },
  512. },
  513. axisTick: {
  514. show: false,
  515. },
  516. data: monthData,
  517. },
  518. ],
  519. yAxis: [
  520. {
  521. boundaryGap: false,
  522. type: 'value',
  523. axisLabel: {
  524. textStyle: {
  525. color: '#eaf7ff',
  526. },
  527. },
  528. nameTextStyle: {
  529. color: '#fff',
  530. fontSize: 12,
  531. lineHeight: 40,
  532. },
  533. splitLine: {
  534. lineStyle: {
  535. color: '#243753',
  536. },
  537. },
  538. axisLine: {
  539. show: true,
  540. lineStyle: {
  541. color: '#283352',
  542. },
  543. },
  544. axisTick: {
  545. show: false,
  546. },
  547. },
  548. ],
  549. series: [
  550. {
  551. symbolSize: 150,
  552. symbol: img[2],
  553. name: '招聘次数',
  554. type: 'line',
  555. smooth: true,
  556. showSymbol: true,
  557. zlevel: 3,
  558. itemStyle: {
  559. normal: {
  560. borderColor: '#a3c8d8',
  561. borderWidth: 5,
  562. color: '#eaf7ff',
  563. }
  564. },
  565. lineStyle: {
  566. normal: {
  567. width: 2,
  568. color: '#0ea8df',
  569. },
  570. },
  571. areaStyle: {
  572. normal: {
  573. color: new echarts.graphic.LinearGradient(
  574. 0,
  575. 0,
  576. 0,
  577. 1,
  578. [
  579. {
  580. offset: 0,
  581. color: 'rgba(88,255,255,0.2)',
  582. },
  583. {
  584. offset: 0.8,
  585. color: 'rgba(88,255,255,0)',
  586. },
  587. ],
  588. false
  589. ),
  590. },
  591. },
  592. data: lineData,
  593. },
  594. {
  595. name: '滑行的光点',
  596. type: 'lines',
  597. coordinateSystem: 'cartesian2d',
  598. symbolSize: 30,
  599. polyline: true,
  600. effect: {
  601. show: true,
  602. trailLength: 0,
  603. symbol: "arrow",
  604. period: 10, //光点滑动速度
  605. symbolSize: 150,
  606. symbol: img[0]
  607. },
  608. lineStyle: {
  609. normal: {
  610. width: 1,
  611. opacity: 0.6,
  612. curveness: 0.2
  613. }
  614. },
  615. data: data
  616. }
  617. ],
  618. };
  619. if (option) {
  620. myChart.setOption(option);
  621. }
  622. },
  623. matterUpTop() {
  624. // 便民招聘
  625. var myChart = echarts.init(document.getElementById('sprh-ymcxfw'));
  626. var monthData = [];
  627. var lineData = [];
  628. let data = []
  629. let arr1 = []
  630. let coords = {}
  631. for (var i = 1; i <= 12; i++) {
  632. let arr = []
  633. monthData.push(i + '月');
  634. var lineNumber = Math.floor(Math.random() * 10000) / 100;
  635. lineData.push(lineNumber);
  636. arr.push(i + "月")
  637. arr.push(lineNumber)
  638. arr1.push(arr)
  639. }
  640. this.$set(coords, "coords", arr1)
  641. data.push(coords)
  642. var img = [
  643. 'image://',
  644. 'image://',
  645. 'image://',
  646. 'image://',
  647. ]
  648. var option = {
  649. grid: {
  650. left: '15%',
  651. top: '5%',
  652. bottom: '30%',
  653. right: '5%',
  654. },
  655. tooltip: {
  656. trigger: 'axis',
  657. show: true,
  658. textStyle: {
  659. fontSize: 14,
  660. color: '#eaf7ff',
  661. },
  662. backgroundColor: 'rgba(50,50,50,0.7)',
  663. borderWidth: 0,
  664. },
  665. dataZoom: [
  666. {
  667. show: true,
  668. height: 4,
  669. xAxisIndex: [0],
  670. bottom: 43,
  671. start: 0,
  672. end: 80,
  673. handleIcon:
  674. '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',
  675. handleSize: '110%',
  676. handleStyle: {
  677. color: 'rgba(255, 255, 255,0.5)',
  678. },
  679. textStyle: {
  680. color: '#fff',
  681. fontSize: 10,
  682. },
  683. fillerColor: 'rgba(36, 180, 223, 1.0)',
  684. borderColor: 'rgba(66, 130, 197,1)',
  685. backgroundColor: 'rgba(12, 67, 124,0.5)',
  686. showDataShadow: false,
  687. brushSelect: false,
  688. },
  689. {
  690. type: 'inside',
  691. },
  692. ],
  693. yAxis: {
  694. show: true,
  695. min: 0,
  696. max: 100,
  697. type: 'value',
  698. nameTextStyle: {
  699. color: 'rgba(255,255,255,0.7)',
  700. fontSize: 12,
  701. },
  702. axisLine: {
  703. show: true,
  704. lineStyle: {
  705. color: 'rgba(28, 158, 222, 1)',
  706. type: 'solid',
  707. },
  708. },
  709. axisTick: {
  710. show: true,
  711. lineStyle: {
  712. color: 'rgba(28, 158, 222, 1)',
  713. },
  714. },
  715. axisLabel: {
  716. formatter: '{value}%',
  717. color: '#eaf7ff',
  718. },
  719. splitLine: {
  720. show: true,
  721. lineStyle: {
  722. type: 'solid',
  723. color: 'rgba(0, 206, 209, 0.3)',
  724. width: 0.5,
  725. },
  726. },
  727. },
  728. xAxis: {
  729. show: true,
  730. type: 'category',
  731. boundaryGap: false,
  732. nameTextStyle: {
  733. fontSize: 14,
  734. },
  735. axisLine: {
  736. lineStyle: {
  737. color: '#eaf7ff',
  738. },
  739. },
  740. data: monthData,
  741. },
  742. series: [
  743. {
  744. type: 'line',
  745. smooth: true,
  746. symbolSize: 3,
  747. data: lineData,
  748. itemStyle: {
  749. normal: {
  750. width: 1,
  751. color: 'rgb(0, 255, 255)',
  752. },
  753. },
  754. lineStyle: {
  755. normal: {
  756. color: 'rgb(0, 146, 246)',
  757. width: 2,
  758. },
  759. },
  760. areaStyle: {
  761. normal: {
  762. color: new echarts.graphic.LinearGradient(
  763. 0,
  764. 0,
  765. 0,
  766. 1,
  767. [
  768. {
  769. offset: 0,
  770. color: 'rgba(0, 146, 246,0.2)',
  771. },
  772. {
  773. offset: 0.5,
  774. color: 'rgba(0, 146, 246,0.1)',
  775. },
  776. {
  777. offset: 1,
  778. color: 'rgba(0, 146, 246,0)',
  779. },
  780. ],
  781. false
  782. ),
  783. },
  784. },
  785. },
  786. {
  787. name: '滑行的光点',
  788. type: 'lines',
  789. coordinateSystem: 'cartesian2d',
  790. symbolSize: 30,
  791. polyline: true,
  792. effect: {
  793. show: true,
  794. trailLength: 0,
  795. symbol: "arrow",
  796. period: 10, //光点滑动速度
  797. symbolSize: 150,
  798. symbol: img[0]
  799. },
  800. lineStyle: {
  801. normal: {
  802. width: 1,
  803. opacity: 0.6,
  804. curveness: 0.2
  805. }
  806. },
  807. data: data
  808. }
  809. ],
  810. }
  811. if (option) {
  812. myChart.setOption(option);
  813. }
  814. },
  815. matterTop() {
  816. // 居民总数
  817. var myChart = echarts.init(document.getElementById('sprh-jmzs'));
  818. var data = ['前程街道办事处', '富民街道办事处', '东风街道办事处', '锦程街道办事处']
  819. let labelData = []
  820. let valueData = []
  821. for (var i = 0; i < data.length; i++) {
  822. labelData.push(data[i]);
  823. var lineNumber = Math.floor(Math.random() * 10000) / 100;
  824. valueData.push(lineNumber);
  825. }
  826. var option = {
  827. xAxis: {
  828. show: false,
  829. },
  830. tooltip: {
  831. show: true,
  832. },
  833. grid: {
  834. top: '5%',
  835. left: '10%',
  836. right: '5%',
  837. bottom: '0'
  838. },
  839. yAxis: [
  840. {
  841. splitLine: 'none',
  842. axisLine: 'none',
  843. axisLabel: {
  844. verticalAlign: 'bottom',
  845. align: 'left',
  846. padding: [0, 0, 5, 5],
  847. textStyle: {
  848. color: '#FFFFFF',
  849. fontSize: '14',
  850. },
  851. },
  852. data: labelData,
  853. },
  854. {
  855. axisLine: 'none',
  856. data: valueData,
  857. axisLabel: {
  858. show: true,
  859. verticalAlign: 'bottom',
  860. align: 'right',
  861. padding: [0, 0, 0, 0],
  862. textStyle: {
  863. color: '#fff',
  864. fontSize: '14',
  865. }
  866. },
  867. },
  868. ],
  869. series: [
  870. {
  871. type: 'bar',
  872. showBackground: true,
  873. data: valueData,
  874. barWidth: 8,
  875. itemStyle: {
  876. normal: {
  877. color: new echarts.graphic.LinearGradient(0, 0, 1, 0, [
  878. {
  879. offset: 0,
  880. color: 'rgba(28, 88, 177, 1.0)',
  881. },
  882. {
  883. offset: 1,
  884. color: 'rgba(17, 224, 255, 1.0)',
  885. },
  886. ]),
  887. },
  888. },
  889. },
  890. {
  891. type: 'lines',
  892. coordinateSystem: 'cartesian2d',
  893. data: valueData.map((item, index) => {
  894. return {
  895. coords: [
  896. [0, index],
  897. [item , index],
  898. ]
  899. };
  900. }),
  901. effect: {
  902. show: true,
  903. period: 2.5,
  904. trailLength: 0.5, //控制拖尾长度
  905. symbolSize: [15,2],
  906. symbol:this.$store.state.common.echarts_baseStreamer,
  907. loop: true,
  908. color: '#fff' //流光颜色
  909. },
  910. lineStyle: {
  911. width: 0,
  912. opacity: 0.6,
  913. curveness: 0
  914. },
  915. z: 99
  916. },
  917. ],
  918. };
  919. if (option) {
  920. myChart.setOption(option);
  921. }
  922. },
  923. tsrqqktj() {
  924. // 特殊人群
  925. var myChart = echarts.init(document.getElementById('sprh-tsrq'));
  926. var data = ['社区矫正人员', '劳模', '志愿者', '失业人员', '信访人员', '残疾人', '低保人员', '精神病人', '释解安置人员', '吸毒人员', '重点稳控人员', '活跃分子', '闹访骨干', '吸毒人员未成年子女', '服刑人员未成年子女', '留守人员', '军烈属', '台胞侨胞', '老龄人', '失信被执行人', '社保人员', '医保人员']
  927. var valueData = [];
  928. let labelData = []
  929. for (var i = 0; i < data.length; i++) {
  930. labelData.push(data[i]);
  931. var lineNumber = Math.floor(Math.random() * 10000);
  932. valueData.push(lineNumber);
  933. }
  934. var option = {
  935. xAxis: {
  936. show: false,
  937. },
  938. tooltip: {
  939. show: true,
  940. },
  941. grid: {
  942. top: '1%',
  943. left: '10%',
  944. right: '5%',
  945. bottom: '0'
  946. },
  947. yAxis: [
  948. {
  949. splitLine: 'none',
  950. axisLine: 'none',
  951. axisLabel: {
  952. verticalAlign: 'bottom',
  953. align: 'left',
  954. padding: [0, 0, 5, 5],
  955. textStyle: {
  956. color: '#FFFFFF',
  957. fontSize: '14',
  958. },
  959. },
  960. data: labelData,
  961. },
  962. {
  963. axisLine: 'none',
  964. data: valueData,
  965. axisLabel: {
  966. show: true,
  967. verticalAlign: 'bottom',
  968. align: 'right',
  969. padding: [0, 0, 0, 0],
  970. textStyle: {
  971. color: '#fff',
  972. fontSize: '14',
  973. }
  974. },
  975. },
  976. ],
  977. series: [
  978. {
  979. type: 'bar',
  980. showBackground: true,
  981. data: valueData,
  982. barWidth: 8,
  983. itemStyle: {
  984. normal: {
  985. color: new echarts.graphic.LinearGradient(0, 0, 1, 0, [
  986. {
  987. offset: 0,
  988. color: 'rgba(28, 88, 177, 1.0)',
  989. },
  990. {
  991. offset: 1,
  992. color: 'rgba(17, 224, 255, 1.0)',
  993. },
  994. ]),
  995. },
  996. },
  997. },
  998. {
  999. type: 'lines',
  1000. coordinateSystem: 'cartesian2d',
  1001. data: valueData.map((item, index) => {
  1002. return {
  1003. coords: [
  1004. [0, index],
  1005. [item , index],
  1006. ]
  1007. };
  1008. }),
  1009. effect: {
  1010. show: true,
  1011. period: 2.5,
  1012. trailLength: 0.5, //控制拖尾长度
  1013. symbolSize: [15,2],
  1014. symbol:this.$store.state.common.echarts_baseStreamer,
  1015. loop: true,
  1016. color: '#fff' //流光颜色
  1017. },
  1018. lineStyle: {
  1019. width: 0,
  1020. opacity: 0.6,
  1021. curveness: 0
  1022. },
  1023. z: 99
  1024. },
  1025. ],
  1026. };
  1027. if (option) {
  1028. myChart.setOption(option);
  1029. }
  1030. },
  1031. xbbl() {
  1032. // 性别比例
  1033. var myChart = echarts.init(document.getElementById('sprh-xbbl'));
  1034. let index = 0;
  1035. const res = [{
  1036. "name": "男",
  1037. "value": 370
  1038. },
  1039. {
  1040. "name": "女",
  1041. "value": 263
  1042. }
  1043. ]
  1044. const border =
  1045. '';
  1046. const man =
  1047. '';
  1048. const woman =
  1049. '';
  1050. const color = ['#00FFFF', 'rgba(196,36,255,1)'];
  1051. function fun() {
  1052. var timer = setInterval(function() {
  1053. console.log(index)
  1054. myChart.dispatchAction({
  1055. type: 'hideTip',
  1056. seriesIndex: 0,
  1057. dataIndex: index
  1058. });
  1059. // 显示提示框
  1060. myChart.dispatchAction({
  1061. type: 'showTip',
  1062. seriesIndex: 0,
  1063. dataIndex: index
  1064. });
  1065. // 取消高亮指定的数据图形
  1066. myChart.dispatchAction({
  1067. type: 'downplay',
  1068. seriesIndex: 0,
  1069. dataIndex: index == 0 ? 2 : index - 1
  1070. });
  1071. myChart.dispatchAction({
  1072. type: 'highlight',
  1073. seriesIndex: 0,
  1074. dataIndex: index
  1075. });
  1076. index++;
  1077. if (index > 2) {
  1078. index = 0;
  1079. }
  1080. }, 3000)
  1081. }
  1082. fun()
  1083. var option = {
  1084. color,
  1085. graphic: {
  1086. elements: [{
  1087. type: 'image',
  1088. z: 3,
  1089. style: {
  1090. image: border,
  1091. width: 150,
  1092. height: 150
  1093. },
  1094. left: 'center',
  1095. top: 'center',
  1096. position: [50, 50]
  1097. },
  1098. {
  1099. type: 'image',
  1100. z: 3,
  1101. style: {
  1102. image: man,
  1103. width: 45,
  1104. height: 80
  1105. },
  1106. left: '36%',
  1107. top: 'center'
  1108. },
  1109. {
  1110. type: 'image',
  1111. z: 3,
  1112. style: {
  1113. image: woman,
  1114. width: 45,
  1115. height: 80
  1116. },
  1117. right: '36%',
  1118. top: 'center'
  1119. }
  1120. ]
  1121. },
  1122. tooltip: {
  1123. show: false
  1124. },
  1125. toolbox: {
  1126. show: false
  1127. },
  1128. series: [{
  1129. name: '',
  1130. type: 'pie',
  1131. center: ['50%', '50%'],
  1132. radius: ['90%', '80%'],
  1133. clockwise: true,
  1134. avoidLabelOverlap: true,
  1135. hoverOffset: 30,
  1136. emphasis:{
  1137. itemStyle:{
  1138. borderColor: '#f3f3f3',
  1139. borderWidth: 6
  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: 20,
  1156. length2: 30,
  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: '15%',
  1196. top: '10%',
  1197. bottom: '12%',
  1198. right: '8%'
  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. let data = ['已婚', '未婚', '离异']
  1313. let nameData = [];
  1314. let valueData = [];
  1315. for (var i = 0; i < data.length; i++) {
  1316. let object1 = {}
  1317. let object2 = {}
  1318. let tooltip = {}
  1319. let labelData = []
  1320. let itemStyle = {
  1321. normal: {
  1322. color: 'rgba(0,0,0,0)',
  1323. label: {
  1324. show: false
  1325. },
  1326. labelLine: {
  1327. show: false
  1328. }
  1329. },
  1330. emphasis: {
  1331. color: 'rgba(0,0,0,0)'
  1332. }
  1333. };
  1334. nameData.push(data[i])
  1335. var lineNumber = Math.floor(Math.random() * 10000);
  1336. this.$set(object1, "name", data[i]);
  1337. this.$set(object1, "value", lineNumber);
  1338. this.$set(object2, "name", "总数");
  1339. this.$set(object2, "value", lineNumber += lineNumber);
  1340. this.$set(object2, "itemStyle", itemStyle);
  1341. this.$set(tooltip, "show", false);
  1342. this.$set(object2, "tooltip", tooltip);
  1343. labelData.push(object1);
  1344. labelData.push(object2);
  1345. valueData.push(labelData)
  1346. }
  1347. var dataStyle = {
  1348. normal: {
  1349. label: {
  1350. show: false
  1351. },
  1352. labelLine: {
  1353. show: false
  1354. },
  1355. // shadowBlur: 15,
  1356. // shadowColor: 'white',
  1357. }
  1358. };
  1359. var placeHolderStyle = {
  1360. normal: {
  1361. color: 'rgba(0,0,0,0)',
  1362. label: {
  1363. show: false
  1364. },
  1365. labelLine: {
  1366. show: false
  1367. }
  1368. },
  1369. emphasis: {
  1370. color: 'rgba(0,0,0,0)'
  1371. }
  1372. };
  1373. var option = {
  1374. color: ['#2b7be2', '#19c4e6', '#00bf5f', '#FDDD60', '#FFB72D'],
  1375. tooltip: {
  1376. show: true,
  1377. formatter: "{b} : {c}"
  1378. },
  1379. legend: {
  1380. top: "2%",
  1381. x: 'right',
  1382. left: "35%",
  1383. itemWidth: 0,
  1384. itemHeight: 0,
  1385. data: nameData,
  1386. itemGap: 0,
  1387. textStyle: {
  1388. color: '#ttf',
  1389. fontFamily: 'Alibaba PuHuiTi',
  1390. align: 'right',
  1391. fontSize: '14px',
  1392. x: 'right',
  1393. textAlign: 'right'
  1394. },
  1395. selectedMode: true,
  1396. orient: "vertical",
  1397. },
  1398. series: [{
  1399. name: 'Line 4',
  1400. type: 'pie',
  1401. clockWise: true,
  1402. hoverAnimation: false,
  1403. radius: ['90%', '75%'],
  1404. itemStyle: dataStyle,
  1405. data: valueData[0]
  1406. }, {
  1407. name: 'Line 3',
  1408. type: 'pie',
  1409. clockWise: true,
  1410. radius: ['80%', '65%'],
  1411. itemStyle: dataStyle,
  1412. hoverAnimation: false,
  1413. data: valueData[1]
  1414. }, {
  1415. name: 'Line 2',
  1416. type: 'pie',
  1417. clockWise: true,
  1418. hoverAnimation: false,
  1419. radius: ['70%', '55%'],
  1420. itemStyle: dataStyle,
  1421. data: valueData[2]
  1422. }
  1423. ]
  1424. };
  1425. var currentIndex = -1;
  1426. var timer = setInterval(function () {
  1427. // 生成新的随机数据
  1428. currentIndex++;
  1429. if (currentIndex >= 3) {
  1430. currentIndex = 0;
  1431. for (var i = 0; i < valueData.length; i++) {
  1432. valueData[i][0].value = Math.floor(Math.random() * 10000);
  1433. }
  1434. } else {
  1435. valueData[currentIndex][0].value = Math.floor(Math.random() * 10000);
  1436. }
  1437. // 更新 option 中的数据
  1438. option.series[0].data = valueData[0];
  1439. option.series[1].data = valueData[1];
  1440. option.series[2].data = valueData[2];
  1441. // 重新渲染图表
  1442. myChart.setOption(option);
  1443. }, 1000); // 每秒更新一次数据
  1444. if (option) {
  1445. myChart.setOption(option);
  1446. }
  1447. },
  1448. getCurrentTime() {
  1449. const now = new Date();
  1450. const year = now.getFullYear();
  1451. const month = now.getMonth() + 1;
  1452. const date = now.getDate();
  1453. const day = now.getDay();
  1454. const weekDays = ['星期日', '星期一', '星期二', '星期三', '星期四', '星期五', '星期六'];
  1455. const hour = now.getHours();
  1456. const minute = now.getMinutes();
  1457. const second = now.getSeconds();
  1458. const formattedMonth = month < 10 ? `0${month}` : month;
  1459. const formattedDate = date < 10 ? `0${date}` : date;
  1460. const formattedHour = hour < 10 ? `0${hour}` : hour;
  1461. const formattedMinute = minute < 10 ? `0${minute}` : minute;
  1462. const formattedSecond = second < 10 ? `0${second}` : second;
  1463. this.currentTime = `${year}年${formattedMonth}月${formattedDate}日 ${weekDays[day]} ${formattedHour}:${formattedMinute}:${formattedSecond}`;
  1464. },
  1465. },
  1466. };
  1467. </script>
  1468. <style scoped>
  1469. /* Your CSS styles here */
  1470. </style>