Как динамически обновить Google Gauge
Я пытался динамически обновить Google Gauge, но, несмотря на рассмотрение нескольких других вопросов, я не могу заставить его работать.
Код приведен ниже, но мне нужно установить значение ползунка, а затем нажать ссылку "Перейти". Это должно обновить датчик. Все, что я могу заставить работать - это изменение текста.
Кто-нибудь может указать, где я иду не так?
<!doctype html>
<html lang="en">
<head>
<title></title>
<meta charset="utf-8">
<link rel="stylesheet" href="http://code.jquery.com/ui/1.10.3/themes/smoothness/jquery-ui.css" />
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js"></script>
<script type='text/javascript' src='http://www.google.com/jsapi'></script>
<script type='text/javascript' src="http://code.jquery.com/ui/1.10.3/jquery-ui.js"></script>
<script type='text/javascript'>
google.load('visualization', '1', {packages:['gauge']});
google.setOnLoadCallback(drawChart);
</script>
<script type='text/javascript'>
function recordValue() {
var val = document.getElementById("amount").value;
setValue(val);
return true;
}
</script>
</head>
<body>
<div id='chart_div'></div>
<p>
<label for="amount">Slider value:</label>
<input type="text" id="amount" style="border: 0; color: #f6931f; font-weight: bold;" />
</p>
<div id="slider-range-max"></div>
<div class="go"><a href="#" class="button" onClick="javascript:return recordValue();">Go</a></div>
<script>
$(function() {
$( "#slider-range-max" ).slider({
range: "max",
min: 1,
max: 100,
value: 50,
slide: function( event, ui ) {
$( "#amount" ).val( ui.value );
}
});
$( "#amount" ).val( $( "#slider-range-max" ).slider( "value" ) );
});
</script>
<script type="text/javascript">
google.load('visualization', '1', {packages: ['gauge']});
google.setOnLoadCallback(drawChart);
var data;
var chart;
var options;
function drawChart() {
data = new google.visualization.DataTable();
data.addColumn('string', 'Gauge');
data.addColumn('number', 'Value');
data.addRows([
['Value', 20]
]);
options= {
animation: {
duration: 2000
},
height: 300,
width: 300,
greenFrom: 40,
greenTo: 100,
yellowFrom: 20,
yellowTo: 40,
redFrom: 0,
redTo: 20,
max: 100
};
// make a temporary view to draw the chart in a blank state
var view = new google.visualization.DataView(data);
view.setColumns([0, {
// create a calculated column that contains all zero's
type: 'number',
calc: function () {
return 0;
}
}]);
chart = new google.visualization.ChartWrapper({
chartType: 'Gauge',
containerId: 'chart_div',
dataTable: view,
options: {
animation: {
duration: 2000
},
height: 300,
width: 300,
greenFrom: 40,
greenTo: 100,
yellowFrom: 20,
yellowTo: 40,
redFrom: 0,
redTo: 20,
max: 100
} });
var runOnce = google.visualization.events.addListener(chart, 'ready', function () {
google.visualization.events.removeListener(runOnce);
// use the real data to redraw
chart.setDataTable(data);
chart.draw();
});
chart.draw();
}
function setValue(val){
data.setValue(0, 0, "['Value', val]");
chart.draw(data, options);
}
</script>
</body>
</html>
1 ответ
Я получил несколько ошибок при отладке этой страницы в Visual Studio 2012, но все же решил первую проблему (после извлечения ползунка, который по какой-то причине не срабатывает).
По сути, вы обновляете столбец 0 строкой, которая используется для отображения индикатора.
Вам необходимо обновить столбец 1 числовым значением:
function setValue(val){
data.setValue(0, 1, parseInt(val));
chart.draw(data, options);
}
Если вы также нуждаетесь в исправлении для слайдера, пожалуйста, сначала сделайте это исправление.