- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
(抱歉重复发帖,github上的issue一周后仍未得到回复:https://github.com/c3js/c3/issues/2254)
我正在使用 C3 JS,我在同一页面上显示了多个堆叠条形图。每一个都有不同的传说,有些传说比其他的要大得多。由于我只能为整个图像定义高度,因此具有较大图例的图表的 y 轴会变小。
下图说明了这个问题:
我的目标是 y 轴在两个图表上具有相同的高度。整体图表高度(图表+图例)并不重要。
是否有可能为图表分配固定高度而不包括此尺寸的图例高度?也许我应该直接使用 D3?
感谢您的关注和这个很棒的库。
最好的,艾伦
最佳答案
我认为唯一的方法是使用 c3js 示例中的自定义图例(参见 http://c3js.org/samples/legend_custom.html)。
所以你必须禁用图例:
legend: {
show: false
}
并创建您自己的图例(例如使用 d3.js):
function createLegend(chart, container) {
var dataKeys = Object.keys(chart.internal.data.xs);
var names = chart.data.names();
console.log("createLegend", dataKeys, names, chart);
$(container).css("max-height", "none");
$(container).css("width", chart.internal.currentWidth);
d3.select(container).insert('div', '.chart').attr('class', 'legend').selectAll('div')
.data(dataKeys)
.enter().append('div')
.attr('class', 'legend-item')
.attr('data-id', function(id) {
return id;
})
.each(function(id) {
d3.select(this)
.append('span').style('background-color', chart.color(id)).attr('class', 'legend-box');
var text = names[id];
if (!text) text = id;
d3.select(this)
.append('span').html(text).attr('class', 'legend-text');
})
.on('mouseover', function(id) {
chart.focus(id);
})
.on('mouseout', function(id) {
chart.revert();
})
.on('click', function(id) {
$(this).toggleClass("c3-legend-item-hidden")
chart.toggle(id);
$(container).css("max-height", "none");
});
}
var chart1 = c3.generate({
bindto: '#chart1',
size: {
height: 250,
width: 400
},
data: {
x: 'x',
columns: [
['x', 'one', 'two'],
['data1', 30, 200],
['data2', 130, 100],
['data3', 30, 200],
['data4', 130, 100],
['data5', 30, 1200],
['data6', 130, 50],
['data7', 30, 20],
['data8', 130, 100],
['data9', 230, 10]
],
type: 'bar',
names: {
data1: 'Long Name 1',
data2: 'Long Name 2',
data3: 'Long Name 3',
data4: 'Long Name 4',
data5: 'Long Name 5',
data6: 'Long Name 6',
data7: 'Long Name 7',
data8: 'Long Name 8',
data9: 'Long Name 9',
},
groups: [
['data1', 'data2', 'data3', 'data4', 'data5', 'data6', 'data7', 'data8', 'data9']
]
},
axis: {
x: {
type: 'category' // this needed to load string x value
}
},
legend: {
show: false
},
onrendered: function() {
$('#chart1').css("max-height", "none");
}
});
createLegend(chart1, '#chart1');
/* only to highlight chart container */
.chart {
background: lightgray;
border: solid 1px red;
}
.legend-box {
display: inline-block;
margin-left: 7px;
margin-right: 7px;
padding: 5px;
}
.legend-item {
cursor: pointer;
display: inline-block;
}
.legend-text {
font-family: "Helvetica";
font-size:12px;
white-space: nowrap;
}
.legend {
width: 100%;
display: inline-block;
text-align: center;
overflow: hidden;
}
<script src="https://code.jquery.com/jquery-3.1.0.min.js" type="text/javascript"></script>
<link href="https://cdnjs.cloudflare.com/ajax/libs/c3/0.4.18/c3.css" rel="stylesheet" type="text/css" />
<script src="https://cdnjs.cloudflare.com/ajax/libs/d3/3.5.17/d3.min.js" type="text/javascript"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/c3/0.4.18/c3.min.js" type="text/javascript"></script>
<div id="chart1" class="chart"></div>
这是一个显示完整示例的 jsfiddle:https://jsfiddle.net/beaver71/zp7km2L1/
关于javascript - C3.js:独立于图例高度分配图表高度,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48263821/
我在 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 ,并且术语“男性”和“女性”出现在正确的表情符号
我是一名优秀的程序员,十分优秀!