|
@@ -57,6 +57,7 @@ let app = new Vue({
|
|
|
if (this.timer) {
|
|
|
clearInterval(this.timer);
|
|
|
}
|
|
|
+ clearInterval(this.timeOut)
|
|
|
},
|
|
|
mounted() {
|
|
|
setTimeout(() => {
|
|
@@ -73,9 +74,6 @@ let app = new Vue({
|
|
|
this.initProjectList()
|
|
|
}, 0)
|
|
|
},
|
|
|
- beforeDestroy(){
|
|
|
- clearInterval(this.timeOut)
|
|
|
- },
|
|
|
methods: {
|
|
|
numFormat(value) {
|
|
|
if (!value) return '0'
|
|
@@ -1133,7 +1131,7 @@ let app = new Vue({
|
|
|
// let k =
|
|
|
// typeof internalDiameterRatio !== 'undefined'
|
|
|
// ? (1 - internalDiameterRatio) / (1 + internalDiameterRatio)
|
|
|
- // : 1 / 3;
|
|
|
+ // : 1 / 5;
|
|
|
|
|
|
// // 新增标签 series @20210613
|
|
|
// let labelSeries = {
|
|
@@ -1524,9 +1522,18 @@ let app = new Vue({
|
|
|
let option = {
|
|
|
tooltip: {
|
|
|
trigger: 'item',
|
|
|
- position: ['65%', '42%'],
|
|
|
+ //position: ['65%', '42%'],
|
|
|
+ position: (point,params,dom,rect,size) => {
|
|
|
+ if(params.name == '传统产业'){
|
|
|
+ return ['55%','25%']
|
|
|
+ } else if (params.name == '战略新兴产业') {
|
|
|
+ return ['55%','65%']
|
|
|
+ } else if (params.name == '基础产业') {
|
|
|
+ return ['18%','35%']
|
|
|
+ }
|
|
|
+ },
|
|
|
formatter: params => {
|
|
|
- return `<span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${params.color}"></span> ${params.name}:${params.value} <br/><span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${params.color}"></span> 投资占比:${params.percent}%`
|
|
|
+ return `<span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${params.color}"></span> ${params.name}:${params.percent}% <br/><span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${params.color}"></span> 金额:${params.value}`
|
|
|
}, //+ '<br/>'+ '{a1}:{c1}' + '%',
|
|
|
axisPointer: {
|
|
|
type: 'cross',
|
|
@@ -1612,6 +1619,35 @@ let app = new Vue({
|
|
|
type: 'cross',
|
|
|
},
|
|
|
},
|
|
|
+ dataZoom:[
|
|
|
+ {
|
|
|
+ // start: 9,//默认为@
|
|
|
+ // end: 100,//黑认认为1@0
|
|
|
+ type: "slider",
|
|
|
+ show: false,
|
|
|
+ // xAxisIndex: [0]
|
|
|
+ handlesize: 0,//滑动条的 左右2个滑动条的大小
|
|
|
+ startValue: 5,// 初始显示值
|
|
|
+ endValue: 0,// 结束显示值
|
|
|
+ height: 10,//组件高度
|
|
|
+ left:"5%",
|
|
|
+ right: "4%",//右边的距离
|
|
|
+ bottom: "25%",//底边的距离
|
|
|
+ borderColor:"#939",
|
|
|
+ fillerColor:"#269cdb",
|
|
|
+ borderRadius: 5,
|
|
|
+ backgroundColor: "#33384b",//两边未选中的滑动条区域的额色
|
|
|
+ showDataShadow: false,//是否显示数据阴影
|
|
|
+ showDetail: false,//即拖拽时候是否显示详细数值信息
|
|
|
+ truerealtime: true,//是否实时更新
|
|
|
+ filterMode: "filter"
|
|
|
+ },{
|
|
|
+ type:'inside',
|
|
|
+ show: true,
|
|
|
+ start: 1,
|
|
|
+ end: 100
|
|
|
+ }
|
|
|
+ ],
|
|
|
grid: {
|
|
|
top: '16%',
|
|
|
right: '3%',
|
|
@@ -1720,6 +1756,32 @@ let app = new Vue({
|
|
|
nterval: 2000,
|
|
|
loopSeries: true,
|
|
|
})
|
|
|
+ let arr = executeList.map(item => item.value2)
|
|
|
+ this.timeOut = setInterval(function () {
|
|
|
+
|
|
|
+ let startValue = myChart.getModel().option.dataZoom[0].startValue;
|
|
|
+ let endValue = myChart.getModel().option.dataZoom[0].endValue;
|
|
|
+ let start = myChart.getModel().option.xAxis[0].data[startValue];//起始X轴
|
|
|
+ let end = myChart.getModel().option.xAxis[0].data[endValue];//结束X轴
|
|
|
+ // 每次向后滚动一个,最后一个从头开始。
|
|
|
+ // console.log(option.dataZoom[0].endValue);
|
|
|
+
|
|
|
+ if (option.dataZoom[0].endValue >= 12) {
|
|
|
+ option.dataZoom[0].endValue = 5
|
|
|
+ option.dataZoom[0].startValue = 0
|
|
|
+ } else {
|
|
|
+ option.dataZoom[0].endValue = option.dataZoom[0].endValue + 6
|
|
|
+ option.dataZoom[0].startValue = option.dataZoom[0].startValue + 6
|
|
|
+ }
|
|
|
+
|
|
|
+ // myChart.dispatchAction({
|
|
|
+ // type: 'showTip',
|
|
|
+ // seriesIndex: 0,
|
|
|
+ // dataIndex: startValue +1,
|
|
|
+ // });
|
|
|
+ myChart.setOption(option);
|
|
|
+ }, 12000);
|
|
|
+
|
|
|
},
|
|
|
initChartR1() {
|
|
|
let myChart = echarts.init(this.$refs['echartL1'])
|
|
@@ -1835,6 +1897,7 @@ let app = new Vue({
|
|
|
nterval: 2000,
|
|
|
loopSeries: true,
|
|
|
})
|
|
|
+
|
|
|
},
|
|
|
|
|
|
initChartR2() {
|
|
@@ -1842,9 +1905,15 @@ let app = new Vue({
|
|
|
let option = {
|
|
|
tooltip: {
|
|
|
trigger: 'item',
|
|
|
- position: ['65%', '42%'],
|
|
|
+ position: (point,params,dom,rect,size) => {
|
|
|
+ if(params.name == '新建'){
|
|
|
+ return ['55%','45%']
|
|
|
+ } else {
|
|
|
+ return ['15%','40%']
|
|
|
+ }
|
|
|
+ },
|
|
|
formatter: params => {
|
|
|
- return `<span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${params.color}"></span> 项目数量:${params.value}个 <br/><span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${params.color}"></span> 投资完成额:${params.data.value2}亿`
|
|
|
+ return `<span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${params.color}"></span> ${params.name}:${params.value}<br/><span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${params.color}"></span> 投资完成额:${params.data.value2}`
|
|
|
}, //+ '<br/>'+ '{a1}:{c1}' + '%',
|
|
|
axisPointer: {
|
|
|
type: 'cross',
|
|
@@ -1884,7 +1953,7 @@ let app = new Vue({
|
|
|
}
|
|
|
myChart.setOption(option)
|
|
|
tools.loopShowTooltip(myChart, option, {
|
|
|
- nterval: 2000,
|
|
|
+ nterval: 10000,
|
|
|
loopSeries: true,
|
|
|
})
|
|
|
},
|