2016-12-16 26 views
1

「タイムライン」を示すスニペットがあります。ライン(SVGグループ)は、マウスの動きに応じて左右に移動する必要があります。コンソールには作業するデータが表示されますが、移動方法はわかりませんg#node-line。今のコードSVGグループを左右に移動

svg#svg 
    g#node-line 
    line#line 
    g#nodes 
     line.node 
     line.node 
     line.node 
     line.node 
     ... 

var ns = "http://www.w3.org/2000/svg"; 
 
    var svg = document.createElementNS(ns, "svg"); 
 
    svg.setAttribute("id", "svg"); 
 
    svg.setAttribute("width", "800px"); 
 
    svg.setAttribute("height", "450px"); 
 

 
    var line = document.createElementNS(ns, "line"); 
 
    line.setAttribute("id", "line"); 
 
    line.setAttribute("stroke", "white"); 
 
    line.setAttribute("stroke-width", "10px"); 
 
    line.setAttribute("x1", "0"); 
 
    line.setAttribute("y1", 225); 
 
    line.setAttribute("x2", "800"); 
 
    line.setAttribute("y2", 225); 
 

 
    var nodes = document.createElementNS(ns, "g"); 
 
    nodes.setAttribute("id", "nodes"); 
 

 
    for (var i = 0; i < 100; i++) { 
 

 
    var node = document.createElementNS(ns, "line"); 
 
    node.setAttribute("class", "node"); 
 
    node.setAttribute("stroke", "white"); 
 
    node.setAttribute("stroke-width", "2px"); 
 
    node.setAttribute("x1", i * 40); 
 
    node.setAttribute("y1", 225); 
 
    node.setAttribute("x2", i * 40); 
 
    node.setAttribute("y2", 225 - 12); 
 

 
    nodes.appendChild(node); 
 

 
    } 
 

 
    var nodeLine = document.createElementNS(ns, "g"); 
 
    nodeLine.setAttribute("id", "node-line"); 
 

 
    nodeLine.appendChild(line); 
 
    nodeLine.appendChild(nodes); 
 

 
    svg.appendChild(nodeLine); 
 

 
    var container = document.getElementById('container'); 
 
    container.appendChild(svg); 
 

 
    document.getElementById('svg').addEventListener('mousemove', function(e) { 
 
    var boundaries = svg.getBoundingClientRect() 
 
    var offset = e.clientX - boundaries.left; 
 
    if (offset < 400) { 
 
     var distanceFromCenter = 400 - offset; 
 
     console.log('left: ' + distanceFromCenter); 
 
    } 
 
    if (offset > 400) { 
 
     var distanceFromCenter = offset - 400; 
 
     console.log('right: ' + distanceFromCenter); 
 
    } 
 
    });
html, body { 
 
    height: 100%; 
 
} 
 
body { 
 
    display: flex; 
 
    flex-direction: column; 
 
    justify-content: center; 
 
    align-items: center; 
 
    overflow: hidden; 
 
} 
 
#container { 
 
    background-color: orange; 
 
}
<div id="container"></div>
はどうもありがとうございまし

これは大まかな構造です。

答えて

1

グループのtransform属性を設定します。

transform="translate(30,0)"は30単位を右に移動し、transform="translate(-30,0)"は30単位を左に移動します。

+0

translateX属性のようなものがありますか?!?! – Timo

+0

はい。できます。どうやって動きを滑らかにすることができますか? – Timo

+0

大丈夫私はそれをしました:D中央からマウス位置までの距離を使用しています: 'distanceFromCenter' ...:Dありがとう! – Timo

関連する問題