echarts画对数坐标坐标[-0.2, 0.6],Y轴不等刻度问题

使用markLine实现y轴刻度不等分

一:实现理论
对数不支持负数坐标,所以将[-1,1]映射到[0,1];
对应的映射函数: y = 1/2x+1/2
2) 则现实的区间为:[-0.2,0.6]
3) 画线:yAxis = for( i=min; i<=max; i= i+0.1){log10(i0.5+ 0.5)100;}
YLine = [ -0.2, -0.1, 0,1, …, 0.6]
yAxis = log10(YLine
0.5 + 0.5)100
name = YLine
100+’%’
4) 需要画的曲线:YLineE = log10(X/100
0.5 + 0.5)*100

注:
需要乘100的原因是,echarts自己会对小数点第三位四舍五入,所以乘100

二:代码实现如下

option = {
    xAxis: {
        type: 'category',
        data: ['1', '2', '3', '4', '5', '6', '7','8','9']
    },
    yAxis: {
        type: 'value',
        "axisTick":{       //y轴刻度线
          "show":false
        },
        "splitLine": {     //网格线
          "show": false
        },
        axisLabel: {
          show: false,//不显示坐标轴上的文字
    },
        min:-50,
        max:0
    },
    series: [
    {
        data: [-39.79, -34.68, -30.10, -25.96,-22.18,-18.71,-15.49,-12.49,-9.69],
        type: 'line',
        smooth: true,
        
        markLine: {
                symbol: ['none', 'none'],//去掉箭头
                itemStyle: {
                    normal: { lineStyle: { type: 'solid', color:'black'}
                    ,label: { show: true, position:'left',formatter:'{b}'} }
                },
                formatter: function (params) {
                },
                data: [{
                        name: '-20%',
                        yAxis: -39.79
                },
                {
                        name: '-10%',
                        yAxis: -34.68
                },
                {
                        name: '0%',
                        yAxis: -30.10
                },
                {
                        name: '10%',
                        yAxis: -25.96
                },
                {
                        name: '20%',
                        yAxis: -22.18
                },
                {
                        name: '30%',
                        yAxis: -18.71
                },
                {
                        name: '40%',
                        yAxis: -15.49
                },
                {
                        name: '50%',
                        yAxis: -12.49
                },
                {
                        name: '60%',
                        yAxis: -9.69
                },
                ]
        }}]
};

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值