Echarts橫向堆疊柱狀圖和markLine實例詳解
1.Echarts 橫向堆疊柱狀圖 + markLine
效果圖
根據月份計算百分比展示markLine
思路: 根據月份計算百分比展示markLine,例如3月就是25%,這裡的圖表是數值,所以markLine要展示百分比需要進行一下計算,思路是在series裡添加一個專門為瞭markLine處理的(這裡是雙柱子所以要采用這種方法,如果是單個柱子就不需要,可以直接在series裡邊項寫markLine),具體計算方式在option代碼上面,大傢自行看一下這裡不復制重復寫瞭
驗證:我這裡的x軸隱藏掉瞭,大傢為瞭驗證計算的對不對可以把axisLabel show: 改為true,對比下數值和markLine值是否正確
代碼如下:
mychart() { var myChart = echarts.init(document.getElementById('profitTotal6')); let echartData = [{ name: "其他", value1: 64, value2: 84, }, { name: "運輸", value1: 104, value2: 164, }, { name: "化工", value1: 619.59, value2: 354.00, }, { name: "煤炭", value1: 338.01, value2: 154.00, }, { name: "光伏", value1: 248.69, value2: 934.00, }, { name: "風電", value1: 556.43, value2: 654.00, }, { name: "水電", value1: 816.31, value2: 354.00, }, { name: "火電", value1: 221.87, value2: 154.00, } ]; let xAxisData = echartData.map(v => v.name); let yAxisData1 = echartData.map(v => v.value1); let yAxisData2 = echartData.map(v => v.value2); let bgdata = []; echartData.map(item => { bgdata.push(parseInt(item.value1 + item.value2) + 100); }) let maxxAxis = Math.max.apply(null,bgdata);//設置x軸最大值 let date_ = new Date(); let month = date_.getMonth() + 1; let markyAxis = maxxAxis / 12 * month; //markLine值 let markyvalueText = parseInt(markyAxis / maxxAxis * 100); //為瞭控制百分樣式 let paddingStyle;//根據數值動態設置padding樣式 if (0 <= markyvalueText && markyvalueText < 10) { paddingStyle = [10, 7]; } else if (10 <= markyvalueText && markyvalueText < 100) { paddingStyle = [10, 5]; } else { paddingStyle = [14, 5]; } option = { // tooltip: { // trigger: 'axis', // axisPointer: { // type: 'shadow' // } // }, legend: { data: ['年度投資完成額(滯後)', '年度投資計劃'], orient: "horizontal",//vertical x: 'center', // y: 'bottom', // right: '-50%', bottom: '2%', icon: "roundRect1", selectedMode: false,//取消圖例上的點擊事件 itemWidth: 16, // 設置寬度 itemHeight: 10, // 設置高度 itemGap: 10,// 設置間距 textStyle: {//文字根據legend顯示 color: "#FFFFFF", fontSize: 12, }, }, grid: { left: '8%', top: '18%', right: '8%', bottom: '12%', containLabel: true }, yAxis: { type: 'category', triggerEvent: true, data: xAxisData, axisLine: { show: false }, axisLabel: { color: "#FFFFFF", fontSize: '14', // interval: 0, // rotate: rotate//文字旋轉角度 }, axisTick: { show: false, alignWithLabel: true, lineStyle: { color: '#0C4F81', type: 'solid' } }, }, xAxis: { type: 'value', max: maxxAxis, nameTextStyle: { color: '#4F88BD', padding: [0, 25, -5, 0], fontSize: 12, fontFamily: 'Microsoft YaHei', }, axisLine: { show: false, lineStyle: { color: "#0C4F81" } }, axisLabel: { show: false,// color: "#4F88BD", fontSize: '12', formatter: '{value}' }, splitLine: { show: false, lineStyle: { type: "dotted", color: "#0C4F81" } }, axisTick: { show: false }, }, series: [ { name: '年度投資完成額(滯後)', type: 'bar', barMaxWidth: 15, stack: 'Ad', emphasis: { focus: 'series' }, itemStyle: { normal: { label: { show: true, // position: 'top', color: '#ffffff' }, color: new echarts.graphic.LinearGradient(0, 0, 1, 0, [{ offset: 0, color: "rgba(128, 123, 254, 1)" }, { offset: 1, color: "rgba(230, 143, 252, 1)" } ]), } }, data: yAxisData1, }, { name: '年度投資計劃', type: 'bar', barMaxWidth: 15, stack: 'Ad', emphasis: { focus: 'series' }, itemStyle: { normal: { label: { show: true, // position: 'top', color: '#ffffff' }, color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: "rgba(13, 78, 137, 1)" }, { offset: 1, color: "rgba(13, 78, 137, 1)" } ]), } }, data: yAxisData2, }, { // 為瞭處理markline name: '最長背景', type: 'bar', barMaxWidth: 5, color: 'transparent', data: bgdata, markLine: { data: [ { name: '考核臨界線',xAxis:markyAxis}, ], silent: true, symbol:'none',//去掉箭頭 itemStyle: { normal: { lineStyle: { color: '#FA7F3C', type: 'solid' }, label:{ // color: '#FA7F3C', formatter:'{c}%', show:true, backgroundColor: '#FFF7F2', color: '#DB6525', fontSize: '100%', borderColor: '#FFF7F2', formatter: function(v){ var s = parseInt(v.value / maxxAxis * 100); return s + '%'; }, padding:paddingStyle, borderRadius: 50, } } }, }, }, ] }; myChart.clear(); myChart.setOption(option); },
2.Echarts 橫向堆疊柱狀圖 + markLine
效果圖
根據數據計算百分比展示markLine
代碼如下
根據數據計算百分比展示markLine,和上面基本同理,這個隻是數值上的轉換,和月份沒有關系瞭
mychart() { var myChart = echarts.init(document.getElementById('profitTotal2')); let echartData = [{ name: "其他", value1: 64, value2: 84, }, { name: "運輸", value1: 104, value2: 164, }, { name: "化工", value1: 619.59, value2: 354.00, }, { name: "煤炭", value1: 338.01, value2: 154.00, }, { name: "光伏", value1: 248.69, value2: 934.00, }, { name: "風電", value1: 556.43, value2: 654.00, }, { name: "水電", value1: 816.31, value2: 354.00, }, { name: "火電", value1: 221.87, value2: 154.00, } ]; let xAxisData = echartData.map(v => v.name); let yAxisData1 = echartData.map(v => v.value1); let yAxisData2 = echartData.map(v => v.value2); let bgdata = []; echartData.map(item => { bgdata.push(parseInt(item.value1 + item.value2) + 100); }) let maxxAxis = Math.max.apply(null,bgdata);//設置x軸最大值 let markyAxis = maxxAxis * 0.9; //markLine值90% let markyvalueText = parseInt(markyAxis / maxxAxis * 100); //為瞭控制百分樣式 let paddingStyle;//根據數值動態設置padding樣式 if (0 <= markyvalueText && markyvalueText < 10) { paddingStyle = [10, 7]; } else if (10 <= markyvalueText && markyvalueText < 100) { paddingStyle = [10, 5]; } else { paddingStyle = [14, 5]; } option = { // tooltip: { // trigger: 'axis', // axisPointer: { // type: 'shadow' // } // }, legend: { data: ['合同總額(預警)', '項目概算'], orient: "horizontal",//vertical x: 'center', // y: 'bottom', // right: '-50%', bottom: '2%', icon: "roundRect1", selectedMode: false,//取消圖例上的點擊事件 itemWidth: 16, // 設置寬度 itemHeight: 10, // 設置高度 itemGap: 10,// 設置間距 textStyle: {//文字根據legend顯示 color: "#FFFFFF", fontSize: 12, }, }, grid: { left: '8%', top: '18%', right: '8%', bottom: '12%', containLabel: true }, yAxis: { type: 'category', triggerEvent: true, data: xAxisData, axisLine: { show: false }, axisLabel: { color: "#FFFFFF", fontSize: '14', // interval: 0, // rotate: rotate//文字旋轉角度 }, axisTick: { show: false, alignWithLabel: true, lineStyle: { color: '#0C4F81', type: 'solid' } }, }, xAxis: { type: 'value', max: maxxAxis, nameTextStyle: { color: '#4F88BD', padding: [0, 25, -5, 0], fontSize: 12, fontFamily: 'Microsoft YaHei', }, axisLine: { show: false, lineStyle: { color: "#0C4F81" } }, axisLabel: { show: false, color: "#4F88BD", fontSize: '12', formatter: '{value}' }, splitLine: { show: false, lineStyle: { type: "dotted", color: "#0C4F81" } }, axisTick: { show: false }, }, series: [ { name: '合同總額(預警)', type: 'bar', barMaxWidth: 15, // zlevel: 1, stack: 'Ad', emphasis: { focus: 'series' }, itemStyle: { normal: { label: { show: true, // position: 'top', color: '#ffffff' }, color: new echarts.graphic.LinearGradient(0, 0, 1, 0, [{ offset: 0, color: "rgba(252, 175, 159, 1)" }, { offset: 1, color: "rgba(241, 88, 135, 1)" } ]), } }, data: yAxisData1, }, { name: '項目概算', type: 'bar', barMaxWidth: 15, // zlevel: 1, stack: 'Ad', emphasis: { focus: 'series' }, itemStyle: { normal: { label: { show: true, // position: 'top', color: '#ffffff' }, color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: "rgba(13, 78, 137, 1)" }, { offset: 1, color: "rgba(13, 78, 137, 1)" } ]), } }, data: yAxisData2, }, { // 為瞭處理markline name: '最長背景', type: 'bar', barMaxWidth: 5, // barGap: '-100%', color: 'transparent', // itemStyle: { // normal: { // color: '#1B375E', // barBorderRadius: 0, // }, // }, data: bgdata, markLine: { data: [ { name: '考核臨界線',xAxis:markyAxis}, ], silent: true, symbol:'none',//去掉箭頭 itemStyle: { normal: { lineStyle: { color: '#FA7F3C', type: 'solid' }, label:{ formatter:'{c}%', show:true, backgroundColor: '#FFF7F2', color: '#DB6525', fontSize: '100%', borderColor: '#FFF7F2', formatter: function(v){ var s = parseInt(v.value / maxxAxis * 100); return s + '%'; }, padding:paddingStyle, borderRadius: 50, } } }, }, }, ] }; myChart.clear(); myChart.setOption(option); },
總結
到此這篇關於Echarts橫向堆疊柱狀圖和markLine的文章就介紹到這瞭,更多相關Echarts堆疊柱狀圖內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- vue3.0+echarts實現立體柱圖
- vue echarts實現柱狀圖動態展示
- vue+echarts實現進度條式柱狀圖
- echartjs實現cross十星輔助線實現示例詳解
- vue實現橫向斜切柱狀圖