Custom tick size on axis (d3js)

前端 未结 2 1147
时光取名叫无心
时光取名叫无心 2020-12-05 15:50

I am creating a svg x-y-chart in d3.js. Is it possible to create ticks of different lengths depending on tickValue?

I have made my own tickFormat function myTi

相关标签:
2条回答
  • 2020-12-05 16:03

    Variant on the answer that suits my requirements. Picked the values I just wanted tick marks for instead of ticks and value, added the "hide" class. But this can be used for any variation on the theme.

                var gy = humiditySVG.append( "g" )
                    .attr( "class", "y axis" )
                    .attr( "transform", "translate(" + 154 + "," + 0 + ")" )
                    .call( yAxis );
    
                humiditySVG.selectAll( "text" )
                    .attr( "class", function ( d ) {
                                               if ( $.inArray(d, [0,50,100])==-1  ) {
                                   return "hide";
                               }
                               return;
                           } );
                humiditySVG.selectAll( "line" )
                    .attr( "x2", function ( d ) {
                               if ( $.inArray(d, [0,50,100])==-1  ) {
                                   return 1;
                               } else {
                                   return 3;
                               }
                               return;
                           } );
    
    0 讨论(0)
  • 2020-12-05 16:05

    The tickSize function can only accept a number as argument, not a function, but there are other solutions.

    The easiest approach? After the axis is drawn, select all the tick lines and resize them according to their data value. Just remember that you'll have to do this after every axis redraw, as well.

    Example:
    https://jsfiddle.net/zUj3E/1/

    Key code:

    d3.selectAll("g.y.axis g.tick line")
        .attr("x2", function(d){
        //d for the tick line is the value
        //of that tick 
        //(a number between 0 and 1, in this case)
           if ( (10*d)%2 ) //if it's an even multiple of 10%
               return 10;
           else
               return 4;
        });
    

    Note that the tick marks at the max and min values are also drawn as part of the same <path> as the axis line, so shortening them doesn't have much effect. If you don't like that lack of control, declare the "outer" ticks to have zero length when you set up the axis. That turns off the corners of the path, but the outer ticks will still have lines that you can control the same as the other tick lines:

    var axis = d3.svg.axis()
        .tickSize(10,0)
    

    Example: https://jsfiddle.net/zUj3E/2/

    If that doesn't work, google for examples of major/minor tick patterns. Just make sure the example you're looking at uses d3 version 3: there were a few extra tick-related methods added in version 2 that are no longer supported. See this SO Q&A.

    0 讨论(0)
提交回复
热议问题