对于D3过渡,获取“错误,为时已晚”

use*_*erx 1 javascript d3.js pie-chart

我正在尝试在饼图的onClick事件中进行三个转换。第一个转换有效,但是第二个和第三个转换失败。我从Mike Bostocks的一个类似问题的评论中了解到,“ 这意味着您正在尝试修改已经开始的过渡,或者从已经结束的过渡中获得过渡。请阅读有关过渡生命周期的API参考部分。

我似乎仍然无法理解发生这种情况的原因。以下是相关代码:

self.primaryLabelText = self.arc.append("text")
    .on("click", function (d: any) {
        console.log("About to send::::" + getStudyLabel(d.index));
        self.selectedIndustryTypeService.sendMessage(getStudyLabel(d.index));
        self.showDialog();

        // The amount we need to rotate:
        var rotate = 180-(d.startAngle + d.endAngle)/2 / Math.PI * 180;

        // Transition the pie chart
        g.transition()
            .attr("transform",  "translate(" + self.width / 2 + "," + self.height / 2 + ") rotate(" + rotate + ")")
            .duration(1000);

        // ?ransition the labels:
        self.primaryLabelText.transition()
            .attr("transform", function(dd: any) {
            return "translate(" + label.centroid(dd) + ") rotate(" + (-rotate) + ")"; })
            .duration(1000);

        self.secondaryLabelText.transition()
            .attr("transform", function(dd: any) {
            return "translate(" + label.centroid(dd) + ") rotate(" + (-rotate) + ")"; })
            .duration(1000);

    })
    .transition()
    .duration(750)
    .attr("transform", function (d: any) {
        return "translate(" + label.centroid(d) + ")";
    })
    .attr("dy", "-0.75em")
    .attr("font-family", "sans-serif")
    .attr("font-size", "15px")
    .attr("text-anchor", "middle")
    .attr("class", "sponsor-pie-widget-label")
    .text(function (d: any) {
        if (d.endAngle - d.startAngle < 0.3) {
            return "";
        } else {
            return getStudyLabel(d.index);
        }
    });
Run Code Online (Sandbox Code Playgroud)

这是什么问题?

use*_*erx 5

问题是我尝试进行过渡的primaryLabel和secondaryLabel没有正确分配。我有以下作业:

self.primaryLabelText = self.arc.append("text")
    .on("click", function (d: any) {
        self.rotateChart(d);
    }).transition()
    .duration(750)
    .attr("transform", function (d: any) {
        return "translate(" + self.label.centroid(d) + ")";
    })
    .attr("dy", "-0.75em")
    .attr("font-family", "sans-serif")
    .attr("font-size", "15px")
    .attr("text-anchor", "middle")
    .attr("class", "sponsor-pie-widget-label")
    .text(function (d: any) {
        if (d.endAngle - d.startAngle < 0.3) {
            return "";
        } else {
            return getStudyLabel(d.index);
        }
    });
Run Code Online (Sandbox Code Playgroud)

结果,变量包含对过渡的引用,而不是标签本身,因为当您链接过渡时,变量将变为过渡类型对象。所以我将其更改为:

self.primaryLabelText = self.arc.append("text")
    .on("click", function (d: any) {
        self.rotateChart(d);
    });

self.primaryLabelText.transition()
    .duration(750)
    .attr("transform", function (d: any) {
        return "translate(" + self.label.centroid(d) + ")";
    })
    .attr("dy", "-0.75em")
    .attr("font-family", "sans-serif")
    .attr("font-size", "15px")
    .attr("text-anchor", "middle")
    .attr("class", "sponsor-pie-widget-label")
    .text(function (d: any) {
        if (d.endAngle - d.startAngle < 0.3) {
            return "";
        } else {
            return getStudyLabel(d.index);
        }
    });
Run Code Online (Sandbox Code Playgroud)

现在一切正常!:)