17- Echarts 配置系列之:单轴 singleAxis

发布时间:2024年01月11日

singleAxis:

用于展示只有一个数据维度的数据。它通常用于展示时间序列数据或者数值序列数据。

对于单轴的应用和绘制,其实就相当于我们平时的直角坐标系少一个 X 或者 Y ,然后进行图形绘制。

注意:

1.在使用单轴时,请先了解以下几点基础知识:

数据轴 value:?用于展示连续的数值数据,连续的数值型数据!例如 数值

类目轴 category:?类目轴适用于展示离散的类别数据,非数值型数据!例如文本、标签

时间轴 time:时间轴用于展示时间序列数据,时间轴上的刻度按照时间的先后顺序排列,刻度之间的间隔会自动根据时间跨度进行调整。

对数轴 log:用于展示数据的对数关系。

上面几个为 轴的基本类型,轴在使用不同的data类型时,需要将 轴的type对应上,不然轴的绘制会出现错误。

2. 我这边配置有一个属性无效的, tooltip 中的 type 设置为 cross 十字准星指示器,配置无效,这样也使其中的 crossStyle 配置无用。首先singleAxis 为单轴,按道理来说本身图形不会存在第二轴来支持 cross 。大家配置的时候可以自己验证一下是否有效,有不同结果欢迎文章评论中讨论。

一、配置代码?

