- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
嗨,我有一个非常基本的 D3.js 图例
svg.append('g')
.classed('legend-color', true)
.attr('text-anchor', 'start')
.attr('transform', 'translate(20,30)')
.style('font-size', '11px')
.style('fill', 'rgb(0,0,0)')
.call(legendOrdinal);
我想将它分成两列,一半一半,否则底部的图例单元格会干扰我的节点。
所以基本上它会从
Category A
Category B
Category C
Category D
Category E
Category F
Category G
Category H
到
Category A Category E
Category B Category F
Category C Category G
Category D Category H
最佳答案
使用单列图例,您可以使用以下内容轻松定位每个条目:
.attr("transform", function(d,i) { "translate(10," + (i * 20) +")" });
要定位多列(同时定位多行),我们需要调整变换的 x 值并根据列调整 y 值。最直接的方法可能是对 x 和 y 使用以下内容:
x = Math.floor(i/c) * w + tx
y = i % c * h + ty
其中 c
是列数,w
是每个图例条目的宽度,tx
是所有图例条目的基数水平翻译,h
是图例条目的高度,ty
是基础量,所有图例条目都垂直翻译。
您可以通过以下函数实现上述功能:
function position(d,i) {
var c = 2; // number of columns
var h = 20; // legend entry height
var w = 150; // legend entry width (so we can position the next column)
var tx = 10; // tx/ty are essentially margin values
var ty = 10;
var x = i % c * w + tx;
var y = Math.floor(i / c) * h + ty;
return "translate(" + x + "," + y + ")";
}
var entries = "ABCDEFGHIJ".split("");
var color = d3.schemeCategory10;
var n = Math.round(entries.length/2);
var w = 100;
var h = 20;
var svg = d3.select("body")
.append("svg")
.attr("width", 400)
.attr("height",200);
var legend = svg.selectAll("g")
.data(entries)
.enter()
.append("g")
.attr("transform", position)
legend.append("text")
.attr("x", 18)
.attr("y", 12)
.text(function(d) { return "Category " + d; });
legend.append("rect")
.attr("width",10)
.attr("height",10)
.attr("fill",function(d,i) { return color[i]; })
function position(d,i) {
var c = 2; // number of columns
var h = 20; // height of each entry
var w = 150; // width of each entry (so you can position the next column)
var tx = 10; // tx/ty are essentially margin values
var ty = 10;
var x = i % c * w + tx;
var y = Math.floor(i / c) * h + ty;
return "translate(" + x + "," + y + ")";
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/d3/4.10.0/d3.min.js"></script>
或者,您可以通过压缩来缩短它:
var entries = "ABCDEFGHIJ".split("");
var color = d3.schemeCategory10;
var svg = d3.select("body")
.append("svg")
.attr("width", 400)
.attr("height",200);
var legend = svg.selectAll("g")
.data(entries)
.enter()
.append("g")
.attr("transform", function(d,i) {
return "translate(" + (i % 2 * 150 + 10) + "," + (Math.floor(i / 2) * 20 + 10) + ")";
})
legend.append("text")
.attr("x", 18)
.attr("y", 12)
.text(function(d) { return "Category " + d; });
legend.append("rect")
.attr("width",10)
.attr("height",10)
.attr("fill",function(d,i) { return color[i]; })
<script src="https://cdnjs.cloudflare.com/ajax/libs/d3/4.10.0/d3.min.js"></script>
如果您希望每一列中的条目是连续的,而不是每一行的条目,我们可以稍微修改一下以指定行数(由您想要的列数和图例数决定)您拥有的元素:Math.ceil(numberEntries/numberColumns)
。这可能看起来像:
var entries = "ABCDEFGHIJ".split("");
var color = d3.schemeCategory10;
var n = Math.round(entries.length/2);
var w = 100;
var h = 20;
var svg = d3.select("body")
.append("svg")
.attr("width", 400)
.attr("height",200);
var legend = svg.selectAll("g")
.data(entries)
.enter()
.append("g")
.attr("transform", position)
legend.append("text")
.attr("x", 18)
.attr("y", 12)
.text(function(d) { return "Category " + d; });
legend.append("rect")
.attr("width",10)
.attr("height",10)
.attr("fill",function(d,i) { return color[i]; })
function position(d,i) {
var c = 3
var r = Math.ceil(entries.length / c);
var h = 20; // height of each entry
var w = 100; // width of each entry (so you can position the next column)
var tx = 10; // tx/ty are essentially margin values
var ty = 10;
var x = Math.floor(i / r) * w + tx;
var y = i % r * h + ty;
return "translate(" + x + "," + y + ")";
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/d3/4.10.0/d3.min.js"></script>
此方法可能导致最后一列只有一个条目,而上面的第一种方法可能导致一行只有一个条目。根据情况,一个或另一个可能更可取
关于javascript - 在两列上传播 D3.js 图例,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51520596/
我在 visual studio 中使用它,但编译器声称 h1 不能嵌套在 legend 元素中,但浏览器无论如何都可以呈现它,所以我很困惑这是有效的还是不是? Caption
Matplotlib 中的图例是帮助观察者理解图像数据的重要工具。 图例通常包含在图像中,用于解释不同的颜色、形状、标签和其他元素. 1. 主要参数 当不设置图例的参数时,默认的图例是这样的.
mongoDB分页的两种方法 mongoDB的分页查询是通过limit(),skip(),sort()这三个函数组合进行分页查询的 下面这个是我的测试数据 第一种方法 查询第一页的数据:db.te
我的 grafana 仪表板图例中有这些名称: stats.gauges.all.cloudwatch.communicationapi.dynamodb.ca_communicationapi_re
鉴于以下情况: import pandas as pd import matplotlib.pyplot as plt d=pd.DataFrame({'category':['a','a','a',
我收到此错误,请问出了什么问题? plt.legend(handles=[d1, d2]) File "/usr/lib/python3/dist-packages/matplotlib/pypl
这个问题已经有答案了: python matplotlib: label in histogram (1 个回答) 已关闭 5 年前。 我无法向使用 matplotlib.pyplot 创建的直方图添
我想更改我的图例,我必须删除分页并将所有标题放在一两行中。我想更改图标。 现在是这个样子 我想要这样的东西 我输入了 scrollArrows: 'none' 但它不起作用。这是我在 Controll
我正在创建一个文件来读取一定数量的 .wav 文件,每个文件对应一个音符。我正在对它们中的每一个执行 FFT,并将它们全部绘制在同一个图形上。但是,我在正确打印图例时遇到了问题,它将我想要使用的名称分
我正在 ggplot 中处理多个 sf 几何图形,并希望以点、线和正方形(对于多边形)的形式显示图例。然而,geom_sf图例结合了我的几何特征(即结合线和点)如下所示: library(ggplot
我想要 geom_text()标签根据变量采用字体系列。 根据 ggplot2 docs 上的示例(向下滚动到底部),我已经这样做了(与 ggplot 文档示例中的相同): library(ggplo
我正在绘制一个 geom_tile 图,其中每个点都有一个特定的 p-value。 图的绘制方式很好,p-value 限制在图例上。 我想添加到这个图例的是具有这个 p-value 的数据点的数量。
我有以下 data.frame : my.df = data.frame(mean = c(0.045729661,0.030416531,0.043202944,0.025600973,0.0405
我正在绘图中打印 Case-Shiller 索引: structure(list(Date = structure(c(10957, 11048, 11139, 11231, 11323, 1141
我想绘制一个包含 4 个不同值( 1 )的栅格,并带有描述类别的分类文本图例,例如 2但有彩盒: 我试过使用图例,例如: legend( 1,-20,legend = c("land","ocean/
我在 R 中用 ggplot2 制作了这个图 由以下代码绘制: ggplot(mtcars) + geom_smooth(fill='grey', alpha=0.3, span=0.1, aes
我有来自两个不同数据框的数据。我正在尝试为每个数据框创建图例。我知道我可以组合数据框并进行操作,但是由于我的数据源,从两个不同的数据框进行绘图最有意义。 请在下面找到简化的示例。我已经接近了,但传说中
我将 highchart 的图形保存为 svg。 var chart = $('#graphicName').highcharts(); EXPORT_WIDTH = 1000; render_wid
我想将自定义符号设置为图例项。目前我有矩形。我需要带有勾号的矩形(如彩色复选框)。根据文档,我可以自定义元素,例如符号附近的文本。 但如果我将绘图上的所有元素都设置为自定义图像 ( Example )
我有下面的代码,可以生成饼图和图例。有没有办法让表情符号和饼图具有相同的对应颜色,因为目前表情符号是黑色的。另外,我希望删除图例中的方形色 block ,并且术语“男性”和“女性”出现在正确的表情符号
我是一名优秀的程序员,十分优秀!