D3.js を使用してデータをマップするプログラムで、Opentip.js の機能セットを利用しようとしています。
新しい Opentip オブジェクトを、マップを構成する名前のない要素に関連付ける方法がわかりません。
これは、私が取っているアプローチを示すコードの抜粋です。
<script type="text/javascript">
var dataset = [[4,2,'Bob'], [5,7,'Sally'], [2,2,'Marvin']];
var width = 38;
var height = 38;
var margin = 20;
function giveX(d) { return d[0] * width + margin }
function giveY(d) { return d[1] * height + margin }
var mapdiv = d3.select("#map")
.append("svg")
.attr("height", 680)
.attr("width", 980)
.style('border', '1px solid black')
var pips = mapdiv.selectAll("circle")
.data(dataset)
.enter().append("circle")
.style("fill", "red")
.style("stroke", "black")
.attr("cx", function(d) {return giveX(d)})
.attr("cy", function(d) {return giveY(d)})
.attr("r", width/2)
</script>
Opentip オブジェクトのコンストラクターは要素識別子を指定するだけでよいのですが、動的に作成された「円」要素を参照する方法がよくわかりません。
selectAll() 呼び出しにコードを追加しようとしましたが、うまくいきません。