option:{
   singleAxis:{
       id:'2',                   // 组件Id
       z:2,                      // 组件绘制优先级
       zlevel:0,                 // 组件层级优先级
       left:'10%',               // 组件距离容器左侧的距离
       right:'10%',              // 组件距离容器右侧的距离
       top:'10%',                // 组件距离容器顶部的距离
       bottom:'10%',             // 组件距离容器底部的距离
       width:'auto',             // 组件宽度
       height:'auto',            // 组件高度
       orient:'vertical',        // 轴的朝向, horizontal 水平或者 vertical
       type:'category',          // 轴的类型
       name:'name',              // 轴的名称
       nameLocation:'end',       // 轴名称显示位置
       nameGap:15,               // 轴名称与轴线之间的距离
       nameRotate:90,            // 轴名称旋转的角度
       inverse:true,             // 是否反向坐标轴
       boundarGap:['10%','10%'], // 坐标轴两边的留白大小
       min:0,                    // 坐标轴刻度最小值
       max:100,                  // 坐标轴刻度最大值
       scale:true,               // 是否脱离 0 刻度值,仅在 type 为 value有效
       splitNumber:5,            // 坐标轴分割段数
       minInterval:10,           // 坐标轴最小间隔大小
       maxInterval:50,           // 坐标轴最大间隔大小
       interval:10,              // 强制设置坐标轴分段间隔
       logBase:10,               // 对数轴的底数
       silent:true,              // 坐标轴是否静态无法交互
       triggerEvent:true,        // 坐标轴标签是否响应触发鼠标事件
       animation:true,           // 是否开启动画
       animationThreshold:200,   // 是否开启动画阈值
       animationDuration:100,    // 初始动画时长
       animationEasing:100,      // 初始动画的缓动效果
       animationDelay:100,       // 初始动画的延迟
       animationDurationUpdate:1000,   // 数据更新动画的时长
       animationEasingUpdate:100,      // 数据更新动画缓动效果
       animationDelayUpdate:100,       // 数据更新动画的延迟
       
       // 坐标轴名称的样式     
       nameTextStyle:{
           color:'red',            //文字颜色
           fontStyle:'normal',     //字体风格
           fontWeight:'normal',    //字体粗细
           fontFamily:'sans-serif',//字体
           fontSize:12,            //字体大小
           align:'left',           //字体水平对齐方式
           verticalAlign:'top',    //竖直对齐方式
           lineHeight:10,          //行高
           backgroundColor:'red',  //文字块背景颜色,可以用图片
           borderColor:'red',      //文字块边框颜色
           borderWidth:5,          //文字块边框宽度
           borderType:'solid',     //文字块描边
           borderDashOffset:10,    //描边为虚线时的偏移量
           borderRadius:10,        //文字块圆角
           padding:[5,5,5,5],      //文字块内边距
           shadowColor:'red',      //文字块阴影颜色
           shadowBlur:10,          //阴影程度
           shadowOffsetX:10,       //阴影在水平方向上的偏移
           shadowOffsetY:10,       //阴影在竖直方向上的偏移
           width:50,               //文本显示宽度
           height:50,              //文本显示高低            
           textBorderColor:'red',  //文字的描边颜色
           textBorderWidth:10,     //描边宽度
           textBorderType:'solid', //描边类型
           textBorderDashOffset:10,//虚线偏移量
           textShadowColor:'red',  //文字的阴影颜色
           textShadowBlur:10,      //文字阴影长度
           textShadowOffsetX:10,   //文字阴影水平偏移量
           textShadowPffsetY:10,   //文字阴影竖直偏移量
           overflow:'none',        //文字超出宽度是否截断或者换行
           ellipsis:'···',         //文字超出截断时,末尾显示的内容  
           // 设置坐标轴名称盒子的丰富样式
           rich:{
              //这里的文字样式优先于上面的配置,同上面的 nameTextStyle包含的配置一样
               color:'red',               //字体颜色
               fontStyle: "italic",       //字体风格
               fontWeight: 'normal',      //字体粗细
               fontFamily:'sans-serif',//字体
               fontSize:12,            //字体大小
               align:'left',           //字体水平对齐方式
               verticalAlign:'top',    //竖直对齐方式
               lineHeight:10,          //行高
               //···略                                                                                                         
           },         
       },
       
       // 坐标轴刻度标签配置
       axisLabel:{
           show:true,                  // 是否显示刻度标签
           interval:1,                 // 坐标轴刻度标签的显示间隔,在类目轴中有效
           inside:false,               // 刻度标签是否朝内 
           rotate:0,                   // 刻度标签旋转角度
           margin:10,                  // 刻度标签与轴线之间的距离
           formatter:'{ared|{value}}',  // 标签内容格式器,使用下面定义的富文本样式
           showMinLabel:true,          // 是否显示最小 tick 的 label
           showMaxLabel:true,          // 是否显示最大 tick 的 label
           hideOverlap:true,           // 是否隐藏重叠标签
           color:'red',                // 标签文字颜色
           fontStyle:'normal',         // 标签文字的风格
           fontWeight:'normal',        // 标签文字粗细
           fontFamily:'serif',         // 字体的字体系列
           fontSize:15,                // 文字字体大小
           align:'center',             // 文字水平对齐方式
           verticaAlign:'top',         // 文字垂直对齐方式
           lineHeight:50,              // 行高
           backgroundColor:'red',      // 文字块背景颜色
           borderColor:'red',          // 文字块边框颜色
           borderWidth:2,              // 文字块边框宽度
           borderType:'solid',         // 文字块边框描边颜色
           borderDashOffset:0,         // 设置虚线的偏移量
           borderRadius:10,            // 文字块圆角
           padding:[5,5],              // 文字块内边距
           shadowColor:'red',          // 文字块背景阴影颜色
           shadowBlur:10,              // 文字块阴影大小
           shadowOffsetX:0,            // 文字块阴影水平偏移量
           shadowOffsetY:10,           // 文字块阴影竖直偏移量
           width:100,                  // 文本显示宽度
           height:100,                 // 文字显示高度
           textBorderColor:'red',      // 文字本身描边颜色
           textBorderWidth:4,          // 文字描边宽度
           textBorderType:'solid',     // 文字描边类型
           textBorderDashOffset:10,    // 文字描边虚线偏移量
           textShadowColor:'red',      // 文字阴影颜色
           textShadowBlur:10,          // 文字阴影长度
           textShadowOffsetX:10,       // 文字阴影水平偏移量
           textShadowOffsetY:10,       // 文字阴影竖直偏移量
           overflow:'none',            // 文字超出宽度是否截断或者换行
           ellipsis:'···',             //  overflow配置为'truncate'时,文本尾巴显示内容
           
           // 富文本设置
           rich:{
               ared:{
                   color:'red',
                   fontSize:20,               
               }           
           }
       }
       
       // 坐标轴轴线配置
       axisLine:{
           show:true,                  // 是否显示轴线
           symbol:'none',              // 轴线两边的箭头
           symbolSize:[10,15],         // 轴线两边箭头大小
           symbolOffset:[0,0],         // 轴线两边箭头的偏移
           // 线的样式
           lineStyle:{
               color:'red',            // 线的颜色
               width:2,                // 线的宽度
               type:'solid',           // 线的类型
               dashOffset:10,          // 虚线的偏移量,type为dashed虚线时生效
               cap:'butt',             // 指定线段末端的绘制图形
               join:'bevel',           // 两个线段连接图形
               miterLimit:10,          // 连接斜截面比例,只有当 join 为 miter 时,生效
               shadowBlur:10,          // 线段阴影大小
               shadowColor:'red',      // 线段阴影颜色
               shadowOffsetX:10,       // 线段阴影水平偏移量
               shadowOffsetY:10,       // 线段阴影竖直偏移量
               opacity:0.5,            // 线段透明度                          
           }                  
       },
       
       // 坐标轴刻度配置
       axisTick:{
           show:true,                   // 是否显示坐标轴刻度
           aligWithLabel:true,          // 刻度线和标签是否对齐
           interval:'auto',             // 坐标轴刻度显示间隔
           inside:true,                 // 坐标轴刻度是否朝内
           length:10,                   // 坐标轴刻度长度
           // 线的样式
           lineStyle:{
               color:'red',            // 线的颜色
               width:2,                // 线的宽度
               type:'solid',           // 线的类型
               dashOffset:10,          // 虚线的偏移量,type为dashed虚线时生效
               cap:'butt',             // 指定线段末端的绘制图形
               join:'bevel',           // 两个线段连接图形
               miterLimit:10,          // 连接斜截面比例,只有当 join 为 miter 时,生效
               shadowBlur:10,          // 线段阴影大小
               shadowColor:'red',      // 线段阴影颜色
               shadowOffsetX:10,       // 线段阴影水平偏移量
               shadowOffsetY:10,       // 线段阴影竖直偏移量
               opacity:0.5,            // 线段透明度             
           },
       },
       
       // 次刻度线的配置
       minorTick:{
           show:true,                  // 是否显示次刻度线
           splitNumber:5,              // 次刻度线分割数
           length:10,                  // 次刻度线的长度
           // 线的样式
           lineStyle:{
               color:'red',            // 线的颜色
               width:2,                // 线的宽度
               type:'solid',           // 线的类型
               dashOffset:10,          // 虚线的偏移量,type为dashed虚线时生效
               cap:'butt',             // 指定线段末端的绘制图形
               join:'bevel',           // 两个线段连接图形
               miterLimit:10,          // 连接斜截面比例,只有当 join 为 miter 时,生效
               shadowBlur:10,          // 线段阴影大小
               shadowColor:'red',      // 线段阴影颜色
               shadowOffsetX:10,       // 线段阴影水平偏移量
               shadowOffsetY:10,       // 线段阴影竖直偏移量
               opacity:0.5,            // 线段透明度       
           }                        
       },
       
      
       
       // 坐标轴分割线配置
       splitLine:{
           show:true,                   // 是否显示分割线
           interval:1                   // 分割线显示间隔数
           // 线的样式
           lineStyle:{
               color:'red',            // 线的颜色
               width:2,                // 线的宽度
               type:'solid',           // 线的类型
               dashOffset:10,          // 虚线的偏移量,type为dashed虚线时生效
               cap:'butt',             // 指定线段末端的绘制图形
               join:'bevel',           // 两个线段连接图形
               miterLimit:10,          // 连接斜截面比例,只有当 join 为 miter 时,生效
               shadowBlur:10,          // 线段阴影大小
               shadowColor:'red',      // 线段阴影颜色
               shadowOffsetX:10,       // 线段阴影水平偏移量
               shadowOffsetY:10,       // 线段阴影竖直偏移量
               opacity:0.5,            // 线段透明度       
           },        
       },
       // 坐标轴次分割线
       minorSplitLine:{
           show:true,                   // 是否显示分割线
           // 次分割线的样式
           lineStyle:{
               color:'red',            // 线的颜色
               width:2,                // 线的宽度
               type:'solid',           // 线的类型
               dashOffset:10,          // 虚线的偏移量,type为dashed虚线时生效
               cap:'butt',             // 指定线段末端的绘制图形
               join:'bevel',           // 两个线段连接图形
               miterLimit:10,          // 连接斜截面比例,只有当 join 为 miter 时,生效
               shadowBlur:10,          // 线段阴影大小
               shadowColor:'red',      // 线段阴影颜色
               shadowOffsetX:10,       // 线段阴影水平偏移量
               shadowOffsetY:10,       // 线段阴影竖直偏移量
               opacity:0.5,            // 线段透明度       
           },       
       },
       
       // 分割区配置
       splitArea:{
           interval:'auto',
           show:false,
           // 区域样式
           areaStyle:{
               color:['red','#fff','#999'],         // 分割区颜色,设置多个时,会按照你的颜色依次循环填充
               shadowBlur:20,                       // 分割区阴影大小
               shadowColor:'red',                   // 分割区阴影颜色
               shadowOffsetX:10,                    // 分割区阴影水平偏移量
               shadowOffsetY:10,                    // 分割区阴影竖直偏移量
               opacity:1,                           // 分割区透明度                          
           }     
       },
       
       // 类目数据
       data:[                                        // 设置 data后,默认 singleAxis.type 为  category,若不设置 data,则默认从 server.data 获取
       
       // 刻度一
       {
           value:'周一',
           // 单独配置刻度标签的样式
           textStyle:{
                color: 'red',                     // 颜色
                fontStyle: 'normal',              // 字体风格
                fontWeight: 500, //或者 'noraml', //  字体粗细
                fontSize: 16,                     // 字体大小
                lineHeight: 20,                   // 行高
                textBorderWidth: 20,              // 文本描边宽度
                textBorderColor: 'red',           //描边颜色
                textBorderType: 'solid',          //描边类型
                textBorderDashOffset: 20,         // 虚线偏移量
                textShadowBlur: 20,               // 文字阴影长度
                textShadowOffsetX: 20,            //阴影相当于 X 轴偏移量
                textShadowOffsetY: 20,            //阴影相当于 Y 轴偏移量
                overflow: 'truncate',             //文字超出宽度如何处理  break 换行
                ellipsis: '...'                   // 配合 overflow 截断时,展示 ···     
           },      
       }, 
       // 刻度二 
       {
           value:'周二',
           textStyle:{ ···· }                  
       },
       ····                                     
       ],
       
       // data 简单配置
       data:['周一','周二','周三','周四'], 
       
       // 坐标轴指示器
       axisPointer:{
           show:false,           // 是否显示径向的指示器
           type:'line',          // 径向指示器类型
           snap:true,            // 指示器是否吸附到点上
           z:1,                  // 指示器的 z 值
           animation:true,                  //是否开启动画
           animationThreshold:2000,         //动画的阈值,单个系列显示的图形数量大于这个阈值时会关闭动画。
           animationDuration:1000,          //初始动画的时长
           animationEasing:'cubicOut',      //初始动画的缓动效果
           animationDelay:2000,             //初始动画的延迟
           animationDurationUpdate:1000,    //数据更新动画的时长
           animationEasingUpdate:200,       //数据更新动画的缓动效果
           animationDelayUpdate:200,        //数据更新动画的延迟           
           triggerEmphasis:true,            //是否触发强调功能
           triggerTooltip:true,             //是否触发 tooltip
           value:10,                        // axisPointer 的初始位置
           status:'show',                   //当前状态 
           //指示器文本标签
           label:{
               show:true,        //是否显示文本标签
               precision:'auto',              //显示文本值的小数点
               formatter:"显示文字",           //文本标签显示设置,可写方法
               margin:3,                      //label 距离轴的距离
               color: "rgba(234, 21, 21, 1)",
 //文字颜色         
               fontStyle:'normal',            //字体风格
               fontWeight:'normal',           //字体粗细
               fontFamily:'sans-serif',       //文字字体
               fontSize:15,                   //字体大小
               lineHeigh:10,                  //行高
               width:10,                      //文字显示宽度
               height:10,                     //文字显示高度
               textBorderColor:'red',         //文本描边颜色
               textBorderWidth:10,            //文本描边宽度
               textBorderType:'solid',        //描边类型
               textBorderDashOffset:10,       //描边为虚线时的偏移量
               textShadowColor:'transparent', //文字阴影颜色
               textShadowBlur:10,             //文字阴影长度
               textShadowOffsetX:10,          //文字阴影水平偏移量
               textShadowOffsetY:10,          //文字阴影竖直偏移量
               overflow:'none',               //文字超出是否截断
               ellipsis:'···',                //文字截断时末尾显示内容
               padding:[5,5,5,5],             //文本标签内边距 
                        
               backgroundColor:'auto',        //文本标签的背景颜色
               borderColor:'red',             //文本标签的边框颜色
               borderWidth:20,                //文本标签的边框宽度
               shadowBlur:20,                 //文本标签阴影大小
               shadowColor:'red',             //阴影颜色
               shadowOffsetX:20,              //文本标签的阴影水平偏移
               shadowOffsetY:20,              //文本标签的阴影竖直偏移                   
           },
           // 指示器 竖直 标记线的样式
           lineStyle:{
               color:'red',                    //线的颜色。
               width:10,                       //线宽
               type:10,                        //线的类型
               dashOffset:10,                  //虚线的偏移量  
               cap:'butt',                     //线段末端的形状
               join:'bevel',                   //线段相连部分形状
               miterLimit:10,                  // join 为 miter 设置斜接面限制比例
               shadowBlur:10,                  //线的阴影大小
               shadowColor:'red',              //线的阴影颜色
               shadowOffsetX:20,               //阴影水平偏移
               shadowOffsetY:20,               //阴影竖直偏移
               opacity:0.5,                    //线的透明度               
           },
           // 当指示器的类型 type ='shadow' 生效 阴影指示器
           shadowStyle:{
               color: "rgba(194, 91, 91, 1)",   //填充颜色
               shadowBlur:10,                   //图形的阴影模糊程度
               shadowColor:10,                  //阴影颜色    
               shadowOffsetX:10,                //阴影水平偏移距离 
               shadowOffsetY:10,                //阴影水平偏移距离
               opacity:0.5,                     //图形透明度                
           },

           //控制手柄配置
           handle:{
               show:true,                       //是否显示手柄
               icon:'image://图片URL',          //手柄图标
               size:45,                         //手柄尺寸
               margin:50,                       //手柄中心与轴的距离
               color:'red',                     //手柄颜色
               throttle:40,                     //视图更新周期
               shadowBlur:4,                    //图形阴影大小
               shadowColor:'red',               //阴影颜色
               shadowOffsetX:2,                 //阴影在水平方向上的偏移
               shadowOffsetY:2,                 //阴影在垂直方向上的偏移        
           },     
       },
       // 单轴的提示组件配置
       tooltip:{
           show:true,                            // 是否显示提示组件
           trigger:'item',                       // 触发类型
           position:['50%','50%'],               // 提示悬浮框的位置
           formatter:'{b}',                      // 内容格式器
           valueFormatter:(value) => '$' + value,// 数值显示部分的格式化回调函数。
           backgroundColor:'red',                // 提示悬浮框的背景颜色
           borderColor:'#333',                   // 悬浮框边框颜色      
           borderWidth:2,                        // 悬浮框边框宽度
           padding: [5,5],                       // 悬浮框内边距
           extraCssText:"css",                   // 而外添加的css样式
           
           //坐标轴指示器配置
           axisPointer{
               // 与上面的 axisPointer 坐标轴指示器一模一样。         
           },
           
       }
 
       
   } 
}

