echarts_div.js 49 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407
  1. /***
  2. * 接口数量 和 接口占比 统一由这个方法调用
  3. */
  4. function countAndPercent(year){
  5. if(year == null){
  6. // year = new Date().getFullYear();
  7. year = '';
  8. }
  9. $.post("/visualization/countAndPercent",{
  10. year:year
  11. },function (res) {
  12. // console.log("四个球 qiu res=", res)
  13. //渲染接口数量
  14. if(res.count.length > 0){
  15. $(".data1").remove();
  16. let tmpl = "";
  17. for(let i=0;i<res.count.length;i++){
  18. if (i==0){
  19. tmpl += "<div class='data1 data_left'><div class='qiu'>";
  20. }else{
  21. tmpl += "<div class='data1'><div class='qiu'>";
  22. }
  23. tmpl += "<p>"+res.count[i].count+"个</p>";
  24. tmpl += "</div>";
  25. tmpl += "<span>"+res.count[i].shareType+"</span></div>";
  26. }
  27. $(".con_sk").append(tmpl);
  28. }
  29. //渲染接口占比
  30. jkzb(res.percent);
  31. });
  32. }
  33. // 接口占比
  34. function jkzb(data) {
  35. // console.log("接口占比 data=", data)
  36. let percent = new Array();
  37. percent.push({'shareTypeDict': 'share_type_1', 'shareType': '市直共享接口', 'count': 0, 'percent': 0});
  38. percent.push({'shareTypeDict': 'share_type_2', 'shareType': '市直归集接口', 'count': 0, 'percent': 0});
  39. percent.push({'shareTypeDict': 'share_type_3', 'shareType': '省上报接口', 'count': 0, 'percent': 0});
  40. percent.push({'shareTypeDict': 'share_type_4', 'shareType': '省共享接口', 'count': 0, 'percent': 0});
  41. for(let i = 0; i < percent.length; i++){
  42. for(let j = 0; j < data.length; j++){
  43. if(percent[i].shareTypeDict == data[j].shareTypeDict){
  44. percent[i].shareType = data[j].shareType;
  45. percent[i].count = parseInt(data[j].count);
  46. percent[i].percent = parseInt(data[j].percent);
  47. }
  48. }
  49. }
  50. let trafficWay = [];
  51. let jsArr = [];
  52. let html = "";
  53. let classArr = ['sgj','sgx','sgj2','sgx2'];
  54. //把JSON格式处理为JSONArray并渲染
  55. if(percent.length>0){
  56. //渲染饼图
  57. for(let i=0;i<percent.length;i++){
  58. let js = {};
  59. js.name = percent[i].shareType;
  60. js.value = percent[i].count;
  61. jsArr.push(js);
  62. //组装页面元素
  63. html += '<div class="'+classArr[i]+' jkzb_list">';
  64. html += '<h3><i></i>'+percent[i].shareType+'</h3>';
  65. html += '<p><span>'+percent[i].count+'</span><span>'+percent[i].percent+'%</span></p>';
  66. html += '</div>';
  67. }
  68. trafficWay = jsArr;
  69. //渲染页面数据
  70. $("#pie_div").html("");
  71. $("#pie_div").append(html);
  72. }else{
  73. let html = '<div class="sgj jkzb_list">' +
  74. ' <h3><i></i>市归集</h3>' +
  75. ' <p><span>0</span><span>0%</span></p>' +
  76. '</div>' +
  77. '<div class="sgx jkzb_list">' +
  78. ' <h3><i></i>市共享</h3>' +
  79. ' <p><span>0</span><span>0%</span></p>' +
  80. '</div>' +
  81. '<div class="sgj2 jkzb_list">' +
  82. ' <h3><i></i>省归集</h3>' +
  83. ' <p><span>0</span><span>0%</span></p>' +
  84. '</div>' +
  85. '<div class="sgx2 jkzb_list">' +
  86. ' <h3><i></i>省共享</h3>' +
  87. ' <p><span>0</span><span>0%</span></p>' +
  88. '</div>';
  89. //渲染页面数据
  90. $("#pie_div").html("");
  91. $("#pie_div").append(html);
  92. }
  93. // 基于准备好的dom,初始化echarts实例
  94. var tootipTimer = null;
  95. var myChart1 = echarts.init(document.getElementById('pie_charts'));
  96. var img = ""
  97. var nameArray = trafficWay.map(item => {
  98. return item.name
  99. })
  100. var data = [];
  101. var color = ['#ff3000', '#00cfff', '#006ced', '#ffe000', '#ffa800', '#ff5b00', '#ff3000', '#ff3000']
  102. var size = 120
  103. var left = 60
  104. for (var i = 0; i < trafficWay.length; i++) {
  105. data.push({
  106. value: trafficWay[i].value,
  107. name: trafficWay[i].name,
  108. itemStyle: {
  109. normal: {
  110. borderWidth: 5,
  111. shadowBlur: 20,
  112. borderColor: color[i],
  113. shadowColor: color[i]
  114. }
  115. }
  116. });
  117. }
  118. var seriesOption = [{
  119. name: '',
  120. type: 'pie',
  121. clockWise: false,
  122. // 适配给你写好了
  123. radius: [72, 76],
  124. width: size,
  125. height: size,
  126. center: ['51%', '50%'],
  127. left: left,
  128. top: "center",
  129. hoverAnimation: false,
  130. itemStyle: {
  131. normal: {
  132. label: {
  133. show: false,
  134. position: 'outside',
  135. color: '#ddd',
  136. formatter: function (params) {
  137. var percent = 0;
  138. var total = 0;
  139. for (var i = 0; i < trafficWay.length; i++) {
  140. total += trafficWay[i].value;
  141. }
  142. percent = ((params.value / total) * 100).toFixed(0);
  143. if (params.name !== '') {
  144. return '接口占比:' + params.name + '\n' + '\n' + '占百分比:' + percent + '%';
  145. } else {
  146. return '';
  147. }
  148. },
  149. },
  150. }
  151. },
  152. data: data
  153. }];
  154. option = {
  155. // backgroundColor: '#01132e',
  156. color: color,
  157. graphic: {
  158. elements: [{
  159. type: "image",
  160. z: 3,
  161. style: {
  162. image: img,
  163. width: size,
  164. height: size
  165. },
  166. left: left,
  167. top: 'center',
  168. }]
  169. },
  170. legend: [{
  171. // icon: `path://M881.387 297.813c38.08 65.387 57.28 136.747 57.28 214.187s-19.094 148.8-57.28 214.187c-38.187 65.28-89.92 117.12-155.2 155.2S589.44 938.667 512 938.667s-148.8-19.094-214.187-57.28c-65.28-38.08-117.013-89.814-155.306-155.307C104.427 660.8 85.333 589.44 85.333 512c0-77.333 19.094-148.693 57.28-214.187 38.08-65.28 89.814-117.013 155.307-155.306C363.2 104.533 434.56 85.333 512 85.333c77.333 0 148.693 19.094 214.187 57.28 65.28 38.187 117.013 89.92 155.2 155.2z m-217.707-47.36C617.387 223.467 566.827 209.92 512 209.92s-105.387 13.547-151.68 40.533-82.987 63.68-109.973 109.974c-26.987 46.293-40.534 96.853-40.534 151.68s13.547 105.386 40.534 151.68c26.986 46.293 63.68 82.986 109.973 109.973 46.293 26.987 96.853 40.533 151.68 40.533s105.387-13.546 151.68-40.533c46.293-26.987 82.987-63.68 109.973-109.973 26.987-46.294 40.534-96.854 40.534-151.68s-13.547-105.387-40.534-151.68c-27.093-46.294-63.786-82.987-109.973-109.974z`,
  172. orient: 'vertical',
  173. // x: 'left',
  174. data: nameArray.slice(4, 8),
  175. left: '10%',
  176. top: 'center',
  177. itemWidth: 15,
  178. align: 'left',
  179. textStyle: {
  180. color: "#fff"
  181. },
  182. itemGap: 20
  183. },
  184. {
  185. // icon: `path://M881.387 297.813c38.08 65.387 57.28 136.747 57.28 214.187s-19.094 148.8-57.28 214.187c-38.187 65.28-89.92 117.12-155.2 155.2S589.44 938.667 512 938.667s-148.8-19.094-214.187-57.28c-65.28-38.08-117.013-89.814-155.306-155.307C104.427 660.8 85.333 589.44 85.333 512c0-77.333 19.094-148.693 57.28-214.187 38.08-65.28 89.814-117.013 155.307-155.306C363.2 104.533 434.56 85.333 512 85.333c77.333 0 148.693 19.094 214.187 57.28 65.28 38.187 117.013 89.92 155.2 155.2z m-217.707-47.36C617.387 223.467 566.827 209.92 512 209.92s-105.387 13.547-151.68 40.533-82.987 63.68-109.973 109.974c-26.987 46.293-40.534 96.853-40.534 151.68s13.547 105.386 40.534 151.68c26.986 46.293 63.68 82.986 109.973 109.973 46.293 26.987 96.853 40.533 151.68 40.533s105.387-13.546 151.68-40.533c46.293-26.987 82.987-63.68 109.973-109.973 26.987-46.294 40.534-96.854 40.534-151.68s-13.547-105.387-40.534-151.68c-27.093-46.294-63.786-82.987-109.973-109.974z`,
  186. orient: 'vertical',
  187. // x: 'left',
  188. data: nameArray.slice(0, 4),
  189. left: '10%',
  190. top: 'center',
  191. itemWidth: 15, show: false,
  192. align: 'left',
  193. textStyle: {
  194. color: "#fff"
  195. },
  196. itemGap: 20
  197. }],
  198. tooltip: {
  199. show: true
  200. },
  201. toolbox: {
  202. show: false
  203. },
  204. series: seriesOption
  205. }
  206. if (option) {
  207. myChart1.setOption(option);
  208. }
  209. // 可调用clearLoop方法,清除定时器
  210. tootipTimer && tootipTimer.clearLoop();
  211. tootipTimer = null;
  212. // 调用轮播的方法
  213. tootipTimer = tools.loopShowTooltip(myChart1, option, {
  214. interval: 2000, // 轮播间隔时间
  215. loopSeries: true // 是否开启轮播循环
  216. });
  217. }
  218. /***
  219. * 获取市接口调用频次top5和top20 统一由这个方法调用
  220. */
  221. function getCityFrequency(){
  222. $.post("/visualization/getCityFrequency",function (res) {
  223. sjk1(res.top5);
  224. sjk2(res.top20);
  225. });
  226. }
  227. /***
  228. * 获取省接口调用频次top5和top20 统一由这个方法调用
  229. */
  230. function getProvinceFrequency(){
  231. $.post("/visualization/getProvinceFrequency",function (res) {
  232. shjk2(res.top20);
  233. shjk1(res.top5);
  234. });
  235. }
  236. /***
  237. * 获取归集和接口排名 统一由这个方法调用
  238. */
  239. function imputationDataAndInterfaceRanking() {
  240. $.post("/visualization/getImputationDataAndInterfaceRanking",function (res) {
  241. jkgj(res.data);//归集数据排名
  242. jkgj2(res.interface);//归集接口排名
  243. });
  244. }
  245. /***
  246. * 获取归集数据分析 由这个方法调用
  247. */
  248. function imputationDataList(year) {
  249. if(year == null){
  250. // year = new Date().getFullYear();
  251. year = "";
  252. }
  253. $.post("/visualization/getImputationDataList",{
  254. year:year
  255. },function (res) {
  256. gjsj(res);
  257. });
  258. }
  259. function getFaultInterfaceCount() {
  260. $.post("/visualization/getFaultInterfaceCount",function (res) {
  261. $("#faultInterfaceCount").text(res);
  262. });
  263. }
  264. // 归集数据排名
  265. function jkgj(res) {
  266. //处理数据为数组
  267. let jsArr = [];
  268. if(res.length > 0){
  269. for(let i=0;i<res.length;i++){
  270. let js = {};
  271. js.name = res[i].deptName;
  272. js.value = res[i].count;
  273. jsArr.push(js);
  274. }
  275. }
  276. let myChart22 = echarts.init(document.getElementById('jkgj'));
  277. let data = jsArr;
  278. let xAxisData = data.map(item => item.name)
  279. let xAxisDataReverse = data.map(item => item.name).reverse();
  280. let seriesData = data.map(item => item.value)
  281. let maxSeriesData = []
  282. // const MAX = Math.max(...seriesData)
  283. // for (let i = 0; i < seriesData.length; i++) {
  284. // maxSeriesData.push(MAX)
  285. // }
  286. let barLinearColors = [
  287. new echarts.graphic.LinearGradient(0, 1, 1, 1, [
  288. {offset: 0, color: "#EB3B5A"},
  289. {offset: 1, color: "#FE9C5A"}
  290. ]),
  291. new echarts.graphic.LinearGradient(0, 1, 1, 1, [
  292. {offset: 0, color: "#FA8231"},
  293. {offset: 1, color: "#FFD14C"}
  294. ]),
  295. new echarts.graphic.LinearGradient(0, 1, 1, 1, [
  296. {offset: 0, color: "#F7B731"},
  297. {offset: 1, color: "#FFEE96"}
  298. ]),
  299. new echarts.graphic.LinearGradient(0, 1, 1, 1, [
  300. {offset: 0, color: "#395CFE"},
  301. {offset: 1, color: "#2EC7CF"}
  302. ])
  303. ]
  304. function rankBarColor(cData) {
  305. let tempData = []
  306. cData.forEach((item, index) => {
  307. tempData.push({
  308. value: item,
  309. itemStyle: {
  310. color: index > 3 ? barLinearColors[3] : barLinearColors[index]
  311. }
  312. })
  313. })
  314. return tempData
  315. }
  316. var option = {
  317. tooltip: {
  318. trigger: 'axis',
  319. axisPointer: {
  320. type: 'none',
  321. },
  322. // backgroundColor: 'rgba(50,50,50,.3)',
  323. textStyle: {
  324. color: '#fff'
  325. }
  326. },
  327. grid: {
  328. left: "-10%",
  329. right: "2%",
  330. width: "100%",
  331. bottom: "0%",
  332. top: "5%",
  333. containLabel: true
  334. },
  335. xAxis: {
  336. type: "value",
  337. splitLine: {show: false},
  338. axisLabel: {show: false},
  339. axisTick: {show: false},
  340. axisLine: {show: false}
  341. },
  342. yAxis: [
  343. {
  344. type: "category",
  345. inverse: true,
  346. axisLine: {show: false},
  347. axisTick: {show: false},
  348. data: xAxisData,
  349. axisLabel: {
  350. rich: {
  351. nt1: {
  352. color: "#fff",
  353. backgroundColor: '#EB3B5A',
  354. width: 16,
  355. height: 16,
  356. fontSize: 12,
  357. align: "center",
  358. borderRadius: 100,
  359. padding: [0, 1, 2, 1]
  360. },
  361. nt2: {
  362. color: "#fff",
  363. backgroundColor: '#FA8231',
  364. width: 16,
  365. height: 16,
  366. fontSize: 12,
  367. align: "center",
  368. borderRadius: 100,
  369. padding: [0, 1, 2, 1]
  370. },
  371. nt3: {
  372. color: "#fff",
  373. backgroundColor: '#F7B731',
  374. width: 16,
  375. height: 16,
  376. fontSize: 12,
  377. align: "center",
  378. borderRadius: 100,
  379. padding: [0, 1, 2, 1]
  380. },
  381. nt: {
  382. color: "#fff",
  383. backgroundColor: '#00a9c8',
  384. width: 16,
  385. height: 16,
  386. fontSize: 12,
  387. align: "center",
  388. borderRadius: 100,
  389. padding: [0, 1, 2, 1]
  390. }
  391. },
  392. formatter: function (value, index) {
  393. let idx = index + 1
  394. if (idx <= 3) {
  395. return ["{nt" + idx + "|" + idx + "}"].join("\n");
  396. } else {
  397. return ["{nt|" + idx + "}"].join("\n");
  398. }
  399. }
  400. }
  401. },
  402. {//名称
  403. type: 'category',
  404. offset: -10,
  405. position: "left",
  406. axisLine: {show: false},
  407. axisTick: {show: false},
  408. axisLabel: {
  409. color: '#fff',
  410. align: "left",
  411. verticalAlign: "bottom",
  412. lineHeight: 30,
  413. fontSize: 12
  414. },
  415. data: xAxisDataReverse
  416. },
  417. ],
  418. series: [
  419. {
  420. zlevel: 1,
  421. type: "bar",
  422. barWidth: 13,
  423. data: rankBarColor(seriesData),
  424. itemStyle: {
  425. normal: {
  426. barBorderRadius: 30
  427. }
  428. },
  429. label: {
  430. show: true,
  431. fontSize: 12,
  432. color: "#fff"
  433. }
  434. },
  435. {
  436. type: "bar",
  437. barWidth: 13,
  438. barGap: "-100%",
  439. itemStyle: {
  440. normal: {
  441. barBorderRadius: 30,
  442. color: 'rgba(27, 17, 134, 0.0)'
  443. }
  444. },
  445. data: maxSeriesData
  446. }
  447. ]
  448. };
  449. if (option) {
  450. myChart22.setOption(option);
  451. }
  452. myChart22.on('mouseover', function () {
  453. // stopShowTip();
  454. });
  455. myChart22.on('mouseout', function () {
  456. // autoShowTip();
  457. });
  458. }
  459. // 归集接口排名
  460. function jkgj2(res) {
  461. //处理数据为数组
  462. let jsArr = [];
  463. if(res.length > 0){
  464. for(let i=0;i<res.length;i++){
  465. let js = {};
  466. js.name = res[i].deptName;
  467. js.value = res[i].count;
  468. jsArr.push(js);
  469. }
  470. }
  471. var myChart33 = echarts.init(document.getElementById('jkgj2'));
  472. let data = jsArr;
  473. let xAxisData = data.map(item => item.name)
  474. let xAxisDataReverse = data.map(item => item.name).reverse();
  475. let seriesData = data.map(item => item.value)
  476. let maxSeriesData = []
  477. // const MAX = Math.max(...seriesData)
  478. // for (let i = 0; i < seriesData.length; i++) {
  479. // maxSeriesData.push(MAX)
  480. // }
  481. let barLinearColors = [
  482. new echarts.graphic.LinearGradient(0, 1, 1, 1, [
  483. {offset: 0, color: "#EB3B5A"},
  484. {offset: 1, color: "#FE9C5A"}
  485. ]),
  486. new echarts.graphic.LinearGradient(0, 1, 1, 1, [
  487. {offset: 0, color: "#FA8231"},
  488. {offset: 1, color: "#FFD14C"}
  489. ]),
  490. new echarts.graphic.LinearGradient(0, 1, 1, 1, [
  491. {offset: 0, color: "#F7B731"},
  492. {offset: 1, color: "#FFEE96"}
  493. ]),
  494. new echarts.graphic.LinearGradient(0, 1, 1, 1, [
  495. {offset: 0, color: "#395CFE"},
  496. {offset: 1, color: "#2EC7CF"}
  497. ])
  498. ]
  499. function rankBarColor(cData) {
  500. let tempData = []
  501. cData.forEach((item, index) => {
  502. tempData.push({
  503. value: item,
  504. itemStyle: {
  505. color: index > 3 ? barLinearColors[3] : barLinearColors[index]
  506. }
  507. })
  508. })
  509. return tempData
  510. }
  511. var option = {
  512. tooltip: {
  513. trigger: 'axis',
  514. axisPointer: {
  515. type: 'none',
  516. },
  517. // backgroundColor: 'rgba(50,50,50,.3)',
  518. textStyle: {
  519. color: '#fff'
  520. }
  521. },
  522. grid: {
  523. left: "-10%",
  524. right: "2%",
  525. width: "100%",
  526. bottom: "0%",
  527. top: "5%",
  528. containLabel: true
  529. },
  530. xAxis: {
  531. type: "value",
  532. splitLine: {show: false},
  533. axisLabel: {show: false},
  534. axisTick: {show: false},
  535. axisLine: {show: false}
  536. },
  537. yAxis: [
  538. {
  539. type: "category",
  540. inverse: true,
  541. axisLine: {show: false},
  542. axisTick: {show: false},
  543. data: xAxisData,
  544. axisLabel: {
  545. rich: {
  546. nt1: {
  547. color: "#fff",
  548. backgroundColor: '#EB3B5A',
  549. width: 16,
  550. height: 16,
  551. fontSize: 12,
  552. align: "center",
  553. borderRadius: 100,
  554. padding: [0, 1, 2, 1]
  555. },
  556. nt2: {
  557. color: "#fff",
  558. backgroundColor: '#FA8231',
  559. width: 16,
  560. height: 16,
  561. fontSize: 12,
  562. align: "center",
  563. borderRadius: 100,
  564. padding: [0, 1, 2, 1]
  565. },
  566. nt3: {
  567. color: "#fff",
  568. backgroundColor: '#F7B731',
  569. width: 16,
  570. height: 16,
  571. fontSize: 12,
  572. align: "center",
  573. borderRadius: 100,
  574. padding: [0, 1, 2, 1]
  575. },
  576. nt: {
  577. color: "#fff",
  578. backgroundColor: '#00a9c8',
  579. width: 16,
  580. height: 16,
  581. fontSize: 12,
  582. align: "center",
  583. borderRadius: 100,
  584. padding: [0, 1, 2, 1]
  585. }
  586. },
  587. formatter: function (value, index) {
  588. let idx = index + 1
  589. if (idx <= 3) {
  590. return ["{nt" + idx + "|" + idx + "}"].join("\n");
  591. } else {
  592. return ["{nt|" + idx + "}"].join("\n");
  593. }
  594. }
  595. }
  596. },
  597. {//名称
  598. type: 'category',
  599. offset: -10,
  600. position: "left",
  601. axisLine: {show: false},
  602. axisTick: {show: false},
  603. axisLabel: {
  604. color: '#fff',
  605. align: "left",
  606. verticalAlign: "bottom",
  607. lineHeight: 30,
  608. fontSize: 12
  609. },
  610. data: xAxisDataReverse
  611. },
  612. ],
  613. series: [
  614. {
  615. zlevel: 1,
  616. type: "bar",
  617. barWidth: 13,
  618. data: rankBarColor(seriesData),
  619. itemStyle: {
  620. normal: {
  621. barBorderRadius: 30
  622. }
  623. },
  624. label: {
  625. show: true,
  626. fontSize: 12,
  627. color: "#fff"
  628. }
  629. },
  630. {
  631. type: "bar",
  632. barWidth: 13,
  633. barGap: "-100%",
  634. itemStyle: {
  635. normal: {
  636. barBorderRadius: 30,
  637. color: 'rgba(27, 17, 134, 0.0)'
  638. }
  639. },
  640. data: maxSeriesData
  641. }
  642. ]
  643. };
  644. myChart33.setOption(option);
  645. myChart33.resize(
  646. {
  647. width: 430,
  648. height: 421
  649. }
  650. );
  651. }
  652. // 省接口调用频次top5
  653. function shjk1(res) {
  654. //将数据处理为三个数组,一个用于展示图例,一个用于渲染图表,一个用于美化
  655. let legend = [];
  656. let data = [];
  657. let fakeData = [];
  658. if(res.length > 0){
  659. for(let i=0;i<res.length;i++){
  660. legend.push(res[i].deptName);
  661. let js = {};
  662. js.name = res[i].deptName;
  663. js.value = res[i].count;
  664. data.push(js);
  665. js.name = res[i].deptName;
  666. // js.value = res[i].count + 10;
  667. js.value = res[i].count;
  668. fakeData.push(js);
  669. }
  670. }
  671. // 基于准备好的dom,初始化echarts实例
  672. //省接口调用频次(左)
  673. var myChart44 = echarts.init(document.getElementById('shjk_div1'));
  674. option = {
  675. //backgroundColor: '#010f23',
  676. title: {
  677. text: '省接口调用频次Top5',
  678. subtext: '',
  679. link: '',
  680. target: 'blank',
  681. x: 'center',
  682. top: '20',
  683. textStyle: {
  684. color: '#FFF',
  685. fontSize: 12,
  686. }
  687. },
  688. tooltip: {
  689. trigger: 'item',
  690. formatter: "{a} <br/>{b} : {c}"
  691. },
  692. legend: {
  693. data: legend,
  694. x: 'center',
  695. y: '92%',
  696. textStyle: {
  697. color: '#FFF',
  698. fontSize: '10'
  699. }, itemWidth: 4, itemHeight: 4
  700. },
  701. color: ['#00a1e5', '#23c768', '#e5ce10', '#ff7e00', '#fe0000', '#c2c1bd',],
  702. series: [
  703. {
  704. name: '省接口调用频次',
  705. type: 'funnel',
  706. left: 'center',
  707. width: '70%',
  708. sort: 'ascending',
  709. label: {
  710. normal: {
  711. formatter: '{b}',
  712. },
  713. },
  714. labelLine: {
  715. normal: {
  716. show: true,
  717. length: 30
  718. }
  719. },
  720. itemStyle: {
  721. normal: {
  722. opacity: 0.3
  723. }
  724. },
  725. tooltip: {
  726. show: false
  727. },
  728. //虚影 假数据 为了好看
  729. data: fakeData
  730. },
  731. {
  732. name: '省接口调用频次',
  733. type: 'funnel',
  734. left: 'center',
  735. width: '70%',
  736. maxSize: '70%',
  737. sort: 'ascending',
  738. label: {
  739. normal: {
  740. position: 'inside',
  741. formatter: '{c}',
  742. textStyle: {
  743. color: '#fff',
  744. fontSize: 14,
  745. }
  746. },
  747. emphasis: {
  748. position: 'inside',
  749. // formatter: '{b}: {c}'//省悬浮
  750. }
  751. },
  752. itemStyle: {
  753. normal: {
  754. opacity: 8,
  755. borderColor: 'rgba(12, 13, 43, .9)',
  756. borderWidth: 3,
  757. shadowBlur: 5,
  758. shadowOffsetX: 0,
  759. shadowOffsetY: 5,
  760. shadowColor: 'rgba(0, 0, 0, .6)'
  761. }
  762. },
  763. data: data
  764. }
  765. ]
  766. };
  767. if (option) {
  768. myChart44.setOption(option);//省接口调用频次(左)
  769. }
  770. }
  771. // 省接口调用频次排名
  772. function shjk2(res) {
  773. //将数据处理为两个数组
  774. let legend = [];
  775. let data = [];
  776. if(res.length > 0){
  777. for(let i=0;i<res.length;i++){
  778. legend.push(res[i].deptName);
  779. data.push(res[i].count);
  780. }
  781. }
  782. // 基于准备好的dom,初始化echarts实例
  783. //省接口调用频次(右)坏了的
  784. let tootipTimer = null;
  785. let myChart45 = echarts.init(document.getElementById('shjk_div2'));
  786. let dataX = legend; //名称
  787. let dataY = data; //数据
  788. let zoomShow = false;
  789. if (dataY.length > 15) {
  790. zoomShow = true;
  791. } else {
  792. zoomShow = false;
  793. }
  794. var option = {
  795. // backgroundColor: '#010f23',
  796. tooltip: {
  797. trigger: 'axis',
  798. axisPointer: {
  799. type: 'shadow',
  800. },
  801. },
  802. grid: {
  803. top: '10%',
  804. right: '5%',
  805. left: '10%',
  806. bottom: '23%',
  807. },
  808. xAxis: [
  809. {
  810. type: 'category',
  811. data: dataX,
  812. axisLine: {
  813. lineStyle: {
  814. color: 'rgba(66, 192, 255, .3)',
  815. },
  816. },
  817. axisLabel: {
  818. interval: 0,
  819. margin: 10,
  820. color: '#fff',
  821. textStyle: {
  822. fontSize: 11,
  823. },
  824. rotate: '45',
  825. },
  826. axisTick: {//刻度
  827. show: false,
  828. },
  829. },
  830. ],
  831. yAxis: [
  832. {
  833. axisLabel: {
  834. padding: [3, 0, 0, 0],
  835. formatter: '{value}',
  836. color: 'rgba(95, 187, 235, 1)',
  837. textStyle: {
  838. fontSize: 12,
  839. },
  840. },
  841. axisTick: {
  842. show: true,
  843. },
  844. axisLine: {
  845. lineStyle: {
  846. color: 'rgba(66, 192, 255, .3)',
  847. },
  848. },
  849. splitLine: {
  850. lineStyle: {
  851. color: 'rgba(255,255,255,0)',
  852. },
  853. },
  854. },
  855. ],
  856. dataZoom: [//滚动条
  857. {
  858. show: zoomShow,
  859. type: 'slider',
  860. realtime: true,
  861. startValue: 0,
  862. endValue: 15,
  863. xAxisIndex: [0],
  864. bottom: '10',
  865. left: '30',
  866. height: 5,
  867. borderColor: 'rgba(0,0,0,0)',
  868. textStyle: {
  869. color: '#fff',
  870. },
  871. },
  872. ],
  873. series: [
  874. {
  875. type: 'bar',
  876. data: dataY,
  877. barWidth: '12',
  878. itemStyle: {
  879. normal: {
  880. color: new echarts.graphic.LinearGradient(
  881. 0,
  882. 0,
  883. 0,
  884. 1,
  885. [
  886. {
  887. offset: 0,
  888. color: 'rgba(5, 64, 250, 1)', // 0% 处的颜色
  889. },
  890. {
  891. offset: 0.98,
  892. color: 'rgba(5, 213, 255, 0)', // 100% 处的颜色
  893. },
  894. ],
  895. false
  896. ),
  897. shadowColor: 'rgba(1, 34, 62, 1)',
  898. shadowBlur: 4,
  899. barBorderRadius: [10, 10, 0, 0]
  900. },
  901. },
  902. label: {
  903. normal: {
  904. show: true,
  905. lineHeight: 10,
  906. formatter: '{c}',
  907. position: 'top',
  908. textStyle: {
  909. color: '#fff',
  910. fontSize: 10,
  911. },
  912. },
  913. },
  914. },
  915. ],
  916. };
  917. if (option) {
  918. myChart45.setOption(option);//省接口调用频次(右)坏了的
  919. }
  920. // 可调用clearLoop方法,清除定时器
  921. tootipTimer && tootipTimer.clearLoop();
  922. tootipTimer = null;
  923. // 调用轮播的方法
  924. tootipTimer = tools.loopShowTooltip(myChart45, option, {
  925. interval: 2500, // 轮播间隔时间
  926. loopSeries: true // 是否开启轮播循环
  927. });
  928. /*let loopSeriesMyChart45 = true;
  929. // 可调用clearLoop方法,清除定时器
  930. tootipTimer && tootipTimer.clearLoop();
  931. tootipTimer = null;
  932. // 调用轮播的方法
  933. tootipTimer = tools.loopShowTooltip(myChart45, option, {
  934. interval: 2000, // 轮播间隔时间
  935. loopSeries: loopSeriesMyChart45 // 是否开启轮播循环
  936. // loopSeries: true // 是否开启轮播循环
  937. });*/
  938. }
  939. // 市接口调用频次top5
  940. function sjk1(res) {
  941. //将数据处理为三个数组,一个用于展示图例,一个用于渲染图表,一个用于美化
  942. let legend = [];
  943. let data = [];
  944. let fakeData = [];
  945. if(res.length > 0){
  946. for(let i=0;i<res.length;i++){
  947. legend.push(res[i].deptName);
  948. let js = {};
  949. js.name = res[i].deptName;
  950. js.value = res[i].count;
  951. data.push(js);
  952. js.name = res[i].deptName;
  953. // js.value = res[i].count + 10;
  954. js.value = res[i].count;
  955. fakeData.push(js);
  956. }
  957. }
  958. // 基于准备好的dom,初始化echarts实例
  959. //市接口调用频次(左)
  960. var myChart55 = echarts.init(document.getElementById('sjk_div1'));
  961. option = {
  962. //backgroundColor: '#010f23',
  963. title: {
  964. text: '市接口调用频次Top5',
  965. subtext: '',
  966. link: '',
  967. target: 'blank',
  968. x: 'center',
  969. top: '20',
  970. textStyle: {
  971. color: '#FFF',
  972. fontSize: 12,
  973. }
  974. },
  975. tooltip: {
  976. trigger: 'item',
  977. formatter: "{a} <br/>{b} : {c}"
  978. },
  979. legend: {
  980. data: legend,
  981. x: 'center',
  982. y: '92%',
  983. textStyle: {
  984. color: '#FFF',
  985. fontSize: '10'
  986. }, itemWidth: 4, itemHeight: 4
  987. },
  988. color: ['#00a1e5', '#23c768', '#e5ce10', '#ff7e00', '#fe0000', '#c2c1bd',],
  989. series: [
  990. {
  991. name: '市接口调用频次',
  992. type: 'funnel',
  993. left: 'center',
  994. width: '60%',
  995. sort: 'ascending',
  996. label: {
  997. normal: {
  998. formatter: '{b}',
  999. },
  1000. },
  1001. labelLine: {
  1002. normal: {
  1003. show: true,
  1004. length: 30
  1005. }
  1006. },
  1007. itemStyle: {
  1008. normal: {
  1009. opacity: 0.3
  1010. }
  1011. },
  1012. tooltip: {
  1013. show: false
  1014. },
  1015. //虚影(假数据,为了好看)
  1016. data: fakeData
  1017. },
  1018. {
  1019. name: '市接口调用频次',
  1020. type: 'funnel',
  1021. left: 'center',
  1022. width: '70%',
  1023. maxSize: '70%',
  1024. sort: 'ascending',
  1025. label: {
  1026. normal: {
  1027. position: 'inside',
  1028. formatter: '{c}',
  1029. textStyle: {
  1030. color: '#fff',
  1031. fontSize: 14,
  1032. }
  1033. },
  1034. emphasis: {
  1035. position: 'inside',
  1036. // formatter: '{b}: {c}'//市悬浮
  1037. }
  1038. },
  1039. itemStyle: {
  1040. normal: {
  1041. opacity: 8,
  1042. borderColor: 'rgba(12, 13, 43, .9)',
  1043. borderWidth: 3,
  1044. shadowBlur: 5,
  1045. shadowOffsetX: 0,
  1046. shadowOffsetY: 5,
  1047. shadowColor: 'rgba(0, 0, 0, .6)'
  1048. }
  1049. },
  1050. data: data
  1051. }
  1052. ]
  1053. };
  1054. if (option) {
  1055. myChart55.setOption(option);//市接口调用频次(左)
  1056. }
  1057. }
  1058. // 市接口调用频次排名
  1059. //市接口调用频次(右)
  1060. function sjk2(res) {
  1061. //将数据处理为两个数组
  1062. let legend = [];
  1063. let data = [];
  1064. if(res.length > 0){
  1065. for(let i=0;i<res.length;i++){
  1066. legend.push(res[i].deptName);
  1067. data.push(res[i].count);
  1068. }
  1069. }
  1070. var tootipTimer = null;
  1071. // 基于准备好的dom,初始化echarts实例
  1072. var myChart56 = echarts.init(document.getElementById('sjk_div2'));
  1073. let dataX = legend; //名称
  1074. let dataY = data; //数据
  1075. let zoomShow = false;
  1076. if (dataY.length > 15) {
  1077. zoomShow = true;
  1078. } else {
  1079. zoomShow = false;
  1080. }
  1081. var option = {
  1082. // backgroundColor: '#010f23',
  1083. tooltip: {
  1084. trigger: 'axis',
  1085. axisPointer: {
  1086. type: 'shadow',
  1087. },
  1088. },
  1089. grid: {
  1090. top: '10%',
  1091. right: '5%',
  1092. left: '10%',
  1093. bottom: '23%',
  1094. },
  1095. xAxis: [
  1096. {
  1097. type: 'category',
  1098. data: dataX,
  1099. axisLine: {
  1100. lineStyle: {
  1101. color: 'rgba(66, 192, 255, .3)',
  1102. },
  1103. },
  1104. axisLabel: {
  1105. interval: 0,
  1106. margin: 10,
  1107. color: '#fff',
  1108. textStyle: {
  1109. fontSize: 11,
  1110. },
  1111. rotate: '45',
  1112. },
  1113. axisTick: {//刻度
  1114. show: false,
  1115. },
  1116. },
  1117. ],
  1118. yAxis: [
  1119. {
  1120. axisLabel: {
  1121. padding: [3, 0, 0, 0],
  1122. formatter: '{value}',
  1123. color: 'rgba(95, 187, 235, 1)',
  1124. textStyle: {
  1125. fontSize: 12,
  1126. },
  1127. },
  1128. axisTick: {
  1129. show: true,
  1130. },
  1131. axisLine: {
  1132. lineStyle: {
  1133. color: 'rgba(66, 192, 255, .3)',
  1134. },
  1135. },
  1136. splitLine: {
  1137. lineStyle: {
  1138. color: 'rgba(255,255,255,0)',
  1139. },
  1140. },
  1141. },
  1142. ],
  1143. dataZoom: [//滚动条
  1144. {
  1145. show: zoomShow,
  1146. type: 'slider',
  1147. realtime: true,
  1148. startValue: 0,
  1149. endValue: 15,
  1150. xAxisIndex: [0],
  1151. bottom: '10',
  1152. left: '30',
  1153. height: 5,
  1154. borderColor: 'rgba(0,0,0,0)',
  1155. textStyle: {
  1156. color: '#fff',
  1157. },
  1158. },
  1159. ],
  1160. series: [
  1161. {
  1162. type: 'bar',
  1163. data: dataY,
  1164. barWidth: '12',
  1165. itemStyle: {
  1166. normal: {
  1167. color: new echarts.graphic.LinearGradient(
  1168. 0,
  1169. 0,
  1170. 0,
  1171. 1,
  1172. [
  1173. {
  1174. offset: 0,
  1175. color: 'rgba(5, 64, 250, 1)', // 0% 处的颜色
  1176. },
  1177. {
  1178. offset: 0.98,
  1179. color: 'rgba(5, 213, 255, 0)', // 100% 处的颜色
  1180. },
  1181. ],
  1182. false
  1183. ),
  1184. shadowColor: 'rgba(1, 34, 62, 1)',
  1185. shadowBlur: 4,
  1186. barBorderRadius: [10, 10, 0, 0]
  1187. },
  1188. },
  1189. label: {
  1190. normal: {
  1191. show: true,
  1192. lineHeight: 10,
  1193. formatter: '{c}',
  1194. position: 'top',
  1195. textStyle: {
  1196. color: '#fff',
  1197. fontSize: 10,
  1198. },
  1199. },
  1200. },
  1201. },
  1202. ],
  1203. };
  1204. if (option) {
  1205. myChart56.setOption(option);//市接口调用频次(右)
  1206. }
  1207. // 可调用clearLoop方法,清除定时器
  1208. tootipTimer && tootipTimer.clearLoop();
  1209. tootipTimer = null;
  1210. // 调用轮播的方法
  1211. tootipTimer = tools.loopShowTooltip(myChart56, option, {
  1212. interval: 2500, // 轮播间隔时间
  1213. loopSeries: true // 是否开启轮播循环
  1214. });
  1215. }
  1216. // 归集数据频次分析
  1217. function gjsj(res) {
  1218. //将数据处理为数组
  1219. let title = ['1月','2月','3月','4月','5月','6月','7月','8月','9月','10月','11月','12月'];
  1220. let _data = [];
  1221. let _coords = [];
  1222. if(res.length > 0){
  1223. for(let i=0;i<res.length;i++){
  1224. _data.push(res[i]);
  1225. let element = [];
  1226. element.push(title[i]);
  1227. element.push(res[i]);
  1228. _coords.push(element);
  1229. }
  1230. }
  1231. // 基于准备好的dom,初始化echarts实例
  1232. var myChart = echarts.init(document.getElementById('gjsj'));
  1233. var img = [
  1234. 'image://',
  1235. 'image://',
  1236. 'image://',
  1237. 'image://',
  1238. ]
  1239. var data = [{
  1240. /**_coords**/
  1241. coords: _coords
  1242. }]
  1243. option = {
  1244. // backgroundColor:'#011024',
  1245. tooltip: {
  1246. trigger: 'axis',
  1247. axisPointer: {
  1248. type: 'cross',
  1249. label: {
  1250. backgroundColor: '#0d3fb7'
  1251. }
  1252. }
  1253. },
  1254. grid: {
  1255. top: '15%',
  1256. left: '5%',
  1257. right: '5%',
  1258. bottom: '15%',
  1259. containLabel: true
  1260. },
  1261. xAxis: [{
  1262. type: 'category',
  1263. axisLine: {
  1264. show: true,
  1265. color: '#0d3fb7'
  1266. },
  1267. axisLabel: {
  1268. color: '#fff'
  1269. },
  1270. splitLine: {
  1271. show: false
  1272. },
  1273. boundaryGap: true,
  1274. /**title**/
  1275. data: title,
  1276. }],
  1277. yAxis: [{
  1278. type: 'value',
  1279. min: 0,
  1280. splitLine: {
  1281. show: true,
  1282. lineStyle: {
  1283. color: 'rgba(255,255,255,0.1)'
  1284. }
  1285. },
  1286. axisLine: {
  1287. show: true,
  1288. },
  1289. axisLabel: {
  1290. show: true,
  1291. textStyle: {
  1292. color: '#d1e6eb',
  1293. },
  1294. },
  1295. axisTick: {
  1296. show: false,
  1297. },
  1298. }],
  1299. series: [{
  1300. name: '归集数据频次分析',
  1301. type: 'line',
  1302. smooth: false, //是否平滑
  1303. showAllSymbol: true,
  1304. symbol: 'circle',
  1305. symbolSize: 10,
  1306. lineStyle: {
  1307. normal: {
  1308. color: "#0d3fb7",
  1309. shadowColor: 'rgba(0, 0, 0, .3)',
  1310. shadowBlur: 0,
  1311. shadowOffsetY: 5,
  1312. shadowOffsetX: 5,
  1313. },
  1314. },
  1315. label: {
  1316. show: true,
  1317. position: 'top',
  1318. textStyle: {
  1319. color: '#fff'
  1320. }
  1321. },
  1322. itemStyle: {
  1323. color: "#0d3fb7",
  1324. borderColor: "#fff",
  1325. borderWidth: 3,
  1326. shadowColor: 'rgba(0, 0, 0, .3)',
  1327. shadowBlur: 0,
  1328. shadowOffsetY: 2,
  1329. shadowOffsetX: 2,
  1330. },
  1331. areaStyle: {
  1332. normal: {
  1333. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
  1334. offset: 0,
  1335. color: 'rgba(108,80,243,0.3)'
  1336. },
  1337. {
  1338. offset: 1,
  1339. color: 'rgba(108,80,243,0)'
  1340. }
  1341. ], false),
  1342. shadowColor: 'rgba(108,80,243, 0.9)',
  1343. shadowBlur: 20
  1344. }
  1345. },
  1346. data: _data
  1347. },
  1348. {
  1349. name: '滑行的光点',
  1350. type: 'lines',
  1351. coordinateSystem: 'cartesian2d',
  1352. symbolSize: 30,
  1353. polyline: true,
  1354. effect: {
  1355. show: true,
  1356. trailLength: 0,
  1357. symbol: "arrow",
  1358. period: 10, //光点滑动速度
  1359. symbolSize: 150,
  1360. symbol: img[0]
  1361. },
  1362. lineStyle: {
  1363. normal: {
  1364. width: 1,
  1365. opacity: 0.6,
  1366. curveness: 0.2
  1367. }
  1368. },
  1369. /**_data**/
  1370. data: data
  1371. }
  1372. ]
  1373. };
  1374. if (option) {
  1375. myChart.setOption(option);
  1376. }
  1377. }