0
現在、私は衛星の視覚化に取り組んでいます。私はD3JSに取り組んでいます。衛星が窓の外に出ると、反対側に戻り、その道を続けます。各衛星は円で と表され、その軌跡はその近地点、アポジおよびピリオドによって計算されます。 私はJSFiddleを作成します。 https://jsfiddle.net/xrhets3d/ `D3JS - ウィンドウの外側にある場合、左に要素を戻します。
var svg = d3.select('#canvas').append('svg')
.attr('width', window.innerWidth)
.attr('height', window.innerHeight * 3);
var center = {
x: window.innerWidth/2,
y: window.innerHeight/2
};
d3.json('https://api.myjson.com/bins/wf2sj', function(error, json) {
if(error) console.error(error);
var scaleX = d3.scaleLinear()
.domain([-180, 180])
.range([0, window.innerWidth]);
var scaleY = d3.scaleLinear()
.domain([-100, 62000])
.range([0, window.innerHeight * 3]);
var scaleSize = d3.scaleLinear()
.domain([1, 8000])
.range([3, 30]);
var colors = {
'Government': 'rgba(52, 152, 219, 0.6)',
'Commercial': 'rgba(155, 89, 182, 0.6)',
'Military': 'rgba(46, 204, 113, 0.6)',
'Civil': 'rgba(231, 76, 60, 0.6)',
'Military/Government': 'rgba(241, 196, 15, 0.6)',
'Government/Commercial': 'rgba(26, 188, 156, 0.6)',
'Military/Commercial': 'rgba(52, 73, 94, 0.6)',
'Government/Civil': 'rgba(149, 165, 166, 0.6)',
};
var circles = svg.selectAll('circle')
.data(json)
.enter()
.append('circle')
.attr('cx', function(d) { return scaleX(d.longitude_geo) })
.attr('cy', function(d) { return scaleY(d.perigee) })
.attr('r', function(d) { return d.launch_mass != "" && d.launch_mass != undefined ? scaleSize(d.launch_mass) : 3 })
.style('fill', function(d) { return colors[d.users] });
circles.transition()
.each(animate);
function animate(d) {
var circle = d3.select(this);
if((circle.attr('cx') - circle.attr('r')) > window.innerWidth) {
circle.attr('cx', 0);
}
circle = circle.transition()
.duration(d.period * 50)
.attr('cy', scaleY(d.apogee))
.attr('cx', function(d) { return parseFloat(circle.attr('cx')) + window.innerWidth/2 })
.transition()
.duration(d.period * 50)
.attr('cx', function(d) { return parseFloat(circle.attr('cx')) + window.innerWidth/2 })
.attr('cy', scaleY(d.perigee))
.on('end', animate);
}
var earth = svg.append('circle')
.attr('cx', center.x)
.attr('cy', - center.y/2)
.attr('r', 20)
.style('fill', '#0F0');
});
`
誰かがアイデアを持っていますか?ありがとう