- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我正试图在制图区域之外获取图表的图例。
这是边距:
var margin = {top: 50, right: 200, bottom: 50, left: 40};
var width = 960 - margin.left - margin.right,
height = 500 - margin.top - margin.bottom;
首先我创建了 svg:
var svg = d3.select("body").append("svg")
.attr("width", width + margin.left + margin.right)
.attr("height", height + margin.top + margin.bottom)
.append("g")
.attr("transform", "translate(" + margin.left + "," + margin.top + ")");
因此,根据我的理解,我现在拥有 svg canvas 元素和其中包含图表的 g。我正在尝试向右边距添加更多内容,因此我可以在 svg Canvas 和附加到它的 g 之间获得一些空间,其中包含图表。然后我想把我的传奇放在那个空旷的地方。
这是我添加图例的地方:
//add legend
var legend = svg.append("g")
.attr("class", "legend")
.attr("height", 300)
.attr("width", 200)
.attr("transform", "translate(-1000,50");
即使我追加到 SVG 元素,它也追加到 svg 元素中的 g。所以,无论我如何翻译它或试图让它在屏幕上显示得更正确,它都不会超过内部 g 的宽度。
在排除故障时,我看到外部 SVG 元素的高度为 960,宽度为 500。附加到其上的 g 的转换/转换为 40,50。宽度最终为 839px x 433.223px(不确定我是否理解)。由于内置边距,外部 svg 现在有一堆空间。
所以我正在尝试增加附加到 svg 的 g 的宽度,这样我就可以将我的图例作为 g 的子项并将其移动到边距创建的空白区域。或者,我正在尝试创建另一个 g,它是第一个 g 的同级,然后我可以使用边距创建的空白空间。
我无法开始工作,也不知道哪种方式最好。
最佳答案
注意变量 svg
正在分配给 <g>
嵌套在 <svg>
中
svg = d3.select("body").append("svg")
.attr("width", width + margin.left + margin.right)
.attr("height", height + margin.top + margin.bottom)
.append("g") // <-- This is what svg is currently being assigned to
.attr("transform", "translate(" + margin.left + "," + margin.top + ")");
因此,当您稍后执行 var legend = svg.append("g")
时,您实际上是将图例附加为上述 <g>
的子项.这就是您描述的在开发工具中看到的内容。
一个含义是 translate()
将你应用到外部的变换 <g>
影响内部<g>
(即 <g>
的内部 legend
的翻译添加到外部 <g>
的翻译)。
您可能希望像这样拆分:
var svg = d3.select("body").append("svg")
.attr("width", width + margin.left + margin.right)
.attr("height", height + margin.top + margin.bottom);
var inner = svg.append("g")
.attr("transform", "translate(" + margin.left + "," + margin.top + ")");
然后更改您的代码以将现有图表绘制到 inner
中而不是 svg
.
因此,var legend = svg.append("g")
将附加图例作为 inner
的 sibling ,以及您应用于 legend
的任何翻译将相对于 svg 的左上角(与 inner
的左上角相反,由 margin
翻译)
您可能想翻译 legend
像这样:
var legend = svg.append("g")
.attr("transform", "translate(" + width - margin.right + "," + margin.top + ")");
这会将图例移动到图表的右端,MINUS margin.right
.这样,您可以调整 margin.right
为legend
创造足够的空间.
最后,注意调用
legend
.attr("height", 300)
.attr("width", 200)
什么都不做,因为对于 svg <g>
,没有办法显式设置宽度和高度。无论如何,这些意义不大,因为 svg 没有 html 布局的“流”行为。开发工具中显示的宽度和高度是由 <g>
的子项边界产生的隐式边界。 . (如果需要,有一种方法可以使用 getBBox()
函数在 javascript 中获取这些计算边界)。
关于javascript - d3.js 获取图表外的图例,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35661493/
我在 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 ,并且术语“男性”和“女性”出现在正确的表情符号
我是一名优秀的程序员,十分优秀!