- ランプの中身(Ruby on Railsのシステム開発)
- ランプの中身(Ruby on Railsのシステム開発)では、株式会社ケイビーエムジェイのRuby on Railsエンジニアが蓄積したノウハウを公開しています。Ruby on Railに関する技術解説や実践的なノウハウなど、開発現場の技術に則したコンテンツを随時追加していきます。 初心者の方でもわかりやすい技術解説を心がけています。リクエスト、ご質問も受け付けいますので、ご気軽にコメントを記述して下さい。
< Rails プラグイン : Rails ... | メイン | RJSを用いて、日付プルダウンメニューを... >
-
- 2008.02.19
Rails プラグイン : CSS Graphsの使い方(そしてちょっとだけ改造)
こんにちは。tnです。
今回はCSSによってグラフ表示を実現するCSS Graphsというプラグインを紹介したいと思います。
http://nubyonrails.com/pages/css_graphs
まずは
ruby script/plugin install http://topfunky.net/svn/plugins/css_graphs
でインストールしましょう。自動的に標準のRailsヘルパーになるそうです。
続いて、グラフに使う画像イメージをgeneratorを使ってコピーします。
ruby script/generate css_graphsこれで準備完了。あとは実際にグラフを貼りたいview上に
<%= bar_graph [['test1', 54],
['test2', 25],
['test3', 81]] %>
と記述すると、
こんなグラフを表示することが出来ます。
他に
<%= horizontal_bar_graph [['test1', 54],
['test2', 25],
['test3', 81]] %>
<%= complex_bar_graph [['test1', 54],
['test2', 25],
['test3', 81]] %>
といったグラフが生成できます。
また、ちょっと変り種として、multi_bar_graphというものもあります。
<% @data_for_graph = [
[['James',175],['John',180],['Thom',168],['Taro',200]],
[['James',60],['John',75],['Thom',52],['Taro',110]]
] %>
<%= multi_bar_graph @data_for_graph, {:width => 300,:height => 250}) do |index,variable|
url_for( :action => 'show', :id => index)
end %>
赤が身長で黄色が体重というデータ…のつもりです。それぞれのグラフはリンクになっていますので、この例の場合、各個人の詳細なプロフィールページに飛ばしてみるのもいいでしょう。
multi_bar_graphの第2引数にはグラフのオプションを記述します。
- :width => 枠の横幅
- :height => 枠の高さ
- :display_value_on_bar => trueのとき、各グラフの数値を表示。
- :colors => グラフの色を指定
- :color_by => 色分けを、グラフの種類毎('dimension')か、個別のデータ毎('index')から選ぶ。
なお、このプラグインを扱う上での注意は、
- グラフは1ページに1つしか作れない
表示位置がかぶったりするようです。 - グラフに用いる値は0-100の間
基本的にパーセンテージを表すグラフのためでしょうか。
ちょっと改造してみる
ところで、ひとつ気になったのが、bar_graphのグラフ枠の横幅。
これは、どうやらグラフの棒が5本であること前提のようです。
6本で試すと、
この通り、なんとなく残念な表示になってしまいます。
そこで、vendor/plugins/css_graphs/lib/css_graphs.rbをエディタで開き、以下のように書き換えます(抜粋/12行目辺り)。
def bar_graph(data=[])
width = 378
height = 150
colors = %w(#ce494a #efba29 #efe708 #5a7dd6 #73a25a)
after
def bar_graph(data=[])
width = 76 * data.size
height = 150
colors = %w(#ce494a #efba29 #efe708 #5a7dd6 #73a25a) * (((data.size - 1)/5)+1)
そうすると、
いい感じになりました!
そのままの状態ではちょっと使いづらいなと思うプラグインも、ちょこっと手を加えてみるとより良くなりますね。それでは、また。
トラックバック URL
この記事にコメントする
TOPICS
2008/06/25
「ZD Net Builder」の連載記事です。第四回は「Rubyでどう書く?:重複したRSSをまとめる」が掲載されました。
2008/05/30
「ZD Net Builder」の連載記事です。第三回は「Rubyでどう書く?:Rubyで特定URLの画像パス一覧を表示する」が掲載されました。
2008/05/07
「ZD Net Builder」に連載を始めました。第二回は「Rubyでどう書く?:RubyでPDF履歴書を作成する」が掲載されました。
2008/04/24
「アットマーク・アイティ」に『 Rubyを使ってPaSoRi経由でSuicaの乗車履歴を取得し、GoogleMapsやGoogleEarthで表示する』が掲載されました。
RoR最新ブログ一覧
カテゴリ
全体のRoR最新ブログ一覧
- Cybozuのスケジュールをmobileme経由でiPhone 3Gに取り込む
- 今週のRuby on Rails最新情報
- Rubyでどう書く?:RubyでWord文書を作成する
- タニタさんの「からだカルテ」を使ってみました
- iPhoneを確保しました
- Edge Railsの最新情報
- Rubyのセキュリティ脆弱性
- mysqlでレコードの中身を一括置換する方法
- 同じappでDBを使い分ける
- Rubyでどう書く?:重複したRSSをまとめる
- TABLEに直接データを入れる便利な方法
- 社内SNSをiPhoneで快適に見るためのCSSを書いてみた
- phpmyadminをセキュアにアクセスする方法
- Rubyプログラムの組み方から、Exeファイルの作成まで
- Ruby、Railsインストール for MacOSX
- will_paginageを使ってみた
- dmgファイルの作り方
- PHP携帯電話の機種情報取得
- Rubyでどう書く?:Rubyで特定URLの画像パス一覧を表示する
- リファラでアクセス制限をしてみた。
- 奇妙な演算子
- RJSを用いて、日付プルダウンメニューを書き換える (2
- railsの実行モードの設定 RAILS_ENV
- postgresでのユーザ権限付与(psql, grant)
- ドロップダウンに簡単にオートコンプリート機能を追加する方法
- Vimの自動補完
- IE6 以前で float に指定した margin が 2 倍になる現象を解消する
- サーバ監視ソフトウェア「ganglia」を使ってみる
- 監視ツールcactiについて
- Rubyでどう書く?:RubyでPDF履歴書を作成する
- グラフを作ってみるか!?
- clearfixでfloat解除
- SELinux無効にしてみる
- Rubyのソースコードから HTML Helpを生成してみよう!
- IEでダイジェスト認証をかけるとエラーになった。
- muninのインストール 〜監視ツールって〜
- Rubyでどう書く?:連続した数列を範囲形式にまとめたい
- RJSを用いて、日付プルダウンメニューを書き換える
- Passenger (mod_rails for apache)での色んな設定値について調べてみた
- docomo の罠
- ローカルで動画変換をする方法
- MacOSにpostgreSQL 8.3をインストール
- Postgres8_3⇔8_1の性能比較してみました
- rake db:migrate すると undefined method `last' for {}:Hash と出る
- ケータイWebサイトに携わっている方へ
- MySQL最大バッファサイズの設定
- railsのand/orを使った機能
- Railsライクなフレームワーク「CakePHP」②
- エラー表示で意図しない改行を解消する−fieldWithErrors、ActionView::Base、field_error_proc
- [mysqlのベンチマーク]MyBenchの設定
- Rubyのコマンドライン引数と環境変数について(初心者向け)
- Rubyを使ってPaSoRi経由でSuicaの乗車履歴を取得し、GoogleMapsやGoogleEarthで表示する
- 簡単&便利 Capistranoのススメ (導入編)
- Rails的コメントアウト
- 使えるvalidate一覧
- せっかくなので、Thin を使って実践
- Xenを用いてCentOS上に仮想CentOSを2つインストールする
- aptanaでrailsをデバッグ実行する
- empty?とblank?の違いって?
- ローカルでコマンドを打つとアスタリスクで囲まれたエラーが出る
- rubyの便利ツールirbをカスタマイズしてみた
- 実行モード "environment"設定の基本
- RadRails(Aptana)のショートカット
- JRubyを触ってみた
- mongrelとの戦い〜503エラー?mongrelが死んだってことさ…
- sshでrootログインの禁止
- database.ymlの設定方法
- Railsライクなフレームワーク「CakePHP」①
- Rails導入でRuby標準クラスへ追加される関数達(String編)
- Rubyのマニュアルを手軽に参照する方法
- railsで画像などファイルをアップロードする方法
- 遠隔地のチョロQを操縦する方法 with JavaScript, AJAX, Rails, Gainer, Webカメラ, and USTREAM.TV
- Ruby on Railsで作られたradMineのカスタマイズ1 ~インストール編~
- MacBook AirのレビューとLet's noteとの比較
- Rails プラグイン : CSS Graphsの使い方(そしてちょっとだけ改造)
- Railsの開発でscreenを使う理由
- ActiveRecordのconditionsを綺麗に書くTips2つ
- [Rails 2.0]起動時のファイルの読み込みの順番がわかった!
- RailsのActionMailer(Tmail)でドットの連続などのRFC違反している携帯メールアドレスに対応する
- スパムを消して消して、もう消しまくって こうなりました。
- Ruby on Railsでacts_as_paranoidを使い倒す
- fastladderをrailroadで図を作ってみる。
- [書評] 他言語開発経験者でも、初心者でも、本屋で「チラ見」して確認してみよう
- ヘルパーメソッド
- Ruby標準csv遅い
- Linux2.6系の脆弱性でroot権限奪ってみた
- railsで開発したダイエットサイトとそのソースコード
- fastladderを試してみました ~rails2.0~
- HeartBeatの設定
- Railsの手動インストール
- Railsで「Lost connection to MySQL server during query」に遭遇した場合の対策
- RadiantCMSのインストール(2)
- Linuxとかのbashで使えるショートカットキーをまとめた一覧
- 長い文字列をカットして表示するプログラム
- SLこまんどの設定
- Rails プラグイン : Rails Widgets >Tabnavの使い方
- Scaffoldはどこからくるの? 後編
- ローカルメールサーバーでRailsでのメール受信のテストを便利に
- HTMLエスケープ
- aptanaのインストールと使い方について
- railroadを用いたER図作成
- RailsでAmazon APIを利用する
- ちょっとしたスペルミスなどで、時間を無駄にした経験があるなら ( カラー表示で編集しやすく )
- ちょー入門、Webサーバ構築で知ってて損をしない用語(2)
- Ruby on Rails ってなになに?
- 最近!流行りの、「Ruby」 知ってますか?
- RubyGems って単語よく出てきますよね?
- CentOS5とaptanaを使ったWindows開発環境 1
- gemコマンドの紹介
- ちょー入門、Webサーバ構築で知ってて損をしない用語(1)
- こんな人がこのブログを書いて・・・
- RadiantCMSのインストール(1)
- RubyでActiveRecordを使わないでDBに接続する方法
- Railsのキャッシュ機能を用いて動的ページを静的ページにする方法を紹介
- Rails 2.0のセキュリティ面の変更点
- DRBDのインストール
- Rails プラグイン : ColumnCommentsの使い方
- Scaffoldはどこからくるの? 前編
- RMagickの使い方
- Ruby on Rails インストール for Windows
プロフィール
- tn
- 新人エンジニアtnです。
このブログでは主にRuby on Railsのプラグインの紹介をして行きます。
開発の手助けになれば幸いです。
■開発環境
OS
・自宅ではUbuntu on VMware on Windows XP
・会社ではMac OS X
Rails
・1.2.5
ブログは主に自宅で書いています。



