- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
google.load("visualization", "1", {packages: ["corechart", 'bar', 'Controls']});
google.setOnLoadCallback(drawChart);
function drawChart() {
var chartsdata = new google.visualization.DataTable();
chartsdata.addColumn('date', 'Datum');
chartsdata.addColumn('number', 'TijdAfd1');
chartsdata.addColumn({
'type': 'string',
'role': 'annotation'
});
chartsdata.addColumn('number', 'TijdAfd2');
chartsdata.addColumn({
'type': 'string',
'role': 'annotation'
});
chartsdata.addColumn('number', 'TijdAfd3');
chartsdata.addColumn({
'type': 'string',
'role': 'annotation'
});
chartsdata.addRows([
[new Date('2017-05-29'), 56, '7,3m³', 42, '5,7m³', 59, '9524m³'],
[new Date('2017-05-30'), 29, '3,8m³', 23, '3,1m³', 30, '4746m³'],
[new Date('2017-05-31'), 53, '6,9m³', 13, '1,8m³', 60, '9522m³'],
[new Date('2017-06-01'), 47, '6,1m³', 45, '6,2m³', 53, '8463m³'],
[new Date('2017-06-02'), 69, '9,1m³', 48, '6,7m³', 66, '10502m³'],
[new Date('2017-06-03'), 39, '5,1m³', 25, '3,4m³', 41, '6604m³'],
[new Date('2017-06-04'), 51, '6,7m³', 44, '6,0m³', 43, '6800m³']
]);
// Create a dashboard.
var dashboard = new google.visualization.Dashboard(
document.getElementById('dashboard_div'));
// Create a range slider, passing some options
var ChartRangeFilter = new google.visualization.ControlWrapper({
controlType: 'ChartRangeFilter',
containerId: 'filter_div',
options: {
//displayLabels: false,
//displayAnnotations: false,
tooltip: {
isHtml: true
},
filterColumnLabel: 'Datum',
ui: {
chartOptions: {
height: 55
}
}
},
// exclude annotation columns
view: {
columns: [0, 1, 3, 5]
}
});
// Create a Column chart, passing some options
var ColumnChart = new google.visualization.ChartWrapper({
chartType: 'ColumnChart',
containerId: 'chart_div',
options: {
focusTarget: 'category',
tooltip: {
isHtml: true
}
}
});
// Establish dependencies, declaring that 'filter' drives 'ColumnChart',
// so that the column chart will only display entries that are let through
// given the chosen slider range.
dashboard.bind(ChartRangeFilter, ColumnChart);
// Draw the dashboard.
dashboard.draw(chartsdata);
}
<script type="text/javascript" src="https://www.gstatic.com/charts/loader.js"></script>
<script type="text/javascript" src="https://www.google.com/jsapi"></script>
<div id="dashboard_div">
<!--Divs that will hold each control and chart-->
<div id="filter_div"></div>
<div id="chart_div"></div>
</div>
我添加了一个仪表板控件并将 ChartRangeFilter 和 ColumnChart 绑定(bind)到它。如果我在 ChartRangeFilter 上配置 View 以排除用于注释的列,那么这些注释也会从我的 ColumnChart 中消失。在 ChartRangeFilter 上将 displayAnnotations 设置为 false 不会改变任何内容。
google.load("visualization", "1", { packages: ["corechart", 'bar', 'Controls'] });
google.setOnLoadCallback(drawChart);
function drawChart() {
$.ajax({
type: "POST",
url: '@Url.Action("AjaxMethod", "AcuatorsRunTimes")',
data: { StartDate: "@ViewData["StartDate"]", EndDate: "@ViewData["EndDate"]" },
success: function (Data) {
var data1 = new google.visualization.arrayToDataTable(Data);
var chartsdata = new google.visualization.DataTable();
chartsdata.addColumn('date', 'Datum');
chartsdata.addColumn({ 'type': 'string', 'role': 'tooltip', 'p': { 'html': true } });
chartsdata.addColumn('number', 'TijdAfd1');
//chartsdata.addColumn('string', "VolumeAfd1");
chartsdata.addColumn({ 'type': 'string', 'role': 'annotation' });
chartsdata.addColumn('number', 'TijdAfd2');
//chartsdata.addColumn('string', "VolumeAfd2");
chartsdata.addColumn({ 'type': 'string', 'role': 'annotation' });
chartsdata.addColumn('number', 'TijdAfd3');
//chartsdata.addColumn('string', "VolumeAfd3");
chartsdata.addColumn({ 'type': 'string', 'role': 'annotation' });
for (var i = 1; i < data1.getNumberOfRows(); i++) {
var myDate = Date.parse(data1.getFormattedValue(i, 0));
var titles = ['Afdeling 1', 'Afdeling 2', 'Afdeling 3'];
var values = [data1.getFormattedValue(i, 4), data1.getFormattedValue(i, 5), data1.getFormattedValue(i, 6)];
var Anno1 = data1.getFormattedValue(i, 7) + 'm³';
var Anno2 = data1.getFormattedValue(i, 8) + 'm³';
var Anno3 = data1.getFormattedValue(i, 9) + 'm³';
chartsdata.addRow([new Date(myDate), HTMLtableRows(titles, values), parseInt(data1.getFormattedValue(i, 1)), Anno1, parseInt(data1.getFormattedValue(i, 2)), Anno2, parseInt(data1.getFormattedValue(i, 3)), Anno3]);
}
// Create a dashboard.
var dashboard = new google.visualization.Dashboard(
document.getElementById('dashboard_div'));
// Create a range slider, passing some options
var ChartRangeFilter = new google.visualization.ControlWrapper({
controlType: 'ChartRangeFilter',
containerId: 'filter_div',
options: {
//displayLabels: false,
//displayAnnotations: false,
tooltip: { isHtml: true },
filterColumnLabel: 'Datum',
ui: {
chartType: 'LineChart',
chartOptions: {
height: 55
}
}
}
});
// Create a column chart, passing some options
var ColumnChart = new google.visualization.ChartWrapper({
chartType: 'ColumnChart',
containerId: 'chart_div',
options: {
focusTarget: 'category',
tooltip: { isHtml: true }
}
});
// Establish dependencies, declaring that 'filter' drives 'ColumnChart',
// so that the column chart will only display entries that are let through
// given the chosen slider range.
dashboard.bind(ChartRangeFilter, ColumnChart);
// Draw the dashboard.
dashboard.draw(chartsdata);
},
failure: function (Data) {
alert(Data.d);
},
error: function (Data) {
alert(Data.d);
}
});
}
最佳答案
包括数据表中用于绘制仪表板的注释列,
然后从过滤器的 view
属性中排除这些列...
var ChartRangeFilter = new google.visualization.ControlWrapper({
controlType: 'ChartRangeFilter',
containerId: 'filter_div',
options: {
tooltip: { isHtml: true },
filterColumnLabel: 'Datum',
ui: {
chartType: 'LineChart',
chartOptions: {
height: 55
}
}
},
// exclude annotation columns
view: {
columns: [0, 1, 2, 4, 6]
}
});
编辑
通过使范围过滤器上的注释变得透明来隐藏它们,
将以下内容添加到 chartOptions
...
annotations: {
highContrast: false,
stem: {
color: 'transparent',
length: 0
},
textStyle: {
color: 'transparent'
}
},
请参阅以下工作片段...
google.load("visualization", "1", {packages: ["corechart", 'bar', 'Controls']});
google.setOnLoadCallback(drawChart);
function drawChart() {
var chartsdata = new google.visualization.DataTable();
chartsdata.addColumn('date', 'Datum');
chartsdata.addColumn('number', 'TijdAfd1');
chartsdata.addColumn({
'type': 'string',
'role': 'annotation'
});
chartsdata.addColumn('number', 'TijdAfd2');
chartsdata.addColumn({
'type': 'string',
'role': 'annotation'
});
chartsdata.addColumn('number', 'TijdAfd3');
chartsdata.addColumn({
'type': 'string',
'role': 'annotation'
});
chartsdata.addRows([
[new Date('2017-05-29'), 56, '7,3m³', 42, '5,7m³', 59, '9524m³'],
[new Date('2017-05-30'), 29, '3,8m³', 23, '3,1m³', 30, '4746m³'],
[new Date('2017-05-31'), 53, '6,9m³', 13, '1,8m³', 60, '9522m³'],
[new Date('2017-06-01'), 47, '6,1m³', 45, '6,2m³', 53, '8463m³'],
[new Date('2017-06-02'), 69, '9,1m³', 48, '6,7m³', 66, '10502m³'],
[new Date('2017-06-03'), 39, '5,1m³', 25, '3,4m³', 41, '6604m³'],
[new Date('2017-06-04'), 51, '6,7m³', 44, '6,0m³', 43, '6800m³']
]);
// Create a dashboard.
var dashboard = new google.visualization.Dashboard(
document.getElementById('dashboard_div'));
// Create a range slider, passing some options
var ChartRangeFilter = new google.visualization.ControlWrapper({
controlType: 'ChartRangeFilter',
containerId: 'filter_div',
options: {
//displayLabels: false,
//displayAnnotations: false,
tooltip: {
isHtml: true
},
filterColumnLabel: 'Datum',
ui: {
chartOptions: {
annotations: {
highContrast: false,
stem: {
color: 'transparent',
length: 0
},
textStyle: {
color: 'transparent'
}
},
height: 55
}
}
}
});
// Create a Column chart, passing some options
var ColumnChart = new google.visualization.ChartWrapper({
chartType: 'ColumnChart',
containerId: 'chart_div',
options: {
focusTarget: 'category',
tooltip: {
isHtml: true
}
}
});
// Establish dependencies, declaring that 'filter' drives 'ColumnChart',
// so that the column chart will only display entries that are let through
// given the chosen slider range.
dashboard.bind(ChartRangeFilter, ColumnChart);
// Draw the dashboard.
dashboard.draw(chartsdata);
}
<script type="text/javascript" src="https://www.gstatic.com/charts/loader.js"></script>
<script type="text/javascript" src="https://www.google.com/jsapi"></script>
<div id="dashboard_div">
<!--Divs that will hold each control and chart-->
<div id="filter_div"></div>
<div id="chart_div"></div>
</div>
关于javascript - 谷歌图表 : How to avoid disappearing of annotations on each chart in dashboard control?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44554057/
我正在尝试将网页内容打印到一页纸上。但是,它将内容分成 2 页,所以我在这里做了一些研究,看到有人推荐: #my_print_div{ width:940px; height:770px; page
我目前正在打印一些东西。我有一个动态页面,其中包含可变数量的 block 级元素。有些可能是 1 行,有些可能是 100 多行。 1text 1 line.... 2text 10 lines....
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 9
我正在训练一个 randomForest 模型,目的是保存它以进行预测(它将被下载并在外部上下文中使用)。我希望这个模型尽可能最小。 我读到有很多options和 packages减少模型的内存大小。
这个问题在这里已经有了答案: MySQL connection timeout (3 个答案) 关闭 9 年前。 我一直在尝试使用 Tomcat 的 native 连接池功能来避免我的 Java W
我正在使用 Phonegap/Cordova 开发 Android 应用程序。我已经按照这样的百分比安排了我的布局(在 CSS 中): 标题 - 50px; Content_row1 - 30%(剩下
我正在编写一个插件,它将表情符号转换为特定站点文本 block 中的图像。简单的答案是使用正则表达式检测 innerHTML 上的触发文本并插入 img 标签,然后将字符串通过管道返回到 innerH
如何避免在我的 Drupal View 上重复? 我应该添加一个过滤器,指定特定字段(即用户 ID)不应出现两次吗?我找不到这样的选项 看法 http://dl.dropbox.com/u/72686
感谢您查看我的 typescript 问题。 为简单起见,我对 typescript “过度属性检查”行为有疑问。我想确保 TypeScript 不接受具有额外属性的对象。 在我的简单界面示例中,OF
我发现对于某些图表,我从 Prometheus 获得了 doubles 值,其中应该只是一个: 我使用的查询: increase(signups_count[4m]) 抓取间隔设置为 recommen
假设我正在运行N个线程。 每个线程都需要与下一个和上一个同步。 for (i = 0 ; i < NITER; i++){ do_something (); sync_
如今,服务器虚拟化是一件大事,所以我的任务是在虚拟化服务器上安装我们的一些软件,看看会发生什么。长话短说:rsync 传输会立即使虚拟化服务器崩溃。虚拟化主机是一台强大的机器,没有其他负载;我认为
以下正则表达式在应用于大型 html 页面时会创建 StackOverflowError: (.|\s)*? 我的假设是,这是由于逻辑“OR”运算符(|)在匹配器中创建了递归调用,并且由于需要解析的
我在运行时使用表达式树构建委托(delegate): Type type = GetType(); ParameterExpression parameterType = Expression.Par
我正在使用 scikit-learn TfidfVectorizer 找出两个文档中最重要的单词。每个文档大小为 1.9GB(约 9000 万字),并且已采用小写、词干化(使用 nltk.stem.p
我进行了一个中间件调用来获取 String 数组,如下所示: String[] freqwords = MViewer.getWordNames(); 问题是可能没有可用数据,因此任何进一步的操作(如
在 JavaFx 中,我使用以下代码创建一个 StackedBarChart: String[] ACTIVITIES = new String[10]{ ... };// there
我正在尝试制作一个使用类 AnimationTimer 来处理它的游戏。我的代码摘要如下所示: 主类 object Game extends JFXApp{ def showMenu{
我正在用不同的步骤创建一个小的 javascript/jQuery 应用程序。为此,我使用了一个具有不同功能的 js 文件。 在文件的顶部我调用了我的第一个函数。在我的第一个函数中,我在单击按钮时调用
我正在使用表格 View 来显示从服务器加载的文本字段数组,所以我有一个表格 View 字段列表,当我填充这些数据字段并向下滚动以填充其他字段时,当我再次向上滚动时,我发现值发生变化并且存在重复值 -
我是一名优秀的程序员,十分优秀!