并非所有坐标都使用平行坐标绘制(d3)

时间:2014-07-18 14:03:51

标签: javascript d3.js data-visualization parallel-coordinates

我正在尝试使用parallel-coordinates库来绘制一些数据。我拥有的数据点的坐标都是 strings 。例如,考虑以下CSV表:

ID,TYPE,USER,OS,FooBar,Country
a1,X,1S,iOS,foo,US
a2,Y,1S,Android,bar,US

这是两个数据点,每个数据点有六个属性。我拥有的html MWE如下:

<!doctype html>

<link rel="stylesheet" type="text/css" href="d3.parcoords.css">
<script src="./d3.min.js"></script>
<script src="./d3.parcoords.js"></script>
<script src="./divgrid.js"></script>


<style>
/* data table styles */
#grid { height: 198px; }
.row, .header { clear: left; font-size: 12px; line-height: 18px; height: 18px; }
.row:nth-child(odd) { background: rgba(0,0,0,0.05); }
.header { font-weight: bold; }
.cell { float: left; overflow: hidden; white-space: nowrap; width: 100px; height: 18px; }
.col-0 { width: 180px; }
.col-1 { width: 80px; }
.col-2 { width: 180px; }
.col-3 { width: 150px;}
</style>

<title>Minimal Working Example</title>

<body>
<div id="visual" class="parcoords" style="width:1280px;height:350px"></div>
<p>Lines from the data</p>
<div id="grid"></div>
</body>


<!-- Setting and inserting the visualization and the corresponding table -->
<script>
 var parcoords = d3.parcoords()("#visual").color("steelblue");

 /*
 Load the data and visualize it
  */
 d3.csv('first-100.csv',function(data) {
   parcoords.data(data)
        .tickFormat(function(d) {return'';})
        .render().brushable().reorderable();

   var grid = d3.divgrid();
   d3.select("#grid")
     .datum(data.slice(0,30))
     .call(grid)
     .selectAll(".row")
     .on({
     "mouseover": function(d) { parcoords.highlight([d]) },
     "mouseout": parcoords.unhighlight
     });

   // update data table on brush event
   parcoords.on("brush", function(d) {
     d3.select("#grid")
       .datum(d.slice(0,30))
       .call(grid)
       .selectAll(".row")
       .on({
       "mouseover": function(d) { parcoords.highlight([d]) },
       "mouseout": parcoords.unhighlight
     });
   });
 });
</script>

不幸的是,正如你在屏幕截图中看到的那样,这只绘制了四(4)个坐标...我相信这个问题在某种程度上与所有坐标都是字符串的事实有关,但我不确定。 / p>

enter image description here

有任何建议如何更正?

1 个答案:

答案 0 :(得分:2)

问题在于,平行坐标库过滤出数据集中具有少于两个唯一值的维度,这是“用户”的情况。和国家&#39;数据中的列。

相关的源代码是HERE。当前版本的d3.parcoords.js中的第168行,它起源于autoscale.js目录中的src文件。以下是链接中断时的代码:

// hack to remove ordinal dimensions with many values
pc.dimensions(pc.dimensions().filter(function(p,i) {
  var uniques = yscale[p].domain().length;
  if (__.types[p] == "string" && (uniques > 60 || uniques < 2)) {
    return false;
  }
  return true;
}));

在您的情况下,如果您想强制渲染有问题的两列,一种解决方案就是在d3.parcoords.js文件中简单地注释掉这个块。

以下是我的示例的PLUNK,其中我已经注释掉了上面的代码块。现在输出正如您所期望的那样。希望有所帮助。