10

たとえば、cssまたはその他の(js?)マーカーアニメーションで行われた脈動ドットのように、gps座標(緯度、経度)によってカスタムhtmlオブジェクトをワールドマップに追加したい

<style>

#circle {
    background: red;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;

}

.gps_ring {
    border: 3px solid red;
    -webkit-border-radius: 30px;
    height: 18px;
    width: 18px;

    left:20px;
    top:214px;
    -webkit-animation: pulsate 1s ease-out;
    -webkit-animation-iteration-count: infinite; 
    opacity: 0.0
}
@-webkit-keyframes pulsate {
    0% {-webkit-transform: scale(0.1, 0.1); opacity: 0.0;}
    50% {opacity: 1.0;}
    100% {-webkit-transform: scale(1.2, 1.2); opacity: 0.0;}
}
</style>

<div id="state" class="grid_4 alpha">
    <div class="gps_ring"></div>

</div>
4

1 に答える 1

2

投影から x、y 座標を取得できます。

var projection = d3.geo.mercator()
            .center([0, 5 ])
            .scale(150);

projection([long, lat]);

アニメーションの場合、d3 トランジションの例または CSSのいずれかを使用できます。

私はあなたのためにブロックを作成しました: http://bl.ocks.org/ckothari/32149f15261b9c5c7a56c40f7f6b353d

編集 申し訳ありませんが、あなたの質問がhttp://datamaps.github.io/の使用に関するものであることに気付きました。topojson を使用できるかどうか教えてください。そうしないと、回答を削除します。

EDIT-2 国に色を付けるには:

d3.tsv('data.csv', function(data){
            g.selectAll('path')
                    .filter(function(d){
                        return data.find(function(d1){
                            return d1.iso == d.properties.iso_a2;
                        })
                    })
                    .attr('class', 'selected');
   //...
 })

EDIT-3 トランジション連鎖

http://bl.ocks.org/mbostock/1125997も参照してください。

于 2016-08-16T11:41:58.497 に答える