Как сделать это лучше для макета d3.js вроде grid - PullRequest
0 голосов
/ 05 июля 2019

Я рисовал элементы со связями, но, к сожалению, организовать их не совсем удачно.Теперь у меня есть эта картина: enter image description here

Мне удалось организовать группы, но невозможно разместить взаимосвязанные элементы на одной линии.Но я хочу получить эту опцию:

enter image description here

Вот текущий код:

var json = {
    "nodes": [
        {"group": 1, "featureId": "pMeter_StartSetId", "trigger": "trigger1"},
        {"group": 1, "featureId": "pMeter_ResetSetId", "trigger": "trigger2"},
        {"group": 1, "featureId": "fS___startFSPopup", "trigger": "trigger3"},
        {"group": 1, "featureId": "reSpins_stRSPopup", "trigger": "trigger4"},
        {"group": 1, "featureId": "jackpotIndication", "trigger": "trigger5"},
        {"group": 1, "featureId": "jackpotShowPopup", "trigger": "trigger6"},
        {"group": 2, "animId": "jI_UpdateIndicators"},        
        {"group": 2, "animId": "jI_JackpotShowPopup" },
        {"group": 2, "animId": "progressiveMeter_UpdateIndicators"},
        {"group": 2, "animId": "progressiveMeter_ResetSetFunc"},
        {"group": 2, "animId": "startFreeSpinsPopup"},
        {"group": 2, "animId": "startRespinsPopup"}
    ],
    "links": [
        {"source": 0, "target":  5 },
        {"source": 2, "target":  7 },
        {"source": 4, "target":  9 },
        {"source": 6, "target":  11},
        {"source": 8, "target":  1 },
        {"source": 10, "target": 3 }
    ]
}

    var main_row = svg.selectAll("g")
        .data(json.nodes)
        .enter()
        .append('g')
        .attr("x", 50).attr("y", 50)
        .attr("width", 160)
        .attr("height", 80)
        .append("rect")
            .attr("x", 50).attr("y", 50)
            .attr("width", 16)
            .attr("height", 80)
            .style("fill","black");

    var simulation = d3.forceSimulation(json.nodes)
        .force("link", d3.forceLink(json.links).distance(300).strength(1))
        .force("center", d3.forceCenter().x(width / 2).y(height / 2)) 
        .force("charge", d3.forceManyBody().strength(1)) 
        .force("collide", d3.forceCollide().strength(.1).radius(32).iterations(1))
        .force("x", d3.forceX().strength(0.5).x( d => x(d.group) ))
        .force("yPosition", d3.forceY(d => d.r === 20 ? 100 : 300))
        .force("xPosition", d3.forceX(d => d.r === 20 ? 100 : 300))
        .force("y", d3.forceY().strength(0.1).y( height/2 ))
        .on("tick", ticked);

    function ticked() {
        link.attr("x1", d => d.source.x + dx)
            .attr("y1", d => d.source.y + dy)
            .attr("x2", d => d.target.x + dx)
            .attr("y2", d => d.target.y + dy);
        main_row.attr("transform", d => "translate(" + d.x + "," + d.y + ")" );

    }
...