我正在尝试使用Google Charts API创建一个仪表盘。
该仪表板包括一个类型为ChartRangeFilter的ControlWrapper和两个ChartWrapper(LineChart和Table)。这个设置很好用,但我想添加一个附加项。
LineChart应显示整个数据集,而Table只显示其中的一部分。例如,我有10行数据,在Table中只应显示前8行。
以下是我的当前ControlWrapper:
这是表格:
当我在表定义中取消注释“//,'rows': [0,1,2,3,4,5,6]”这行时,在移动ControlWrapper的滑块时会出现错误。
有没有办法让这个工作起来?
原因是(在这个例子中)最后两行只有第三列的数据,这些数据只显示在线形图中而不在表格中。
提前致谢!
//编辑:
这里有一个示例页面:http://circlecount.com/test.chart.range.php 这里是代码:
我想要的: - 整个时期(10天)的图表 - 只有前7天的表格 - 一个控制包装器,控制图表和表格,时间跨度为整个时期(10天)
我希望这样可以更清楚地说明我的问题,如果不行,请给我留言。
提前感谢!
更新: 根据jmac的想法,我使用了以下函数使其正常运行。
您可以在这里找到一个可用的示例:http://circlecount.com/test.chart.range.php
该仪表板包括一个类型为ChartRangeFilter的ControlWrapper和两个ChartWrapper(LineChart和Table)。这个设置很好用,但我想添加一个附加项。
LineChart应显示整个数据集,而Table只显示其中的一部分。例如,我有10行数据,在Table中只应显示前8行。
以下是我的当前ControlWrapper:
control = new google.visualization.ControlWrapper({
'controlType': 'ChartRangeFilter',
'containerId': 'control',
'options': {
'filterColumnIndex': 0,
'ui': {
'chartType': 'LineChart',
'chartOptions': {
'chartArea': {'width': '95%'},
'hAxis': {'baselineColor': 'none'}
},
'chartView': {
'columns': [0,1]
},
'minRangeSize': 86400000
}
}
});
这是表格:
chart = new google.visualization.ChartWrapper({
'chartType': 'Table',
'containerId': 'table',
'options': {
width: 470,
height: 340,
sortColumn: 0,
sortAscending: false
},
'view': {
'columns': [0, 1]
//,'rows': [0,1,2,3,4,5,6]
}
});
当我在表定义中取消注释“//,'rows': [0,1,2,3,4,5,6]”这行时,在移动ControlWrapper的滑块时会出现错误。
Invalid row index 6. Should be in the range [0-5]
有没有办法让这个工作起来?
原因是(在这个例子中)最后两行只有第三列的数据,这些数据只显示在线形图中而不在表格中。
提前致谢!
//编辑:
这里有一个示例页面:http://circlecount.com/test.chart.range.php 这里是代码:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML+RDFa 1.1//EN" "http://www.w3.org/MarkUp/DTD/xhtml-rdfa-2.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" version="XHTML+RDFa 1.1" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.w3.org/1999/xhtml http://www.w3.org/MarkUp/SCHEMA/xhtml-rdfa-2.xsd" lang="de" xml:lang="de" dir="ltr" xmlns:og="http://ogp.me/ns#" >
<head>
<script src="http://www.google.com/jsapi?key=" type="text/javascript"></script>
<script type="text/javascript">google.load("jquery", "1.7.1");</script>
</head>
<body>
<script type="text/javascript">
// Load the Visualization API and the piechart package.
google.load('visualization', '1.0', {'packages':['corechart', 'table', 'controls']});
// Set a callback to run when the Google Visualization API is loaded.
google.setOnLoadCallback(fctDrawChart);
var control, chart;
function fctDrawChart() {
//follower
var data = new google.visualization.DataTable();
var myTempDate = new Date();
data.addColumn('date', 'Day');
data.addColumn('number', 'Followers');
data.addRows(10);
data.setCell(0, 0, new Date('11/07/2011'));
data.setCell(0, 1, 11);
data.setCell(1, 0, new Date('11/08/2011'));
data.setCell(1, 1, 222);
data.setCell(2, 0, new Date('11/09/2011'));
data.setCell(2, 1, 1242);
data.setCell(3, 0, new Date('11/10/2011'));
data.setCell(3, 1, 1420);
data.setCell(4, 0, new Date('11/11/2011'));
data.setCell(4, 1, 1609);
data.setCell(5, 0, new Date('11/12/2011'));
data.setCell(5, 1, 1676);
data.setCell(6, 0, new Date('11/13/2011'));
data.setCell(6, 1, 1734);
data.setCell(7, 0, new Date('11/14/2011'));
data.setCell(7, 1, 1773);
data.setCell(8, 0, new Date('11/15/2011'));
data.setCell(8, 1, 1857);
data.setCell(9, 0, new Date('11/16/2011'));
data.setCell(9, 1, 1874);
var dataView = new google.visualization.DataView(data);
dataView.setColumns([0, 1]);
var dashboard = new google.visualization.Dashboard(document.getElementById('dashboard'));
control = new google.visualization.ControlWrapper({
'controlType': 'ChartRangeFilter',
'containerId': 'control',
'options': {
'filterColumnIndex': 0,
'ui': {
'chartType': 'LineChart',
'chartOptions': {
'chartArea': {'width': '95%'},
'hAxis': {'baselineColor': 'none'}
},
'chartView': {
'columns': [0,1]
},
'minRangeSize': 86400000
}
}
});
google.visualization.events.addListener(control, 'statechange', function() {
$("#periodSelector").val("custom");
});
chart = new google.visualization.ChartWrapper({
'chartType': 'Table',
'containerId': 'table',
'options': {
width: 470,
height: 340,
sortColumn: 0,
sortAscending: false
},
'view': {
'columns': [0, 1]
,'rows': [0,1,2,3,4,5,6]
}
});
chart2 = new google.visualization.ChartWrapper({
'chartType': 'LineChart',
'containerId': 'chart',
'options': {
width: 470,
height: 340,
sortColumn: 0,
sortAscending: false
},
'view': {
'columns': [0, 1]
}
});
dashboard.bind(control, chart);
dashboard.bind(control, chart2);
dashboard.draw(data);
}
</script>
<div id='dashboard' >
<div id='table' style='width:240px;height:400px;'></div>
<div id='chart' style='width:240px;height:400px;'></div>
<div id='control' style='width:840px;height:40px;'></div>
</div>
</div>
</body>
</html>
我想要的: - 整个时期(10天)的图表 - 只有前7天的表格 - 一个控制包装器,控制图表和表格,时间跨度为整个时期(10天)
我希望这样可以更清楚地说明我的问题,如果不行,请给我留言。
提前感谢!
更新: 根据jmac的想法,我使用了以下函数使其正常运行。
google.visualization.events.addListener(control, 'statechange',
function(event) {
if (control.getState()["range"]["end"] > myLastRealDate) {
var myRowsArr = new Array();
var myTempDate = control.getState()["range"]["start"];
for (var i=0;i<myLastRealRow-(myDateArr[(myTempDate.getMonth()+1)+"/"+myTempDate.getDate()+"/"+myTempDate.getFullYear()]);i++) {
myRowsArr.push(i);
}
chart.setView({'rows': myRowsArr});
}
else {
chart.setView({'rows': null});
}
});
您可以在这里找到一个可用的示例:http://circlecount.com/test.chart.range.php