javascript - 堆积 D3JS 气泡图

标签 javascript json d3.js circle-pack

嘿,我正在使用 D3JS 作为图表库,我真的很想利用气泡图中的超酷功能。上主D3JS chart站点下面的Bubble Chart用来比较两组数据:

enter image description here

Bubble Chart .

我想知道是否有人真的知道如何创建这样的气泡图,我正在努力通过使用大小变量来让它工作。

我真的很想比较两组数据,例如:

主机名 (45,955,158) VS 活跃站点 (21,335,629)

我正在使用的代码如下,我使用 JSON 来检索我的数据,我是 js 的主要新手,甚至更多,所以这个 jQuery 库非常感谢任何帮助。

index.html

<div class="four columns browserstats2003">
            <h3>Browser Stats 2003</h3>

        </div>        
    <div class="four columns mobilephonestats">
       <h3>Smartphone Sales 2003</h3>
       <p>The first smartphone had not been released in 2003.</p>
               <div id=""></div>


    </div>

手机.json

{
 "name": "flare",
 "children": [
  {
   "name": "analytics",
   "children": [
    {
     "name": "cluster",
     "children": [
      {"name": "Smartphone Sales", "size": 11111},
  {"name": "Smartphone Salesa", "size": 2111}
     ]
    }
   ]
  }
 ]
}

js/js.js //JavaScript 文档

$(document).ready(function () {

        //  2003 bubble chart
            var diameter = 360,
                format = d3.format(",d"),
                color = d3.scale.category20c();

            var bubble = d3.layout.pack()
                .sort(null)
                .size([diameter, diameter])
                .padding(1.5);

            var svg = d3.select(".mobilephonestats").append("svg")
                .attr("width", diameter)
                .attr("height", diameter)
                .attr("class", "bubble");

            d3.json("mobile.json", function(error, root) {
              var node = svg.selectAll(".node")
                  .data(bubble.nodes(classes(root))
                  .filter(function(d) { return !d.children; }))
                .enter().append("g")
                  .attr("class", "node")
                  .attr("transform", function(d) { return "translate(" + d.x + "," + d.y + ")"; });

              node.append("title")
                  .text(function(d) { return d.className + ": " + format(d.value); });

              node.append("circle")
                  .attr("r", function(d) { return d.r; })
                  .style("fill", function(d) { return color(d.packageName); });

              node.append("text")
                  .attr("dy", ".3em")
                  .style("text-anchor", "middle")
                  .text(function(d) { return d.className.substring(0, d.r / 3); });
            });

            // Returns a flattened hierarchy containing all leaf nodes under the root.
            function classes(root) {
              var classes = [];

              function recurse(name, node) {
                if (node.children) node.children.forEach(function(child) { recurse(node.name, child); });
                else classes.push({packageName: name, className: node.name, value: node.size});
              }

              recurse(null, root);
              return {children: classes};
            }

            d3.select(self.frameElement).style("height", diameter + "px");

// end bubble year 

        });

最佳答案

example you provided ,他肯定使用了强制布局,这比您使用的气泡图要复杂一些。您必须考虑碰撞和动画等因素。

为什么不看看 the JavaScript he used生成它。

Jim Vallandingham 在 Bubble Clouds 上撰写了详尽的教程,这应该可以帮助您入门。

要在圆圈中间创建拆分作为进行某种形式的数据比较的一种方式,“剪辑路径”是前进的方向:

  • 附加两个圆圈,每个圆圈代表一个数据集。
  • 附加两个剪辑路径,每个数据集一个
  • 向每个剪辑路径附加一个矩形。
  • 设置矩形的 x 属性和宽度,它定义了中间分割的位置。这必须是数据的函数。
  • 裁剪矩形和圆形

代码如下:

var nodeEnter = node.enter().append("a")
      .attr("class", "g-node")
      .call(force.drag);

  var democratEnter = nodeEnter.append("g")
      .attr("class", "g-democrat");

  democratEnter.append("clipPath") // clip-path to crop the rectangle
      .attr("id", function(d) { return "g-clip-democrat-" + d.id; })
    .append("rect");

  democratEnter.append("circle");

  var republicanEnter = nodeEnter.append("g")
      .attr("class", "g-republican");

  republicanEnter.append("clipPath") // Clip-path to crop the rectangle
     .attr("id", function(d) { return "g-clip-republican-" + d.id; })
     .append("rect");

  republicanEnter.append("circle");

  node.selectAll("rect")
      .attr("y", function(d) { return -d.r - clipPadding; })
      .attr("height", function(d) { return 2 * d.r + 2 * clipPadding; });

  // Defining the x-attr and width of the rectangle, which effectively splits the circle
  node.select(".g-democrat rect")
      .attr("x", function(d) { return -d.r - clipPadding; }) 
      .attr("width", function(d) { return 2 * d.r * d.k + clipPadding; });

  node.select(".g-republican rect")
      .attr("x", function(d) { return -d.r + 2 * d.r * d.k; })
      .attr("width", function(d) { return 2 * d.r; });

  // Setting the clip-path to crop the circles
  node.select(".g-democrat circle")
      .attr("clip-path", function(d) { return d.k < 1 ? "url(#g-clip-democrat-" + d.id + ")" : null; });

  node.select(".g-republican circle")
      .attr("clip-path", function(d) { return d.k > 0 ? "url(#g-clip-republican-" + d.id + ")" : null; });

这应该生成如下内容:

<g class="g-democrat">
    <clipPath id="g-clip-democrat-43">
        <rect y="-63.36487389363757" height="126.72974778727514" x="-63.36487389363757" width="59.449375597303515">
        </rect>
    </clipPath>
    <circle clip-path="url(#g-clip-democrat-43)" r="59.36487389363757">
</circle></g>
<g class="g-republican">
    <clipPath id="g-clip-republican-43">
        <rect y="-63.36487389363757" height="126.72974778727514" x="-3.915498296334057" width="118.72974778727514">
        </rect>
    </clipPath>
    <circle clip-path="url(#g-clip-republican-43)" r="59.36487389363757">
</circle></g>

关于javascript - 堆积 D3JS 气泡图,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20500955/

相关文章:

C# 从嵌套数组中提取 JSON

javascript - 如何在嵌套对象数组中查找范围?

javascript - 在 D3 中创建圆形图表?

javascript - 将 MathJax 放入 d3-tips 的 header 要求

javascript - 使用淡入和淡出动画 block 中的文本变化

javascript - 当div底部到达顶部时JQuery添加类

javascript - 鼠标悬停多次时 mouseenter 冒泡

javascript - 如何为 jvectormap jquery 插件生成新 map ?

json - 使用 jq 对 JSON 中特定字段的值求平均值

javascript - $.ajax() 不提供从静态 json 文件获取 json 的请求