#
whycq
2023-10-10 155f2b80f2a9b6f900c73f6e4461e9cebb7cd028
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
 
<template>
    <view class="viewimg">
        <view>
            <view>echarts示列</view>
            <echarts :option="option" style="height: 300px;"></echarts>
            <button @click="updateClick">更新数据</button>
        </view>
        <view>
            <echarts :option="optionone" style="height: 400px;"></echarts>
        </view>
        <view>
            <echarts :option="optiontwo" style="height: 400px;"></echarts>
        </view>
    </view>
</template>
 
<script>
    import echarts from '@/components/echarts/echarts.vue';
    export default {
        data() {
            return {
                option: {},
                optionone: {},
                optiontwo: {}
            };
        },
        onLoad() {
            // console.log(777777);
        },
        components: {
            echarts
        },
        mounted() {
            this.logstatrt();
            this.logstatrtone();
            this.logstatrttwo();
        },
        methods: {
            logstatrt() {
                // console.log('初次调用');
                this.option = {
                    backgroundColor: '#011246',
                    tooltip: {
                        trigger: 'axis',
                        axisPointer: {
                            type: 'shadow'
                        }
                    },
                    grid: {
                        top: '25%',
                        right: '45',
                        bottom: '20',
                        left: '30'
                    },
                    legend: {
                        data: [{
                            name: '人保'
                        }, {
                            name: '太保'
                        }, {
                            name: '平安'
                        }, {
                            name: '人保增速'
                        }, {
                            name: '太保增速'
                        }, {
                            name: '平安增速'
                        }],
                        top: '0%',
                        textStyle: {
                            color: 'rgba(255,255,255,0.9)' //图例文字
                        }
                    },
                    dataZoom: [{
                        type: 'slider',
                        realtime: true,
                        //移动端展示方式
                        handleSize: '100%', //滑动条两侧的大小
                        start: 0,
                        end: 50
                    }],
                    grid: {
                        left: '3%',
                        right: '4%',
                        bottom: '15%',
                        height: '70%',
                        containLabel: true
                    },
                    xAxis: [{
                        type: 'category',
                        data: ['2015', '2016', '2017', '2018', '2019'],
                        axisLine: {
                            lineStyle: {
                                color: 'rgba(255,255,255,.1)'
                            }
                        },
                        axisLabel: {
                            textStyle: {
                                color: 'rgba(255,255,255,.7)',
                                fontSize: '14'
                            }
                        }
                    }],
                    yAxis: [{
                            type: 'value',
                            name: '单位万',
                            splitLine: {
                                show: false
                            },
                            axisLabel: {
                                show: true,
                                fontSize: 14,
                                color: 'rgba(255,255,255,.6)'
                            },
                            axisLine: {
                                min: 0,
                                max: 10,
                                lineStyle: {
                                    color: 'rgba(255,255,255,.4)'
                                }
                            } //左线色
                        },
                        {
                            type: 'value',
                            name: '增速',
                            show: true,
                            axisLabel: {
                                show: true,
                                fontSize: 14,
                                formatter: '{value} %',
                                color: 'rgba(255,255,255,.6)'
                            },
                            axisLine: {
                                lineStyle: {
                                    color: 'rgba(255,255,255,.4)'
                                }
                            }, //右线色
                            splitLine: {
                                show: true,
                                lineStyle: {
                                    color: 'rgba(255,255,255,.1)'
                                }
                            } //x轴线
                        }
                    ],
                    series: [{
                            name: '人保',
                            type: 'bar',
                            data: [35, 36.6, 38.8, 40.84, 41.6],
                            // "barWidth": "30",
                            itemStyle: {
                                normal: {
                                    color: {
                                        type: 'linear',
                                        x: 0.5,
                                        y: 0.5,
                                        r: 0.5,
                                        colorStops: [{
                                                offset: 0,
                                                color: '#00FFE3' // 0% 处的颜色
                                            },
                                            {
                                                offset: 1,
                                                color: '#4693EC' // 100% 处的颜色
                                            }
                                        ],
                                        globalCoord: false // 缺省为 false
                                    }
                                }
                            }
                            // "barGap": "0.2"
                        },
                        {
                            name: '太保',
                            type: 'bar',
                            data: [16, 14.8, 14.1, 15, 16.3],
 
                            color: {
                                type: 'linear',
                                x: 0.5,
                                y: 0.5,
                                r: 0.5,
                                colorStops: [{
                                        offset: 0,
                                        color: '#248ff7' // 0% 处的颜色
                                    },
                                    {
                                        offset: 1,
                                        color: '#6851f1' // 100% 处的颜色
                                    }
                                ],
                                globalCoord: false // 缺省为 false
                            }
                        },
                        {
                            name: '平安',
                            type: 'bar',
                            data: [10.2, 9.2, 9.1, 9.85, 8.9],
                            color: {
                                type: 'linear',
                                x: 0.5,
                                y: 0.5,
                                r: 0.5,
                                colorStops: [{
                                        offset: 0,
                                        color: '#fccb05' // 0% 处的颜色
                                    },
                                    {
                                        offset: 1,
                                        color: '#f5804d' // 100% 处的颜色
                                    }
                                ],
                                globalCoord: false // 缺省为 false
                            }
                        },
                        {
                            name: '人保增速',
                            type: 'line',
                            yAxisIndex: 1,
 
                            data: [0, 6.01, 5.26, 1.48],
                            lineStyle: {
                                normal: {
                                    width: 2
                                }
                            },
                            itemStyle: {
                                normal: {
                                    color: '#86d370'
                                }
                            },
                            smooth: true
                        },
                        {
                            name: '太保增速',
                            type: 'line',
                            yAxisIndex: 1,
 
                            data: [0, -4.73, 6.38, 8.67],
                            lineStyle: {
                                normal: {
                                    width: 2
                                }
                            },
                            itemStyle: {
                                normal: {
                                    color: '#3496f8'
                                }
                            },
                            smooth: true
                        },
                        {
                            name: '平安增速',
                            type: 'line',
                            yAxisIndex: 1,
 
                            data: [0, -1.09, 8.24, -9.64],
                            lineStyle: {
                                normal: {
                                    width: 2
                                }
                            },
                            itemStyle: {
                                normal: {
                                    color: '#fbc30d'
                                }
                            },
                            smooth: true
                        }
                    ]
                };
            },
            logstatrtone() {
                this.optionone = {
                    backgroundColor: '#0c1e55',
 
                    color: ['#00a0fc', '#ffe400', '#ff9a09', '#ef1e5f', '#23cbe5', '#ec561b', '#ffa500', '#dddf00', '#b23aee',
                        '#50b332'
                    ],
 
                    tooltip: {
                        trigger: 'item',
                        // formatter: "   {a} <br/>{b} : {c} ({d}%)"
                        formatter: "   企业数:{c}"
                    },
                    legend: { // 图例-图上面的分类
                        // orient: 'vertical',
                        // right: 30,
                        //   icon: 'rect',//长方形
                        icon: 'circle',
                        top: "1%",
                        itemWidth: 10,
                        itemHeight: 10,
                        // itemGap: 13,
                        data: ['16℃以下', '16-18℃', '18-20℃', '20-22℃', '22-24℃', '24-26℃', '26℃以上'],
                        // right: '56%',
                        textStyle: {
                            fontSize: 14,
                            color: '#a6cde8',
                            lineHeight: 49
                        },
                        formatter: function(name) {
                            return "" + name + ""
                        },
                        padding: [2, 2]
                    },
                    grid: {
                        top: '20%',
                        left: '53%',
                        right: '10%',
                        bottom: '6%',
                        containLabel: true
                    },
 
                    series: [{
                        label: {
                            normal: {
                                formatter: '{b|{b}:} {c} \n  {per|{d}%} ',
                                rich: {}
                            },
                            emphasis: {
                                show: true,
                            }
                        },
                        // labelLine: {
                        //     normal: {
                        //         show: false
                        //     }
                        // },
                        name: '访问来源',
                        type: 'pie',
                        radius: '55%',
                        center: ['50%', '60%'],
                        data: [{
                                value: 195,
                                name: '16℃以下'
                            },
                            {
                                value: 185,
                                name: '16-18℃'
                            },
                            {
                                value: 260,
                                name: '18-20℃'
                            },
                            {
                                value: 213,
                                name: '20-22℃'
                            },
                            {
                                value: 52,
                                name: '22-24℃'
                            },
                            {
                                value: 35,
                                name: '24-26℃'
                            },
                            {
                                value: 46,
                                name: '26℃以上'
                            },
                        ],
                        itemStyle: {
                            emphasis: {
                                shadowBlur: 10,
                                shadowOffsetX: 0,
                                shadowColor: 'rgba(0, 0, 0, 0.5)'
                            }
                        },
                        labelLine: {
                            normal: {
                                length: 5,
                                length2: 1,
                                smooth: true,
                            }
                        },
                    }]
                };
            },
            logstatrttwo() {
                var m2R2Data = [{
                        value: 335,
                        value1: 234,
                        legendname: 'Ⅰ类',
                        name: "Ⅰ类",
                        itemStyle: {
                            color: "#8d7fec"
                        }
                    },
                    {
                        value: 310,
                        value1: 314,
                        legendname: 'Ⅱ类',
                        name: "Ⅱ类",
                        itemStyle: {
                            color: "#5085f2"
                        }
                    },
                    {
                        value: 234,
                        value1: 235,
                        legendname: 'Ⅲ类',
                        name: "Ⅲ类",
                        itemStyle: {
                            color: "#e75fc3"
                        }
                    },
                    {
                        value: 154,
                        value1: 213,
                        legendname: 'Ⅳ类',
                        name: "Ⅳ类",
                        itemStyle: {
                            color: "#f87be2"
                        }
                    },
                    {
                        value: 335,
                        value1: 321,
                        legendname: 'Ⅴ类',
                        name: "Ⅴ类",
                        itemStyle: {
                            color: "#f2719a"
                        }
                    },
 
                ];
 
                this.optiontwo = {
                    title: [{
                            text: '全网调控情况',
                            textStyle: {
                                fontSize: 16,
                                color: "black"
                            },
                            left: "35%"
                        },
                        {
                            text: '全网均温',
                            subtext: 44.5 + '℃',
                            textStyle: {
                                fontSize: 15,
                                color: "black"
                            },
                            subtextStyle: {
                                fontSize: 20,
                                color: 'black'
                            },
                            textAlign: "center",
                            x: '40%',
                            y: '44%',
                        }
                    ],
                    tooltip: {
                        trigger: 'item',
                        formatter: function(parms) {
                            var str = parms.seriesName + "</br>" +
                                parms.marker + "" + parms.data.legendname + "</br>" +
                                "当前温度:" + parms.data.value + "</br>" +
                                "目标温度:" + parms.data.value1 + "</br>" +
                                "占比:" + parms.percent + "%";
                            return str;
                        }
                    },
                    legend: {
                        type: "scroll",
                        orient: 'vertical',
                        left: '80%',
                        align: 'left',
                        top: 'middle',
                        textStyle: {
                            color: '#8C8C8C'
                        },
 
                    },
                    series: [{
                        name: '全网调控情况',
                        type: 'pie',
                        center: ['40%', '50%'],
                        radius: ['40%', '65%'],
                        clockwise: false, //饼图的扇区是否是顺时针排布
                        avoidLabelOverlap: false,
                        itemStyle: { //图形样式
                            normal: {
                                borderColor: '#ffffff',
                                borderWidth: 1,
                            },
                        },
                        label: {
                            normal: {
                                show: true,
                                position: 'outter',
                                formatter: function(parms) {
                                    return parms.data.legendname
                                }
                            }
                        },
                        labelLine: {
                            normal: {
                                length: 15,
                                length2: 13,
                                smooth: true,
                            }
                        },
                        data: m2R2Data
                    }]
                };
            },
            /**
             * 更新数据
             */
            updateClick() {
                this.option.series=[{
                            name: '人保',
                            type: 'bar',
                            data: [10, 10, 10, 10, 10],
                            // "barWidth": "30",
                            itemStyle: {
                                normal: {
                                    color: {
                                        type: 'linear',
                                        x: 0.5,
                                        y: 0.5,
                                        r: 0.5,
                                        colorStops: [{
                                                offset: 0,
                                                color: '#00FFE3' // 0% 处的颜色
                                            },
                                            {
                                                offset: 1,
                                                color: '#4693EC' // 100% 处的颜色
                                            }
                                        ],
                                        globalCoord: false // 缺省为 false
                                    }
                                }
                            }
                            // "barGap": "0.2"
                        },
                        {
                            name: '太保',
                            type: 'bar',
                            data: [16, 14.8, 14.1, 15, 16.3],
 
                            color: {
                                type: 'linear',
                                x: 0.5,
                                y: 0.5,
                                r: 0.5,
                                colorStops: [{
                                        offset: 0,
                                        color: '#248ff7' // 0% 处的颜色
                                    },
                                    {
                                        offset: 1,
                                        color: '#6851f1' // 100% 处的颜色
                                    }
                                ],
                                globalCoord: false // 缺省为 false
                            }
                        },
                        {
                            name: '平安',
                            type: 'bar',
                            data: [10.2, 9.2, 9.1, 9.85, 8.9],
                            color: {
                                type: 'linear',
                                x: 0.5,
                                y: 0.5,
                                r: 0.5,
                                colorStops: [{
                                        offset: 0,
                                        color: '#fccb05' // 0% 处的颜色
                                    },
                                    {
                                        offset: 1,
                                        color: '#f5804d' // 100% 处的颜色
                                    }
                                ],
                                globalCoord: false // 缺省为 false
                            }
                        },
                        {
                            name: '人保增速',
                            type: 'line',
                            yAxisIndex: 1,
 
                            data: [0, 6.01, 5.26, 1.48],
                            lineStyle: {
                                normal: {
                                    width: 2
                                }
                            },
                            itemStyle: {
                                normal: {
                                    color: '#86d370'
                                }
                            },
                            smooth: true
                        },
                        {
                            name: '太保增速',
                            type: 'line',
                            yAxisIndex: 1,
 
                            data: [0, -4.73, 6.38, 8.67],
                            lineStyle: {
                                normal: {
                                    width: 2
                                }
                            },
                            itemStyle: {
                                normal: {
                                    color: '#3496f8'
                                }
                            },
                            smooth: true
                        },
                        {
                            name: '平安增速',
                            type: 'line',
                            yAxisIndex: 1,
 
                            data: [0, -1.09, 8.24, -9.64],
                            lineStyle: {
                                normal: {
                                    width: 2
                                }
                            },
                            itemStyle: {
                                normal: {
                                    color: '#fbc30d'
                                }
                            },
                            smooth: true
                        }
                    ]
                // this.option = {
                //     notMerge: true, // 自定义变量:true代表不合并数据,比如从折线图变为柱形图则需设置为true;false或不写代表合并
                //     xAxis: {
                //         type: 'category',
                //         data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
                //     },
                //     yAxis: {
                //         type: 'value'
                //     },
                //     series: [{
                //         data: [120, 200, 150, 80, 70, 110, 130],
                //         type: 'bar',
                //         showBackground: true,
                //         backgroundStyle: {
                //             color: 'rgba(220, 220, 220, 0.8)'
                //         }
                //     }]
                // };
            }
        }
    };
</script>
<style>
    .viewimg {
        height: 100%;
        /* background: #d1e9e9; */
    }
</style>