ABI自定义统计图(象形图柱状图+面积图)分享

3624
1

土豆我是马铃薯 数据达人Lv4

发表于2020-5-26 10:15

楼主
本帖最后由 土豆我是马铃薯 于 2020-5-26 10:18 编辑

在ABI通用统计图组件中暂时没有象形柱状图,则需要我们自己在自定义组件中引入echarts。效果如下:


实现方法:

一、在ABI资源管理器中上传echarts资源包echarts.min.js,如下路径(其他路径也行)


二、拖入echarts自定义组件


三、双击自定义组件,填写编译好得代码


代码如下:
  1. EUI.include("vfs/root/products/ebi/echarts.min.js");
  2. //------------------------------------引用请注明出处
  3. var spirit = 'image://';

  4. var maxData =eval('<#=grid1.b3#>');
  5. var maxData1 =eval('<#=grid1.c3#>');
  6. var myData =eval('<#=grid1.a2$#>');
  7. var databeast =eval('<#=grid1.b2$.select(true,@.txt)#>');
  8. var databeast1 =eval('<#=grid1.c2$.select(true,@.txt)#>')
  9. //var databeauty = [280, 128, 255, 254, 313, 143, 360, 343, 338, 163, 333, 317, 263, 302, 372, 163]


  10. option = {
  11.     // tooltip: {
  12.     //     trigger: 'axis',
  13.     //     axisPointer: {
  14.     //         type: 'cross',
  15.     //         crossStyle: {
  16.     //             color: '#999'
  17.     //         }
  18.     //     }
  19.     // },
  20.     tooltip : {
  21.     trigger: 'axis',
  22.   formatter(params) {
  23.       console.log(JSON.stringify(params))

  24.         return `
  25.                 频繁停电数:${params[0].data}
  26.                 频繁停电次数:${params[2].data}
  27.                `;
  28. }
  29. },
  30.     xAxis: {
  31.         type: 'category',
  32.         inverse: true,
  33.         axisLine: {
  34.             show: false
  35.         },
  36.         axisTick: {
  37.             show: false
  38.         },
  39.         axisLabel: {
  40.             interval: 0, //横轴信息全部显示
  41.             show: true,
  42.             margin: 8,
  43.             textStyle: {
  44.                 color: '#868686',
  45.                 fontSize: 14,
  46.             },

  47.         },
  48.         data: myData,
  49.     },
  50.     yAxis: [{
  51.         name:'单位:万元',
  52.          nameTextStyle:{
  53.           color:'#868686',
  54.         },
  55.         color:'#868686',
  56.         type: 'value',
  57.         axisLine: {
  58.             show: false,
  59.         },
  60.         //y轴分割线
  61.         axisTick: {
  62.             show: false,
  63.         },
  64.         position: 'center',
  65.         //y轴标签
  66.         axisLabel: {
  67.             show: true,
  68.             textStyle:{
  69.                 color:'#868686',
  70.                 fontsize:14,
  71.             },
  72.              formatter: function (value, index) {           
  73.                   return value.toFixed(0);      
  74.                  }
  75.         },
  76.         splitLine: {
  77.             show: false,
  78.             lineStyle: {
  79.                 color: '#3E3E3E',
  80.                 width: 1,
  81.                 type: 'dashed',
  82.             },
  83.         },
  84.         splitNumber: 6,
  85.         max:maxData,
  86.        interval: maxData/6


  87.     },{
  88.         name:'单位:万元',
  89.          nameTextStyle:{
  90.           color:'#868686',
  91.         },
  92.         type: 'value',
  93.         axisLine: {
  94.             show: false,
  95.         },
  96.         //y轴分割线
  97.         axisTick: {
  98.             show: false,
  99.         },
  100.         position: 'center',
  101.         //y轴标签
  102.         axisLabel: {
  103.             show: true,
  104.             textStyle:{
  105.                 color:'#868686',
  106.                 fontsize:14,
  107.             },
  108.             formatter: function (value, index) {           
  109.                   return value.toFixed(0);      
  110.                  }   
  111.         },
  112.         splitLine: {
  113.             show: true,
  114.             lineStyle: {
  115.                 color: '#3E3E3E',
  116.                 width: 1,
  117.                 type: 'dashed',
  118.             },
  119.         },
  120.        max:maxData1,
  121.         splitNumber: 6,
  122.   interval: maxData1/6


  123.     }
  124.         ],
  125.     series: [{
  126.             type: 'pictorialBar',

  127.             symbol: 'rect',
  128.             label: {
  129.                 emphasis: {
  130.                     show: true,
  131.                     position: 'center',
  132.                     offset: [0, 0],
  133.                     textStyle: {
  134.                         color: '#000',
  135.                         fontSize: 14,
  136.                     },
  137.                 },
  138.             },
  139.             itemStyle: {
  140.                 normal: {
  141.                     color: '#61FFD8',
  142.                     backgroundColor: 'rgba(2,191,138,1)',
  143.                 },
  144.                 emphasis: {
  145.                     color: '#08C7AE',
  146.                 },
  147.             },
  148.             symbolRepeat: 'fixed',
  149.             symbolClip: true,
  150.             symbolSize: [20, 5],
  151.             symbolBoundingData: maxData,
  152.             animationEasing: 'elasticOut',
  153.             data: databeast,
  154.             animationDelay: function(dataIndex, params) {
  155.                 return params.index * 30;
  156.             }
  157.         },
  158.         {
  159.             // full data
  160.             type: 'pictorialBar',
  161.              yAxisIndex: 0,
  162.             itemStyle: {
  163.                 normal: {
  164.                     color: 'rgba(82,110,63,0.2)'
  165.                 }
  166.             },
  167.             name: '模拟数据1',
  168.             label: {
  169.                 normal: {
  170.                     show: true,
  171.                     formatter: function(params) {
  172.                         return (params.value);
  173.                     },
  174.                   position: ['20%', '0%'],
  175.                     offset: [10, -20],
  176.                     textStyle: {
  177.                         color: '#fff',
  178.                         fontSize: 0
  179.                     }
  180.                 }
  181.             },
  182.             animationDuration: 0,
  183.             symbolRepeat: 'fixed',
  184.             symbolMargin: '5%',
  185.             symbol: 'rect',
  186.             symbolSize: [20, 5],
  187.             symbolBoundingData: maxData,
  188.             data: databeast,
  189.             z: 99999,
  190.             animationEasing: 'elasticOut',
  191.             animationDelay: function(dataIndex, params) {
  192.                 return params.index * 30;
  193.             }
  194.         },
  195.         {
  196.             name: '模拟数据',
  197.             type: 'line',
  198.              yAxisIndex: 1,
  199.             smooth: true,
  200.             symbol: 'circle',
  201.             symbolSize: 5,
  202.             sampling: 'average',
  203.              symbolBoundingData: maxData1,
  204.             itemStyle: {
  205.                 color: '#FFC002'
  206.             },
  207.             stack: 'a',
  208.             areaStyle: {
  209.                 color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
  210.                     offset: 0,
  211.                     color: 'rgba(255,192,2,0.32)'
  212.                 }, {
  213.                     offset: 1,
  214.                     color: 'rgba(3,16,23,-0.01)'
  215.                 }])
  216.             },
  217.             data: databeast1
  218.         }

  219.     ],
  220. };
  221. return option;

复制代码



echarts.min.zip (239.78 KB, 下载次数: )

最近看过此主题的会员

esen_4TM8T6J7Y5

esen_53PEHNYN7Q

esen_4Y3L5ADO80

esen_50U2PL1OSG1M

leony

123890

esen_4TUELCHD9M

v笑向前走

wxw

esen_50GY6WGUZV

esen_4YNPQEX87K

esen_4YO0F42DH6

huxh

esen_4V5P4W1G9J

sunmeiling

zhuhc

1个回答

只看楼主

小亿 管理员

发表于2020-5-26 10:24

只看该作者

取消 关注该作者的回复

沙发

感谢大神分享,打卡么么哒~

登录后可回答问题,请登录注册

快速回复 返回顶部 返回列表

小时

全天响应

分钟

快速处理问题

工程师强势助力

明星产品
解决方案
联系合作

400咨询:400-0011-866

技术支持QQ:400-0011-866(工作日9:00-18:00)

产品建议邮箱yixin@esensoft.com

关注我们

扫TA学习更多干货

一对一专家交流

版权所有© 2006-2024 北京亿信华辰软件有限责任公司 京ICP备07017321号 京公网安备11010802016281号