- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
图表中时间线 rowLabel 的正确 svg 元素是什么?
我试图将行标签(行名称)放在图表左侧的 div 中,并删除实际的行标签。我可以通过以下方式轻松删除行标签:
timeline: { groupByRowLabel: true, showrowLabels: false}
但我找不到一种方法将实际标签移到单独的 div 中的左侧,这样一个巨大的水平滚动将使行标签保持在左侧卡住。
function afterDraw() {
//trying to move the rowlabelhere
var header = document.getElementById('rowlabel');
header.innerHTML = '';
var svg = document.getElementsByTagName('svg')[0];
var g = svg.getElementsByTagName('g')[0];
var gtext = g.getElementsByTagName('text')[0];
var svgNew = header.appendChild(svg.cloneNode());
var gNew = svgNew.appendChild(gtext.cloneNode(true));
var height = parseFloat(gNew.getElementsByTagName('text')[0].getAttribute('y')) - 25;
gNew.setAttribute('transform','translate(60,-'+height+')');
}
这是一个有问题的代码笔:
最佳答案
您可以按照您的描述移除标签,
然后使用 group()从数据表中拉取标签的方法,
并将它们添加到图表左侧的容器中。
为了得到正确顺序的标签,
我们可以对标签和开始日期进行分组,
然后按开始日期排序。
var group = google.visualization.data.group(
data,
[0, 1],
[{
column: 0,
type: 'number',
label: data.getColumnLabel(0),
aggregation: google.visualization.data.count
}]
);
group.sort([{column: 1}]);
但这会导致部分标签重复,
所以我们可以使用一个数组来过滤掉那些,
当我们将它们添加到容器中时。
var rowLabels = [];
var rowElements = [];
var labels = document.getElementById('labels');
for (var i = 0; i < group.getNumberOfRows(); i++) {
var team = group.getValue(i, 0);
if (rowLabels.indexOf(team) === -1) {
rowLabels.push(team);
var label = labels.appendChild(document.createElement('div'));
label.className = 'label';
label.innerHTML = team;
rowElements.push(label);
}
}
然后在'ready'
事件中,我们可以调整标签高度,
以匹配图表行。
var rows = container.getElementsByTagName('rect');
var rowIndex = -1;
Array.prototype.forEach.call(rows, function(rect) {
if (rect.getAttribute('x') === '0') {
rowIndex++;
if (rowIndex < rowElements.length) {
var rowHeight = (parseFloat(rect.getAttribute('height')) - 1) + 'px';
rowElements[rowIndex].style.height = rowHeight;
rowElements[rowIndex].style.lineHeight = rowHeight;
}
}
});
请参阅以下工作片段...
(以整页模式查看片段以查看完整效果)
google.charts.load('current', {
packages:['timeline']
}).then(function () {
var data = new google.visualization.DataTable({
cols: [
{id: 'team', label: 'Team', type: 'string'},
{id: 'start', label: 'Season Start Date', type: 'date'},
{id: 'end', label: 'Season End Date', type: 'date'}
],
rows: [
{c: [{v: 'Baltimore Ravens'}, {v: 'Date(2000, 8, 5)'}, {v: 'Date(2001, 1, 5)'}]},
{c: [{v: 'New England Patriots'}, {v: 'Date(2001, 8, 5)'}, {v: 'Date(2002, 1, 5)'}]},
{c: [{v: 'Tampa Bay Buccaneers'}, {v: 'Date(2002, 8, 5)'}, {v: 'Date(2003, 1, 5)'}]},
{c: [{v: 'New England Patriots'}, {v: 'Date(2003, 8, 5)'}, {v: 'Date(2004, 1, 5)'}]},
{c: [{v: 'New England Patriots'}, {v: 'Date(2004, 8, 5)'}, {v: 'Date(2005, 1, 5)'}]},
{c: [{v: 'Pittsburgh Steelers'}, {v: 'Date(2005, 8, 5)'}, {v: 'Date(2006, 1, 5)'}]},
{c: [{v: 'Indianapolis Colts'}, {v: 'Date(2006, 8, 5)'}, {v: 'Date(2007, 1, 5)'}]},
{c: [{v: 'New York Giants'}, {v: 'Date(2007, 8, 5)'}, {v: 'Date(2008, 1, 5)'}]},
{c: [{v: 'Pittsburgh Steelers'}, {v: 'Date(2008, 8, 5)'}, {v: 'Date(2009, 1, 5)'}]},
{c: [{v: 'New Orleans Saints'}, {v: 'Date(2009, 8, 5)'}, {v: 'Date(2010, 1, 5)'}]},
{c: [{v: 'Green Bay Packers'}, {v: 'Date(2010, 8, 5)'}, {v: 'Date(2011, 1, 5)'}]},
{c: [{v: 'Green Bay Packers'}, {v: 'Date(2010, 8, 5)'}, {v: 'Date(2011, 1, 5)'}]},
{c: [{v: 'New England Patriots'}, {v: 'Date(2001, 8, 5)'}, {v: 'Date(2002, 1, 5)'}]},
{c: [{v: 'Tampa Bay Buccaneers'}, {v: 'Date(2002, 8, 5)'}, {v: 'Date(2003, 1, 5)'}]},
{c: [{v: 'New England Patriots'}, {v: 'Date(2003, 8, 5)'}, {v: 'Date(2004, 1, 5)'}]},
{c: [{v: 'New England Patriots'}, {v: 'Date(2004, 8, 5)'}, {v: 'Date(2005, 1, 5)'}]},
{c: [{v: 'Pittsburgh Steelers'}, {v: 'Date(2005, 8, 5)'}, {v: 'Date(2006, 1, 5)'}]},
]
});
var group = google.visualization.data.group(
data,
[0, 1],
[{
column: 0,
type: 'number',
label: data.getColumnLabel(0),
aggregation: google.visualization.data.count
}]
);
group.sort([{column: 1}]);
var rowLabels = [];
var rowElements = [];
var labels = document.getElementById('labels');
for (var i = 0; i < group.getNumberOfRows(); i++) {
var team = group.getValue(i, 0);
if (rowLabels.indexOf(team) === -1) {
rowLabels.push(team);
var label = labels.appendChild(document.createElement('div'));
label.className = 'label';
label.innerHTML = team;
rowElements.push(label);
}
}
var options = {
height: 650,
timeline: {
groupByRowLabel: true,
showRowLabels: false
},
width: 1000
};
var container = document.getElementById('chart');
var chart = new google.visualization.Timeline(container);
google.visualization.events.addListener(chart, 'ready', afterDraw);
chart.draw(data, options);
window.addEventListener('resize', function () {
chart.draw(data, options);
});
function afterDraw() {
var header = document.getElementById('header');
header.innerHTML = '';
var svg = document.getElementsByTagName('svg')[0];
var g = svg.getElementsByTagName('g')[1];
var svgNew = header.appendChild(svg.cloneNode());
var gNew = svgNew.appendChild(g.cloneNode(true));
var height = parseFloat(gNew.getElementsByTagName('text')[0].getAttribute('y')) - 25;
gNew.setAttribute('transform','translate(0,-'+height+')');
g.parentNode.removeChild(g);
var rows = container.getElementsByTagName('rect');
var rowIndex = -1;
Array.prototype.forEach.call(rows, function(rect) {
if (rect.getAttribute('x') === '0') {
rowIndex++;
if (rowIndex < rowElements.length) {
var rowHeight = (parseFloat(rect.getAttribute('height')) - 1) + 'px';
rowElements[rowIndex].style.height = rowHeight;
rowElements[rowIndex].style.lineHeight = rowHeight;
}
}
});
}
});
#header {
height: 56px;
}
#labels {
border: 1px solid #b7b7b7;
margin-top: 56px;
}
.label {
border-top: 1px solid #b7b7b7;
font-family: Arial;
font-size: 13px;
text-align: right;
padding-left: 8px;
padding-right: 8px;
}
.label:first-child {
border: none;
}
.label:nth-child(even) {
background-color: #e6e6e6;
}
.label:nth-child(odd) {
background-color: #ffffff;
}
.scroll {
width: 800px;
overflow-x: scroll;
}
.inline {
display: inline-block;
vertical-align: top;
}
.nowrap {
white-space: nowrap;
}
<script src="https://www.gstatic.com/charts/loader.js"></script>
<div class="nowrap">
<div class="inline" id="labels"></div>
<div class="inline scroll">
<div id="header"></div>
<div id="chart"></div>
</div>
</div>
关于javascript - 谷歌图表 : Timeline move rowLabel text in another div,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55271673/
我正在尝试实现一个时间轴,但是当我点击其中一个不同的状态时我无法更改颜色 :( 有谁知道我的问题是什么或者我该怎么做? 本来的想法是给不同的状态分配不同的颜色,但是没有成功:( 在图片中我留下了一个我
我在我的应用程序中使用时间轴 JS 来根据日期显示两种类型的报告。它工作正常,但是当报告数据数量较多时,很难找到哪个报告属于哪个类别。所以我想在timemarker中使用不同的文本颜色来区分两种类型。
我有一个由客户端软件调用的 WPF 应用程序。它第一次工作正常。当我从客户端软件关闭 WPF 应用程序并再次加载 WPF 应用程序(中间没有关闭客户端软件))时,它抛出一个异常,因为“属性元数据已经为
我需要可视化时间线内的大量数据。我发现'verite Timeline '看起来很有希望,但我没有任何经验,使用了很多数据集。有人可以告诉我这个工具的性能或告诉我更好的解决方案吗?谢谢! 最佳答案 正
我有一个数据框,其中包含不同团队执行的任务的信息。 我想使用 R.Blue box = team 绘制类似的图,如下所示。任务已完成 = 绿框。执行任务=灰框。我正在考虑使用 ggplot2 geom
我对任何可以执行以下操作的库感兴趣: 我有一个时间范围:假设 1995 年到 2010 年,我可以以某种方式对其进行分类,假设为“互联网时代”。 然后我希望能够将其进一步分解,将 2001-2010
我有一个谷歌时间轴,如下面的代码所示,我想更改任何标题为“黑色”的条目的颜色。我似乎无法让它工作,我尝试了几种不同的解决方案。这是我的代码: http://jsfiddle.net/5j0umkcx/
我正在尝试创建一个 Internet 检查器类,它将检查与某个 url 的连接并相应地更新状态属性。为了避免 ui 卡住,我想使用一个线程和一个计时器在一定时间间隔后重新检查。问题是时间轴关键帧中的
我目前正在构建一个基于网络的迷你社交网络。与 Facebook 一样,每个用户都有一个发布最近事件的时间表。这些事件包括状态更新、在页面上发帖、添加新 friend 和喜欢页面。 它们在数据库中使用这
我创建了一个时间表,有时连续有两个时间表。这不是问题,但我想在一行中重叠显示它们。 请看这个例子: 因此,较小的行应显示为较大行的一部分。 Google 的可视化 API 很棒,是一件非常好的东西,但
我有一个包含很多行的时间表,每行中都有几个时间表。 我想为每个时间表固定一个确切的颜色,这样一种类型的时间表在每一行中都会有相同的颜色。 我正在使用这段代码: var options = {
我将如何存储用户“帖子”?这样我就可以有效地从数据库中获取它们,然后在请求特定用户页面时处理它们以按时间顺序显示? 我是否像这样将所有用户的所有帖子存储在一个表中: Post ID | Poster
我需要将 Pane 的背景颜色设置一秒钟,然后将其切换为透明。我已将其设置为更改背景颜色,使用持续时间为 1000 毫秒的时间线暂停它,然后切换为透明。 时间轴没有暂停,程序飞过它并且过快地将背景设置
编辑:Java/FX 版本:13.0.2 集成环境:Eclipse 4.13.0 Tracker 和 changePerFrame 值在类级别上声明为私有(private) double 变量。 目标
我正在尝试找到合适的 css 类来为 vis timeline 的组标签分配新的背景颜色。这是我的 jsfiddle 示例。 I want to give the Label in front of
我正在 Timeline lite 中对多个补间进行排序,但我希望其中几个补间同时发生在不同的对象上。如果没有 onComplete 函数,有没有办法做到这一点。我当前的补间序列是: tl.to($s
我正在构建一个视差滚动网站(我们不都是这样),除其他外,它会在用户滚动时显示图像。 我通过将图像放在背景中并在顶部放置一个实心填充的 div 来完成“显示”。然后我根据滚动位置将此 div 从 100
我的问题是关于 Chrome DevTools,具体来说,我有关于时间轴选项卡的问题。因此,正如我读过无数次,我的浏览器必须以 60fps 的速度渲染我的像素。有时虽然它有一些繁重的 JS 执行并阻止
说明: 在pg中,当我们进行了基于时间点的还原(PITR)后,数据库会启用新的时间线并继续进行操作。 但是,当我们进行基于时间点的还原后如果发现又出现错误,想要继续还原数据库该如何操作呢?如何还
我在 Vis JS Timeline 中使用以下选项在时间线顶部生成带有时间标签的水平轴: orientation: { axis: 'both' }, 水平轴如下所示: 我的时间线有很多行,
我是一名优秀的程序员,十分优秀!