zoukankan      html  css  js  c++  java
  • D3.js学习(三)

    上一节中,我们已经画出了图表,并且给图表添加了坐标轴的标签和标题,在这一节中,我们将要学习几个绘制线条不同特性的几个函数,以及给图表添加格栅。ok,进入话题!

    如何给线条设置绘制的样式?

    这个其实非常简单,在我们之前定义的valueline基础上加一个.interpolate(“样式”)就行啦

    //定义线条
    var valueline = d3.svg.line()
        .interpolate("basis")
        .x(function(d){return x(d.date);})
        .y(function(d){return y(d.close);});

    line().interpolate可取的值有很多,需要深入了解的同学可以查看他的详细说明

    不同取值的有不同效果
    image

    image

    image

    image

    image

    image

    image

     

    给图表增加格栅

    我们知道,增加一系列的格栅可以在视觉效果上有一个很大的提升,那么,我们怎样给图表增加格栅呢?跟前面绘制x轴、y轴一样,我们需要为我们将要绘制的格栅创建三个部分的代码:

      1. 1.在css部分给他设置样式
      2. 2.定义一个初始化(绘制)函数
      3. 3.绘制他

     

    CSS部分

    .grid .tick {
        stroke: lightgrey;
        opacity: 0.7;
    }
    .grid path {
        stroke- 0;
    }

    定义格栅的初始化(绘制)函数

    //定义格栅绘制函数
    function make_x_axis(){
        return d3.svg.axis()
            .scale(x)
            .orient("bottom")
            .ticks(5);
    }
    function make_y_axis(){
        return d3.svg.axis()
            .scale(y)
            .orient("left")
            .ticks(5);
    }

    绘制格栅

    //绘制格栅-x方向
    svg.append("g")
        .attr("class", "grid")
        .attr("transform", "translate(0," + height + ")")
        .call(make_x_axis()
            .tickSize(-height, 0, 0)
            .tickFormat("")
        )
    //绘制格栅-y方向
    svg.append("g")
        .attr("class", "grid")
        .call(make_y_axis()
            .tickSize(-width, 0, 0)
            .tickFormat("")
        )

    上面的代码中需要说明的是.tickSize()方法,我们在这里设置了他们的长度和起始位置,最后一个.tickFormat(“”)是为了让所有的tick都没有标注。最后的效果如下
    image

    下节我们将给图表进行填充!

  • 相关阅读:
    投票通过,PHP 8 确认引入 Union Types 2.0
    Laravel 菜鸟的晋级之路
    给公司写的composer包开发的规范
    Swoft 源码剖析
    听说PHP的生成器yield处理大量数据杠杠的
    读懂JWT的使用,你就会用PHP如何实现了
    python标准库及其它应用
    python常用算法题
    python迭代器实例
    python生成器实例
  • 原文地址:https://www.cnblogs.com/magic-xxj/p/9186085.html
Copyright © 2011-2022 走看看