d3 wordcloud fontsize不适应

时间:2016-05-10 11:44:34

标签: d3.js font-size word-cloud

我的d3.wordcloud文档的fontsize不受wordlist.tsv文件中指定的计数影响。但是根据我对代码的理解应该是。

<!DOCTYPE html>
<html>
<script src="http://d3js.org/d3.v3.min.js"></script>
<script src="build/d3.layout.cloud.js"></script>
<head>
    <title>Word Cloud Example</title>
</head>

<body>
</body>

<script>
 var width = 500; heigth = 500;



var wordscale = d3.scale.linear().range([10,60]);
 var fill = d3.scale.category20();
        d3.tsv("wordlist.tsv",function(data){
        var wordlist2 = data
                .filter(function(d){ return +d.count > 10;})
                .map(function(d){ return{text: d.word +" ("+ d.count+")", fsize: +d.count};})
                .sort(function(a,b){return d3.descending(a.fsize,b.fsize);})
                .slice(0,100);



        wordscale.domain([0,d3.max(wordlist2, function(d) {return d.fsize;})]);
            d3.layout.cloud()
                .size([width, heigth]) 
                .padding(1)
                .words(wordlist2) 
                .rotate(0)
                .fontSize(function(d) { return wordscale(+d.fsize); })
                .on("end", draw) //afblijven
                .start(); //start algoritme
});


function draw(words) {
   d3.select("body")
          .append("svg")
                .attr("width", width)
                .attr("height", heigth)
                .attr("class", "wordcloud")
              .append("g")
                .attr("transform", "translate("+width/2+","+heigth/2+")")
                .selectAll("text")
                .data(words)
              .enter().append("text")
                .style("font-size", function(d) { d.fsize + "px"; })
                .style("fill", function(d, i) { return fill(i); })
                .attr("transform", function(d) {return "translate(" + [d.x, d.y] + ")rotate(" + d.rotate + ")";})
                .text(function(d) { return d.text; });
    }

</script>
</html>

从我理解的以下代码行:

.fontSize(function(d) { return wordscale(+d.fsize); })

应该将代码调整到代码中前面定义的比例,但是它没有,并且所有单词的大小都相同。尽管.tsv文件中的每个单词的count参数都不同

任何建议?

1 个答案:

答案 0 :(得分:1)

解决了,我忘记了以下代码行中的return语句

.style("font-size", function(d) { d.fsize + "px"; })

这应该是:

.style("font-size", function(d) {return d.fsize + "px"; })