d3里的比例尺

时间:2023-03-08 20:08:18
    // d3中的比例尺也有定义域和值域,分别是domain和range,开发者需要指定domain和range的范围,如此即可以得到一个计算关系;
// 线性比例尺:能将一个连续的区间映射到另一区间,要解决柱形图宽度的问题,就需要线性比例尺;
// 如:
var dataset = [1.2, 2.3, 0.9, 1.5, 3.3];
var min = d3.min(dataset)
var max = d3.max(dataset)
var linear = d3.scale.linear()
.domain([min,max])
.range(0,300)
linear(0.9) //0
linear(2.3); //返回 175
linear(3.3); //返回 300
// 序数比例尺:定义域和值域不一定是连续的
var index = [0, 1, 2, 3, 4];
var color = ["red", "blue", "green", "yellow", "black"];
// 我们希望 0 对应颜色 red,1 对应 blue,依次类推。
var ordinal = d3.scale.ordinal()
.domain(index)
.range(color);
ordinal(0); //返回 red
ordinal(2); //返回 green
ordinal(4); //返回 black