作成パターンからインスピレーションを受け、この.style("fill", "url(#grump_avatar" + i + ")");
data.forEach(function(d, i) {
defs.append("svg:pattern")
.attr("id", "grump_avatar" + i)
.attr("width", config.avatar_size)
.attr("height", config.avatar_size)
.attr("patternUnits", "userSpaceOnUse")
.append("svg:image")
.attr("xlink:href", d.img)
.attr("width", config.avatar_size)
.attr("height", config.avatar_size)
.attr("x", 0)
.attr("y", 0);
var circle = svg.append("circle")
.attr("transform", "translate(" + d.posx + "," + d.posy + ")")
.attr("cx", config.avatar_size/2)
.attr("cy", config.avatar_size/2)
.attr("r", config.avatar_size/2)
.style("fill", "#fff")
.style("fill", "url(#grump_avatar" + i + ")");
})
作業コードhere
ようにDEFのIDを渡しますパフォーマンスの問題。だから、それを避けるために、画像上にクリップパスを使うことができます。このよう
:私たちが望むよう
var config = {
"avatar_size": 100
}
var body = d3.select("body");
var svg = body.append("svg")
.attr("width", 500)
.attr("height", 500);
var defs = svg.append('svg:defs');
data = [{
posx: 100,
posy: 100,
img: "https://cdn4.iconfinder.com/data/icons/seo-and-data/500/pencil-gear-128.png",
}, {
posx: 200,
posy: 200,
img: "https://cdn4.iconfinder.com/data/icons/seo-and-data/500/gear-clock-128.png"
}, {
posx: 300,
posy: 300,
img: "https://cdn4.iconfinder.com/data/icons/seo-and-data/500/magnifier-data-128.png"
}];
svg .append('clipPath')
.attr('id','clipObj')
.append('circle')
.attr('cx',config.avatar_size/2)
.attr('cy',config.avatar_size/2)
.attr('r',config.avatar_size/2);
data.forEach(function(d,i){
svg.append('image')
.attr('xlink:href',d.img)
.attr('width',config.avatar_size)
.attr('height',config.avatar_size)
.attr('transform','translate('+parseInt(d.posx+config.avatar_size/2)+','+parseInt(d.posy+config.avatar_size/2)+')')
.attr('clip-path','url(#clipObj)');
});
はまた、我々は簡単に新しいものとクリッピングエリアを置き換えることができます。 コードペンのリンクです:http://codepen.io/anon/pen/VagxKp?editors=0010