私はちょうどGoogleチャートとその本当にクールなものを使い始めました. 唯一の問題は、SQL サーバー ビューから供給されたデータを使用してこれを実装するための良い例が見つからないことです。だから私はこの機能を容易にするためにサンプルプロジェクトを作成しましたが、それを機能させるために戦っています. 以下の私のコードを見つけてください:
<script type="text/javascript">
// Load the Visualization API and the piechart package.
google.load('visualization', '1', { 'packages': ['corechart'] });
// Set a callback to run when the Google Visualization API is loaded.
google.setOnLoadCallback(drawChart);
function drawChart() {
var jsonData = $.ajax({
url: "api/Google",
dataType: "json",
async: false
}).responseText;
alert(jsonData);
// Create our data table out of JSON data loaded from server.
var data = new google.visualization.DataTable(jsonData);
data.addColumn('string', 'Employee');
data.addColumn('number', 'TotalNoOfReports');
// Instantiate and draw our chart, passing in some options.
var chart = new google.visualization.PieChart(document.getElementById('chart_div'));
chart.draw(data, { width: 400, height: 240 });
}
</script>
正しい json データ文字列を取得していますが、jsonData を DataTable() クラスに渡すと、グラフのデータが返されません。また、data.AddRows(jsonData) を呼び出そうとしましたが、まだ運がありません。Google は通常の json データの構造を理解しておらず、次の形式である必要があると推測しています。
{"cols":[{"id":"Col1","label":"","type":"date"}],
"rows":[
{"c":[{"v":"a"},{"v":"Date(2010,10,6)"}]},
{"c":[{"v":"b"},{"v":"Date(2010,10,7)"}]}
]
}
jsonData を上記の構造のように見えるようにする方法はありますか、おそらくもっと一般的なものです。唯一のグラフの例は静的であり、データベースから読み取る必要がある場合があります。助けてください。