如何在栏上设置自定义标签?

拉胡尔·德赛(Rahul Desai)

如下面的快照所示,如何在图表上设置YesNo标签?

在此处输入图片说明

D3代码:

var data = [
    {
        "episode": "Ep. 01",
        "yes": "60",
        "no": "40"
    },
    {
        "episode": "Ep. 02",
        "yes": "70",
        "no": "30"
    },
    {
        "episode": "Ep. 03",
        "yes": "50",
        "no": "50"
    },
    {
        "episode": "Ep. 04",
        "yes": "90",
        "no": "10"
    },
    {
        "episode": "Ep. 05",
        "yes": "30",
        "no": "70"
    },
    {
        "episode": "Ep. 06",
        "yes": "60",
        "no": "40"
    },
    {
        "episode": "Ep. 07",
        "yes": "70",
        "no": "30"
    },
    {
        "episode": "Ep. 08",
        "yes": "50",
        "no": "50"
    },
    {
        "episode": "Ep. 09",
        "yes": "90",
        "no": "10"
    },
    {
        "episode": "Ep. 10",
        "yes": "30",
        "no": "70"
    }
];

var margin = {top: 20, right: 100, bottom: 30, left: 40},
    width = 600 - margin.left - margin.right,
    height = 500 - margin.top - margin.bottom;

var x = d3.scale.ordinal()
.rangeRoundBands([0, width], .1);

var y = d3.scale.linear()
.rangeRound([height, 0]);

var color = d3.scale.ordinal()
.range(["#B4D92A", "#FF3332"]);

var xAxis = d3.svg.axis()
.scale(x)
.orient("bottom");

var yAxis = d3.svg.axis()
.scale(y)
.orient("left")
.tickFormat(d3.format(".0%"));

var svg = d3.select("body").append("svg")
.attr("width", width + margin.left + margin.right)
.attr("height", height + margin.top + margin.bottom)
.append("g")
.attr("transform", "translate(" + margin.left + "," + margin.top + ")");

//d3.csv("data.csv", function(error, data) {
color.domain(d3.keys(data[0]).filter(function(key) { return key !== "episode"; }));

data.forEach(function(d) {
    var y0 = 0;
    d.ages = color.domain().map(function(name) { return {name: name, y0: y0, y1: y0 += +d[name]}; });
    d.ages.forEach(function(d) { d.y0 /= y0; d.y1 /= y0; });
});

//data.sort(function(a, b) { return b.ages[0].y1 - a.ages[0].y1; });

x.domain(data.map(function(d) { return d.episode; }));

svg.append("g")
.attr("class", "x axis")
.attr("transform", "translate(0," + height + ")")
.call(xAxis);

svg.selectAll(".ellipse")
.data(data)
.enter()
.append("ellipse")
.attr("cx", function(d) { return x(d.episode) + 14; })
.attr("cy", function(d) { return y(0); })
.attr("rx", 18)
.attr("ry", 5)
.style("fill", "#728220");

var episode = svg.selectAll(".episode")
.data(data)
.enter().append("g")
.attr("class", "episode")
.attr("transform", function(d) { return "translate(" + x(d.episode) + ",0)"; });

episode.selectAll("rect")
.data(function(d) { return d.ages; })
.enter().append("rect")
.attr("width", x.rangeBand() - 15)
.attr("y", function(d) { return y(d.y1); })
.attr("height", function(d) { return y(d.y0) - y(d.y1); })
.style("fill", function(d) { return color(d.name); })
/*.attr("rx", 5)
.attr("ry", 5);*/

var legend = svg.select(".episode:last-child").selectAll(".legend")
.data(function(d) { return d.ages; })
.enter().append("g")
.attr("class", "legend")
.attr("transform", function(d) { return "translate(" + x.rangeBand() / 2 + "," + y((d.y0 + d.y1) / 2) + ")"; });

legend.append("line")
.attr("x2", 10);

legend.append("text")
.attr("x", 13)
.attr("dy", ".35em")
.text(function(d) { return d.name; });

//});

jsFiddle

未知用户

Fiddle

只需将legend变量更改label并使用selectAll。

将文本附加到所有堆积的条形图上。然后使用变换将文本标签旋转到-90。

希望这可以帮助。

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章

如何在工具栏android中的标题上设置自定义字体

如何在导航栏上添加自定义视图

iOS上的自定义可滚动标签栏

如何在Android的自定义标题栏中添加菜单和设置选项?

如何在Strongloop上为自定义远程方法设置自定义架构

如何在Swift 3.0中使用自定义UI创建标签栏

如何在操作栏上添加自定义按钮?

如何在Flutter中自定义标签栏宽度?

如何在mpandroidchart上设置自定义值axisLeft

如何在X轴上设置自定义标签?

Rails:如何在关联上设置自定义键

Android-如何在清单文件中为自定义工具栏设置标题?标签属性不起作用

如何自定义标签栏?扑

如何在Flutter上设置自定义高程颜色?

如何在WordDelimiter TokenFilter上设置自定义参数

Flutter如何制作自定义标签栏?

删除自定义标签栏上的行

在自定义标题栏上设置标题文本

如何在自定义tableviewcelll中设置标签的自定义字体?

如何在vb.net中的图表上的数据点上放置自定义标签?

如何在Android的动作栏中设置自定义视图?

如何在nvd3中的Y轴上设置自定义刻度和标签

如何自定义添加在情节提要上的标签栏项

如何在我的自定义导航控制器中隐藏标签栏?

如何使用标签栏自定义设计滚动视图?

如何在 CSS 上设置自定义“边距”

如何在 Codeigniter 上设置自定义错误消息

如何设置 RecyclerView 高度,以便自定义标签栏不会隐藏 Android 中的列表项

如何在颤振中自定义标签栏