「jqPlot」を使って円グラフを作成

Webサイトで円グラフ表示したいと要望があったので、以前使用したjqPlotでデモを作成しました。ダウンロード
最初の要望は「凡例つけて」、「いい感じにカラーリングしてほしい。」、「定期的に変更が伴うので、編集画面も」でした。
スクリプト
ベースとなるスタイルシート・スクリプト。excanvasは、IE8表示用です。
<script src="jquery.min.js" type="text/javascript"></script> <link href= "jquery.jqplot.min.css" type="text/css" rel="stylesheet"> <script src="jquery.jqplot.min.js" type="text/javascript"></script> <script src="excanvas.min.js" type="text/javascript"></script>
円グラフの表示用のpieRenderer
<script src="plugins/jqplot.pieRenderer.min.js" type="text/javascript"></script>
実装
<div id="div1033" style="height:400px; width:500px; margin:auto;"></div> <script> $(document).ready(function(){ // データ data = [[ ['United States', 12], ['France', 11], ['Russia', 9], ['United Kingdom', 7], ['Japan', 3], ['Belgium', 2], ['Others', 10] ]] // データラベル // データ配列の順にカンマ区切りで指定します。 datalabel = [ 'United States 12', 'France 11', 'Russia 9', 'United Kingdom 7', 'Japan 3', 'Belgium 2', 'Others 10' ] // 円グラフ配色 seriescolors = [ "#4472A6", "#AA4644", "#89A550", "#715891", "#4199AF", "#D08949", "#616161" ] // オプション option = { title: 'Fields Medalists (1936 - 2010)', // タイトル seriesDefaults: { renderer: jQuery.jqplot.PieRenderer, // 円グラフ用プラグイン rendererOptions: { dataLabels: datalabel, // データラベル showDataLabels: true, // データラベル表示有無 startAngle: -90 // 円グラフ基線位置 } }, seriesColors: seriescolors, legend: { show:true, location: 'e' } // 凡例 } // 作成実行 $.jqplot( 'div1033', data, option); }); </script>
「開始位置を変えてほしい」「凡例やめて、項目と値をグラフ内に表示」
- startAngle
円グラフの開始位置を0時にしました。("基線位置"なる名称みたいですが、正式には何でしょうね?)デフォルトが3時の方向のようですので、-90(度)することで設定(回転)できます。 - seriesColors
パイの配色を配列で順に指定できます。(表示データ) 円グラフの配色は、Power Pointの"fruit salad"を参考にしました。 - legend
「凡例」を英語でlegend。show:falseと指定することで非表示にできます。
円グラフ サンプル
CakePHP経由でDBアクセスして表示するデモです。コードもそちらに。
追加オプション
円グラフ ツールチップ
<!-- 追加で、jqplot.highlighter.min.jsを読み込みます--> <script src="plugins/jqplot.highlighter.min.js" type="text/javascript"></script>
オプションにhighlighterの設定を追加して下さい。
// オプション option = { highlighter: { show: true, // ツールチップを表示する useAxesFormatters: false, // 円グラフの場合falseに設定する formatString:'%s, %P', // ツールチップのフォーマット }, }
関連記事
-
-
スワイプ対応の画像スライダー・ギャラリー用プラグイン
画像スライダー(ギャラリー)を作成してくれるjQueryプラグインの中からスワイプ操作で画像をスライドできるものをいくつか集めてみました。 シンプルでカスタマイズ豊富なスライダー用プラグイン「b
-
-
様々なタイプのグラフ表示をカバーする「jqPlot」(折れ線グラフ)
Webページにグラフ表示する機会があったので、探してみました。 今回、使用してみた「jqPlot」がシンプルにもできてカスタマイズも豊富でいいです。グラフ用データの形式が少しクセがあり、動的に扱う際
-
-
シンプルでカスタマイズ豊富なスライダー用プラグイン「bxSlider」
「bxSlider」はシンプルに設置でき、かついろいろとオプションが設定可能なスライダー用プラグインです。サイト CDN 標準でもしくはオプションで実現できそうなこと スワイプ キャプション
-
-
「jqPlot」 カスタマイズ
以前、ここで使用した「jqPlot」ですが、色々なキーワードで訪問される方がいらっしゃったので、それを元ネタとして使わせてもらいカスタマイズ方法を紹介したいと思います。 以下4つのファイルへリンクし
-
-
ECサイトの商品表示に使えそうなスライダー「Simple Multi-Item Slider」
「Simple Multi-Item Slider」は、いうなればネスト型の画像スライダーです。ECサイトでの商品陳列からサムネイルメニューなどにも使用できそうです。ダウンロード デモ スクリプ
-
-
タブを画面サイズによってアコーディオンにしてくれる「Easy Responsive Tabs to Accordion」
「Easy Responsive Tabs to Accordion」はタブ表示を画面サイズによって折りたたみのアコーディオン形式に変換してくれるjQueryプラグインです。 デフォルトでは、768
-
-
テーブル・リスト要素を便利にしてくれるプラグイン
レスポンシブに対応したテーブルを実装できる「FooTable」 リストをインクリメント検索・ソートできる「List.js」 colResizable #カラム幅可変
-
-
テキストエリアを自動的にリサイズしてくれる「Autosize」
「Autosize」は、テキストエリアのサイズを入力文字数によって自動的に変更してくれるjQueryプラグインです。標準では、枠を超える文字数を入力するとスクロールバーが表示されますが、かわりに建増し
-
-
数値入力スライダー「jQuery Simple Slider」
「jQuery Simple Slider」はスライダーを使用して数値設定が行えるようにしてくれるjQueryプラグインです。"Unobtrusive Numerical Slider"とあるように余
-
-
カルーセル プラグイン
「カルーセル(Carousel)」とは"回転木馬"という意味らしいのですが、jQuery(Javascript)では画像やコンテンツをスライド表示させるもののようです。が、スライダーとの違いはよく分り
Comment
jQuery:「jqPlot」を使って円グラフを作成 | Think deeply, Do less, More effective http://bit.ly/12df0O2