zoukankan      html  css  js  c++  java
  • echarts二维坐标这样写出立体柱状图

    一、方法一,直接使用立体图片来显示,即series里面type:‘pictorialBar’

    代码如下:

    //imgUrl可以是图片,可以是svg,是做成像立体柱状图的图片
    const imgUrl = 'image://'
    let yData = [{value:13, symbol: imgUrl},
    {value:53, symbol: imgUrl},
    {value:23, symbol: imgUrl},
    {value:43, symbol: imgUrl},
    {value:66, symbol: imgUrl},
    {value:78, symbol: imgUrl},
    {value:68, symbol: imgUrl}]
    let xData = ['周一', '周二', '周三', '周四', '周五', '周六', '周日']
    let nc = document.getElementById("timeRange");
    let myChart = echarts.init(nc); 

    let option = {
              grid: {
                left: '16%',
                bottom: '26%',
                right: '10%',
                top: '16%'
              },
              tooltip: {
                show: true,
                confine: true, // true限制在图表内部
                trigger: 'axis',
                position(point, params, dom, rect, size) {
                  // 固定在顶部,并且数据下标小于7的显示在右边,大于7的显示在左边
                  return params[0].dataIndex <= 7
                         ? [point[0] + 20, '30%']
                         : {top: '30%', left: point[0] - size.contentSize[0] - 25}
                },
                padding: 6,
                backgroundColor: 'transparent',
                borderWidth: 1,
                borderColor: 'transparent',
                axisPointer: {  //坐标轴指示器,坐标轴触发有效,
                  type: 'shadow', //默认为line,line直线,cross十字准星,shadow阴影
                  shadowStyle: {
                    color: 'rgba(0,222,255,0.3)'
                  }
                }
              },
              xAxis: {
                axisLine: {
                  show: true,
                  lineStyle: {
                    color: '#397cbc'
                  }
                },
                axisTick: {
                  show: true
                },
                axisLabel: {
                  fontSize: 16 * this.scale,
                  color: '#30eee9',
                  interval: '0',//强制显示所有类目
                  rotate: -45,//类目倾斜放
                  textStyle: {
                    color(value, index) {
                      return index < 10 ? '#FCC059' : '#30EEE9';
                    }
                  },
                },
                data: xData,
              },
              yAxis: {
                type: 'value',
                minInterval: 1,
                axisLabel: {
                  formatter: '{value}',
                  textStyle: {
                    color: '#2ad1d2'
                  }
                },
                axisLine: {
                  show: false
                },
                axisTick: {
                  show: false
                },
                splitLine: {
                  //背景网格线
                  show: true,
                  lineStyle: {
                    color: '#125770'
                  }
                }
              },
              series: [
                {
                  type: 'pictorialBar',
                  symbol: imgUrl,
                  barGap: 0,
                  barWidth: 20,//柱图宽度
                  symbolSize: ['100%', '100%'],
                  data: yData
                }
              ]
            }
    myChart..setOption(option)

      

    二、使用三个series数据拼接,并使用相应的颜色阴影组合成类立体图形

    代码:直接上关键代码
    let yData = [23, 30, 33, 5, 60, 7, 88]
    let xData = ['周一', '周二', '周三', '周四', '周五', '周六', '周日']
    let nc = document.getElementById("timeRange");
    let myChart = echarts.init(nc); 
    // option设置 let option = { grid: { // 整体位置 left: 0, // 距离左侧距离 bottom: 0, // 距离低侧的距离 top: 10, // 距离顶部的距离 right: 0, // 距离右侧的距离 height: 'auto', 'auto', containLabel: true }, tooltip: { show: true, confine: true, // true限制在图表内部 trigger: 'axis', position(point, params, dom, rect, size) { // 固定在顶部 return params[0].dataIndex <= 17 ? [point[0] + 20, '30%'] : {top: '30%', left: point[0] - size.contentSize[0] - 25} }, padding: 6, backgroundColor: 'transparent', borderWidth: 1, borderColor: 'transparent', axisPointer: { //坐标轴指示器,坐标轴触发有效, type: 'shadow', //默认为line,line直线,cross十字准星,shadow阴影 shadowStyle: { color: 'rgba(0,222,255,0.3)' } } }, xAxis: { axisLine: { show: true, lineStyle: { color: '#397cbc' } }, axisTick: { show: true }, axisLabel: { fontSize: 16 * this.scale, color: '#30eee9', interval: '0',//强制显示所有类目 rotate: -45,//类目倾斜放 textStyle: { color(value, index) { return index < 10 ? '#FCC059' : '#30EEE9'; } }, }, data: xData, }, yAxis: { type: 'value', minInterval: 1, axisLabel: { formatter: '{value}', textStyle: { color: '#2ad1d2' } }, axisLine: { show: false }, axisTick: { show: false }, splitLine: { //背景网格线 show: true, lineStyle: { color: '#125770' } } }, series: [ // 数据配置项(柱状图) { // 正面 type: 'bar', // 图表类型 bar 为柱状图 barWidth: 20, // 柱体的宽度 data: yData, // 柱体数据 itemStyle: { // 单个柱体的配置项 color: '#4A90E2' }, barGap: 0 // 柱体间隔 }, { // 侧面 type: 'bar', barWidth: 20, itemStyle: { color: '#3773BA' }, data: yData, barGap: 0 }, { // 顶部 name:'b', tooltip:{ show:false }, type: 'pictorialBar', itemStyle: { //顶部 normal: { color:function(params) { let colorList = ["#FC9F9F","#F7B177","#BBF64A","#4DF4EE","#947FFA","#749f83","#ca8622","#bda29a","#6e7074","#546570"]; return colorList[params.dataIndex]; }, borderColor:'', borderWidth:0.01, label: { show: true, //开启显示 position: 'top', //在上方显示 textStyle: { //数值样式 color :'black', fontSize: 16, fontFamily:'微软雅黑', } } } }, symbol: 'rect', symbolRotate:45, symbolSize: ['30','30'], symbolOffset:['0','-17'], symbolPosition: 'end', data: yData, z:3 } ] }
    myChart..setOption(option)

      

  • 相关阅读:
    SourceTree Win10 安装过程及配置
    Laravel 5.5 官方推荐 Nginx 配置学习
    Laravel 获取当前 Guard 分析 —源自电商购物车的实际需求
    Laravel Query Builder 复杂查询案例:子查询实现分区查询 partition by
    Laravel Scheduling Package
    Homestead 中使用 laravel-mix 问题汇总
    iBrand 教程:Git 软件安装过程截图
    使用 Satis 搭建私有的 Composer 包仓库
    Windows + Homestead 5 搭建 Laravel 开发环境
    Homestead 安装 phpMyAdmin 作为数据库管理客户端 — Laravel 实战 iBrand API 教程
  • 原文地址:https://www.cnblogs.com/CandyDChen/p/15186909.html
Copyright © 2011-2022 走看看