二、解剖图

?三、配置实例代码

使用:

代码:

option = {
    tooltip: {},

  singleAxis:[
    // 第一个 单轴的基本使用
  {
    width:'88%',
    height:'40%',
    left:'center',
    name:'时间',
    type:'category',
    // 轴指示器
    axisPointer:{
        show:true,
        handle:{
          show:true,
        margin:70,
          size:35,
          icon:'image://'
        },
        label:{
          fontSize:12,
          margin:20,
        },
          lineStyle: {
        color: 'rgba(0,0,0,0.2)',
        width: 2,
        type: 'solid'
      },
      },
      // 类目轴
      data:[
      {
        value:'2022-01-01',
        textStyle:{
          fontSize:14,
          color:'red'
        },
      },
      '2022-01-02',
     {
       value: '2022-01-03',
         textStyle:{
          fontSize:14,
          color:'red'
        },
     },
      '2022-01-04',
      '2022-01-05',
      '2022-01-06',
      '2022-01-07',
      '2022-01-08'
    ],
    // 分割线
    splitLine:{
      show:true,
      lineStyle:{
        width:2,
        color:'#333',
      }
    },
    // 分割区配置
    splitArea:{
      show:true,
    },
    
  },
 
  // 第二个 单轴的河流图
  {
      width:'90%',
      height:'30%',
      bottom:'5%',
      type:'time',
       axisLabel:{
        show:true,
        formatter:'{yyyy}-{MM}-{dd}'
      },
  }
  ],

  series: [
    {
      type: 'scatter',
      // 显示各点值
      label:{
        show:true,
        formatter:'{c}'
      },
      // 根据 data 数值来配置点的大小
      symbolSize: (value, params) => [value,value],
      data: [10,20,15,30,45,65,18,20],
      coordinateSystem: 'singleAxis'
    },

    // 海流图 
     {
      singleAxisIndex:1,
      coordinateSystem: 'singleAxis',
      type: 'themeRiver',
     
      data: [
        ['2015/11/08', 10, 'DQ'],
        ['2015/11/09', 15, 'DQ'],
        ['2015/11/10', 35, 'DQ'],
        ['2015/11/11', 38, 'DQ'],
        ['2015/11/12', 22, 'DQ'],
        ['2015/11/08', 35, 'TY'],
        ['2015/11/09', 36, 'TY'],
        ['2015/11/10', 37, 'TY'],
        ['2015/11/11', 22, 'TY'],
        ['2015/11/12', 24, 'TY'],
     
        ['2015/11/08', 21, 'SS'],
        ['2015/11/09', 25, 'SS'],
        ['2015/11/10', 27, 'SS'],
        ['2015/11/11', 23, 'SS'],
        ['2015/11/12', 24, 'SS'],

        ['2015/11/08', 10, 'QG'],
        ['2015/11/09', 15, 'QG'],
        ['2015/11/10', 35, 'QG'],
        ['2015/11/11', 38, 'QG'],
        ['2015/11/12', 22, 'QG'],

        ['2015/11/08', 18, 'SY'],
        ['2015/11/09', 15, 'SY'],
        ['2015/11/10', 35, 'SY'],
        ['2015/11/11', 38, 'SY'],
        ['2015/11/12', 22, 'SY'],

        ['2015/11/08', 10, 'DD'],
        ['2015/11/09', 15, 'DD'],
        ['2015/11/10', 35, 'DD'],
        ['2015/11/11', 38, 'DD'],
        ['2015/11/12', 22, 'DD'],

      ]
    }
  ]
};

文章来源:https://blog.csdn.net/youyudehan/article/details/135527885
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。