d3.js标记自动定位不起作用

时间:2015-06-03 20:58:46

标签: javascript svg d3.js markers

我开始玩d3来绘制树形图,我遇到了路径标记上的自动定位问题。似乎路径标记根本没有旋转。

enter image description here

我的标记定义为:

defs.selectAll('marker')
                .data(nodes, function (d) { return d.id || (d.id = ++i); })
                .enter()
                .append('svg:marker')
                .attr('id', function (d) { return 'marker_' + d.name; })
                .attr('markerHeight', 6)
                .attr('markerWidth', 6)
                .attr('orient', 'auto')
                .attr('markerUnits', 'strokeWidth')
                .attr('refX', 3)
                .attr('refY', 3)
                .append('svg:path')
                .attr('d', 'M0,0 V6 L6,3 Z')
                .attr('fill', getNodeColor);

是否应该旋转这些标记以与引用它们的路径对齐?

编辑:

<svg style="width: 2000px; height: 600px;">
        <defs>
            <marker refX="3" refY="3" markerHeight="6" markerWidth="6" orient="auto" id="mymarker">
                <path d="M0,0 V6 L6,3 Z" style="fill: #FF0000;"></path>
            </marker>
        </defs>
        <path class="link"
              d="M1246.764705882353,15C1246.764705882353,63.142857142857146 277.05882352941165,63.142857142857146 277.05882352941165,111.28571428571429"
              style="marker-end:url(#mymarker);
                     stroke: rgb(31, 177, 230);
                     stroke-width: 1.5px;">
        </path>
    </svg>

以上是一个超简化的例子。浏览器中的结果是:

enter image description here

这是一个JSFiddle http://jsfiddle.net/mcottingham/LLud4kja/

1 个答案:

答案 0 :(得分:2)

删除标记,您会看到曲线的末端是垂直的,因此标记的方向符合预期。

<svg style="width: 2000px; height: 600px;">
        <path
              d="M1246.764705882353,15C1246.764705882353,63.142857142857146 277.05882352941165,63.142857142857146 277.05882352941165,111.28571428571429"
              style="fill: none;
                     stroke: rgb(31, 177, 230);
                     stroke-width: 1.5px;">
        </path>
    </svg>