前の記事 ≪:WEB DB PRESS Vol.34 - 本
次の記事 ≫:サイトのブックマーク件数などを一挙に調べられる『SocialMeter』

JavaScriptでグラフを描画出来るライブラリ『WebFX』

2006年08月22日-はてなブックマーク

スポンサード リンク
[PR] 英単語を忘却曲線アプリを使って超効率よく記憶する方法

Chart Usage (WebFX)

In web applications developed now days a lot of the logic that previously resided on the server side is now being implemented on the client side. This is especially true for information presentation, components such as trees and columnlist makes it possible for users to interact with the application, or web site if you wish, without contacting the server. However the ability to present data in a graphic rather than textual format has been quite limited, unless a plugin is used or an image is requested from the server.

JavaScriptでグラフを描画出来るライブラリ『WebFX』。
サーバサイドの技術は使わず、JavaScriptのみ次のようなグラフを描画できます。



次のようにJavascriptとCSSを読み込んだ後、DIVを定義しておきます。

<script type="text/javascript" src="includes/iecanvas.js"></script>
<script type="text/javascript" src="includes/chart.js"></script>
<script type="text/javascript" src="includes/canvaschartpainter.js"></script>
<link rel="stylesheet" type="text/css" media="screen" href="includes/canvaschart.css" />
<body>
<div id="chart" class="chart" style="width: 400px; height: 200px;"></div>

そして、次のようにJavaScriptを呼び出すことでグラフを描画できるようです。

function draw() {
var c = new Chart(document.getElementById('chart'));
c.setDefaultType(CHART_AREA | CHART_STACKED);
c.setGridDensity(5, 5);
c.setVerticalRange(0, 100);
c.setHorizontalLabels(['mon', 'tue', 'wed', 'thu', 'fri']);
c.add('Spam',            '#4040FF', [ 5, 10, 20, 10, 40, 52, 68, 70, 70, 60]);
c.add('Innocent',        '#8080FF', [ 8,  7, 12, 20, 24, 16, 36, 28, 28, 45]);
c.add('Missed Spam',     '#A5A5FF', [ 8,  7, 12, 20, 24, 16, 36, 36, 18,  5]);
c.add('False Positives', '#DEDEFF', [ 1,  2,  3,  2,  1,  4, 18, 12,  8,  7]);
c.draw();
}

window.onload = function() {
ieCanvasInit('includes/iecanvas.htc');
draw();
};

サーバ側でソフトが動かなくても使えるのが便利ですね。

関連の記事検索:JavaScript, graph, Ajax
スポンサード リンク

By.KJ : 2006年08月22日 07:09 livedoor Readerで購読 Twitterに投稿

間違いの指摘をしていただける方はメール、あるいはTwitter/FBでお願いします(クリック)