GWTGoogleチャート-クイックガイド

Google Chartsは、インタラクティブなグラフ作成機能を追加することでWebアプリケーションを強化することを目的とした純粋なJavaScriptベースのグラフ作成ライブラリです。幅広いチャートをサポートします。グラフは、Chrome、Firefox、Safari、Internet Explorer(IE)などの標準的なブラウザでSVGを使用して描画されます。従来のIE6では、VMLを使用してグラフィックを描画します。

Google Chart Java ModuleはオープンソースのJavaベースのライブラリであり、GWTアプリケーション内でエレガントで機能豊富なGoogle Chartsの視覚化を提供し、GWTウィジェットライブラリと一緒に使用できます。GWTアプリケーション内の適切な例とともに、GoogleChartsのすべての基本コンポーネントについて説明する章があります。

特徴

以下は、GoogleChartsライブラリの主な機能です。

  • Compatability −AndroidやiOSなどのすべての主要なブラウザとモバイルプラットフォームで動作するように見えます。

  • Multitouch Support−AndroidやiOSなどのタッチスクリーンベースのプラットフォームでマルチタッチをサポートします。iPhone / iPadおよびAndroidベースのスマートフォン/タブレットに最適です。

  • Free to Use −オープンソースであり、非営利目的で自由に使用できます。

  • Lightweight − loader.jsコアライブラリは、非常に軽量なライブラリです。

  • Simple Configurations − jsonを使用してチャートのさまざまな構成を定義し、習得と使用が非常に簡単です。

  • Dynamic −チャート生成後でもチャートを変更できます。

  • Multiple axes− x、y軸に限定されません。チャート上の複数の軸をサポートします。

  • Configurable tooltips−ツールチップは、ユーザーがチャート上の任意のポイントにカーソルを合わせると表示されます。googlechartsは、ツールチップをプログラムで制御するためのツールチップ組み込みフォーマッターまたはコールバックフォーマッターを提供します。

  • DateTime support−日時を特別に処理します。日付ごとのカテゴリに対する多数の組み込みコントロールを提供します。

  • Print −Webページを使用してチャートを印刷します。

  • External data−サーバーからの動的なデータのロードをサポートします。コールバック関数を使用してデータを制御します。

  • Text Rotation −任意の方向へのラベルの回転をサポートします。

サポートされているチャートタイプ

Google Chartsライブラリは、次の種類のグラフを提供します-

シニア番号 チャートタイプ/説明
1

Line Charts

線/スプラインベースのチャートを描画するために使用されます。

2

Area Charts

エリアごとのグラフを描画するために使用されます。

3

Pie Charts

円グラフの描画に使用されます。

4

Sankey Charts, Scatter Charts, Stepped area charts, Table, Timelines, TreeMap, Trendlines

散在するチャートを描画するために使用されます。

5

Bubble Charts

バブルベースのチャートを描画するために使用されます。

6

Dynamic Charts

ユーザーがグラフを変更できる動的なグラフを描画するために使用されます。

7

Combinations

さまざまなチャートの組み合わせを描画するために使用されます。

8

3D Charts

3Dチャートの描画に使用されます。

9

Angular Gauges

スピードメータータイプのチャートを描くために使用されます。

10

Heat Maps

ヒートマップの描画に使用されます。

11

Tree Maps

ツリーマップの描画に使用されます。

次の章では、上記の各タイプのチャートについて、例を挙げて詳細に説明します。

ライセンス

Google Chartsはオープンソースであり、無料で使用できます。リンクをたどってください:利用規約。

このチュートリアルでは、GoogleChartsとGWTFrameworkを使用して作業を開始するための開発環境を準備する方法について説明します。このチュートリアルでは、GWT Frameworkをセットアップする前に、マシンにJDK、Tomcat、Eclipseをセットアップする方法についても説明します。

システム要件

GWTにはJDK1.6以降が必要であるため、最初の要件はJDKをマシンにインストールすることです。

JDK 1.6以上。
記憶 最小要件はありません。
ディスクスペース 最小要件はありません。
オペレーティング・システム 最小要件はありません。

与えられた手順に従って、GWTアプリケーション開発を開始するための環境をセットアップします。

ステップ1-マシンへのJavaのインストールを確認する

次に、コンソールを開き、次のJavaコマンドを実行します。

OS 仕事 コマンド
Windows コマンドコンソールを開く c:\> java -version
Linux コマンドターミナルを開く $ java -version
Mac オープンターミナル マシン:〜joseph $ java -version

すべてのオペレーティングシステムの出力を確認しましょう

シニア番号 OSと生成された出力
1

Windows

Javaバージョン "1.6.0_21"

Java(TM)SEランタイム環境(ビルド1.6.0_21-b07)

Java HotSpot(TM)クライアントVM(ビルド17.0-b17、混合モード、共有)

2

Linux

Javaバージョン "1.6.0_21"

Java(TM)SEランタイム環境(ビルド1.6.0_21-b07)

ava HotSpot(TM)クライアントVM(ビルド17.0-b17、混合モード、共有)

3

Mac

Javaバージョン "1.6.0_21"

Java(TM)SEランタイム環境(ビルド1.6.0_21-b07)

Java HotSpot(TM)64ビットサーバーVM(ビルド17.0-b17、混合モード、共有)

ステップ2-JavaDevelopment Kit(JDK)をセットアップする

Javaがインストールされていない場合は、OracleのJavaサイトであるJava SE DownloadsからJavaソフトウェア開発キット(SDK)をインストールできます。ダウンロードしたファイルにJDKをインストールする手順が記載されています。所定の手順に従って、セットアップをインストールおよび構成してください。最後に、PATHおよびJAVA_HOME環境変数を設定して、javaおよびjavacを含むディレクトリ(通常はそれぞれjava_install_dir / binおよびjava_install_dir)を参照します。

をセットする JAVA_HOMEJavaがマシンにインストールされているベースディレクトリの場所を指す環境変数。例えば

シニア番号 OSと出力
1

Windows

環境変数JAVA_HOMEをC:\ Program Files \ Java \ jdk1.6.0_21に設定します

2

Linux

export JAVA_HOME = / usr / local / java-current

3

Mac

export JAVA_HOME = / Library / Java / Home

Javaコンパイラの場所をシステムパスに追加します。

シニア番号 OSと出力
1

Windows

文字列;%JAVA_HOME%\ binをシステム変数Pathの最後に追加します。

2

Linux

export PATH = $ PATH:$ JAVA_HOME / bin /

3

Mac

必要ありません

または、Borland JBuilder、Eclipse、IntelliJ IDEA、Sun ONE Studioなどの統合開発環境(IDE)を使用している場合は、簡単なプログラムをコンパイルして実行し、IDEがJavaのインストール場所を認識していることを確認します。それ以外の場合は、所定のドキュメントに従って適切なセットアップを行います。 IDEの。

ステップ3-EclipseIDEをセットアップする

このチュートリアルのすべての例は、EclipseIDEを使用して作成されています。したがって、オペレーティングシステムに基づいて最新バージョンのEclipseをマシンにインストールすることをお勧めします。

Eclipse IDEをインストールするには、から最新のEclipseバイナリをダウンロードします。 https://www.eclipse.org/downloads/。インストールをダウンロードしたら、バイナリディストリビューションを便利な場所に解凍します。たとえば、WindowsのC:\ eclipse、またはLinux / Unixの/ usr / local / eclipseで、最後にPATH変数を適切に設定します。

Eclipseは、Windowsマシンで次のコマンドを実行することで起動できます。または、eclipse.exeをダブルクリックするだけです。

%C:\eclipse\eclipse.exe

Eclipseは、Unix(Solaris、Linuxなど)マシンで次のコマンドを実行することで起動できます。

$/usr/local/eclipse/eclipse

起動が成功した後、すべてが正常であれば、結果が表示されます

ステップ4:Eclipse用のGWTSDKとプラグインをインストールする

リンクPluginfor Eclipse(SDKを含む)に記載されている手順に従って、GWTSDKとPluginforEclipseバージョンをマシンにインストールします。

GWTプラグインのセットアップが成功した後、すべてが正常であれば、次の画面が表示されます。 Google icon 赤い長方形でマークされています。

ステップ5:GoogleChartsをインストールする

MVNリポジトリページから最新のGoogleCharts jarをダウンロードし、プロジェクトのクラスパスに追加します。

<project-name> .gwt.xmlファイルに次のエントリを追加します

<inherits name = "com.googlecode.gwt.charts.Charts"/>

この章では、GWTでGoogle ChartsAPIを使用してグラフを描画するために必要な構成を紹介します。

ステップ1:GWTアプリケーションを作成する

次の手順に従って、GWTで作成したGWTアプリケーションを更新します-アプリケーションの作成の章-

ステップ 説明
1 GWT-アプリケーションの作成の章で説明されているように、パッケージcom.tutorialspointの下にHelloWorldという名前のプロジェクトを作成します
2 以下で説明するように、HelloWorld.gwt.xmlHelloWorld.html、およびHelloWorld.javaを変更します。残りのファイルは変更しないでください。
3 アプリケーションをコンパイルして実行し、実装されたロジックの結果を確認します。

変更されたモジュール記述子の内容は次のとおりです src/com.tutorialspoint/HelloWorld.gwt.xml

<?xml version = "1.0" encoding = "UTF-8"?>
<module rename-to = 'helloworld'>
   <inherits name = 'com.google.gwt.user.User'/>
   <inherits name = 'com.google.gwt.user.theme.clean.Clean'/>
   <entry-point class = 'com.tutorialspoint.client.HelloWorld'/>
   <inherits name="com.googlecode.gwt.charts.Charts"/>
   <source path = 'client'/>
   <source path = 'shared'/>
</module>

以下は、変更されたHTMLホストファイルの内容です。 war/HelloWorld.html

<html>
   <head>
      <title>GWT Highcharts Showcase</title>
      <link rel = "stylesheet" href = "HelloWorld.css"/>
      <script language = "javascript" src = "helloworld/helloworld.nocache.js">
   </head>
   <body>    
   </body>
</html>

構成を理解した後、最後に更新されたHelloWorld.javaが表示されます。

ステップ2:構成を作成する

ライブラリをロードしてチャートを作成する

ChartLoaderを使用してライブラリをロードしてから、チャートを作成します。

ChartLoader chartLoader = new ChartLoader(ChartPackage.CORECHART);
chartLoader.loadApi(new Runnable() {
   public void run() {
      // Create and attach the chart
      PieChart chart = new PieChart();           
   } 
});

データ表

データテーブルを作成して詳細を設定します。

// Prepare the data
DataTable data = DataTable.create();
data.addColumn(ColumnType.STRING, "Browser");
data.addColumn(ColumnType.NUMBER, "Percentage");
data.addRow("Firefox", 45.0);
data.addRow("IE", 26.8);
data.addRow("Chrome", 12.8);
data.addRow("Safari", 8.5);
data.addRow("Opera", 6.2);
data.addRow("Others", 0.7);

// Draw the chart
chart.draw(data);

サイズ

設定する幅と高さを設定します。

chart.setWidth("700px");
chart.setHeight("700px");

手順3:グラフを親パネルに追加します。

チャートをルートパネルに追加しています。

RootPanel.get().add(chart);

構成構文をさらに理解するために、次の例を検討してください。

HelloWorld.java

package com.tutorialspoint.client;

import com.google.gwt.core.client.EntryPoint;
import com.google.gwt.user.client.ui.RootPanel;
import com.googlecode.gwt.charts.client.ChartLoader;
import com.googlecode.gwt.charts.client.ChartPackage;
import com.googlecode.gwt.charts.client.ColumnType;
import com.googlecode.gwt.charts.client.DataTable;
import com.googlecode.gwt.charts.client.corechart.PieChart;

public class HelloWorld implements EntryPoint {
   private PieChart chart;

   private void initialize() {
      ChartLoader chartLoader = new ChartLoader(ChartPackage.CORECHART);
      chartLoader.loadApi(new Runnable() {
         public void run() {
            // Create and attach the chart
            chart = new PieChart();
            RootPanel.get().add(chart);
            draw();
         }
      });
   }
   private void draw() {
      // Prepare the data
      DataTable data = DataTable.create();
      data.addColumn(ColumnType.STRING, "Browser");
      data.addColumn(ColumnType.NUMBER, "Percentage");
      data.addRow("Firefox", 45.0);
      data.addRow("IE", 26.8);
      data.addRow("Chrome", 12.8);
      data.addRow("Safari", 8.5);
      data.addRow("Opera", 6.2);
      data.addRow("Others", 0.7);

      // Draw the chart
      chart.draw(data);
      chart.setWidth("400px");
      chart.setHeight("400px");
   }
   public void onModuleLoad() {
      initialize();
   }
}

結果

結果を確認します。

面グラフは、面積ベースのグラフを描画するために使用されます。このセクションでは、次のタイプのエリアベースのグラフについて説明します。

シニア番号 チャートタイプ/説明
1 基本エリア

基本面グラフ

2 負の値の領域

負の値を持つ面グラフ。

3 スタックエリア

領域が互いに積み重なっているチャート。

4 ポイントが欠けているエリア

データに欠落しているポイントがあるグラフ。

棒グラフは、棒ベースのグラフを描画するために使用されます。このセクションでは、次のタイプの棒グラフに基づいたグラフについて説明します。

シニア番号 チャートタイプ/説明
1 ベーシックバー

基本的な棒グラフ

2 グループ化された棒グラフ

グループ化された棒グラフ。

3 スタックドバー

バーが重なり合った棒グラフ。

4 ネガティブバー

負のスタックを持つ棒グラフ。

5 差分棒グラフ

違いを示す棒グラフ。

バブルチャートは、バブルベースのチャートを描画するために使用されます。このセクションでは、次のタイプのバブルベースのチャートについて説明します。

シニア番号 チャートタイプ/説明
1 ベーシックバブル

基本的なバブルチャート。

2 データラベル付きのバブルチャート

データラベル付きのバブルチャート。

ローソク足チャートは、値の分散に対する始値と終値を示すために使用され、通常は株式を表すために使用されます。このセクションでは、次のタイプのローソク足ベースのチャートについて説明します。

シニア番号 チャートタイプ/説明
1 基本的なローソク足

基本的なローソク足チャート。

2 カスタマイズされた色のローソク足

カスタマイズされたローソク足チャート。

カラムチャートは、カラムベースのチャートを描画するために使用されます。このセクションでは、次のタイプの列ベースのグラフについて説明します。

シニア番号 チャートタイプ/説明
1 基本コラム

基本的な列チャート

2 グループ化された縦棒グラフ

グループ化された列チャート。

3 積み上げ列

柱が互いに積み重なっている柱チャート。

4 負のスタック列

負のスタックを持つ列チャート。

5 差分縦棒グラフ

違いを示す列チャート。

組み合わせチャートは、各シリーズを次のリストの異なるマーカータイプとしてレンダリングするのに役立ちます:線、領域、棒、ローソク足、および階段状領域。シリーズにデフォルトのマーカータイプを割り当てるには、seriesTypeプロパティを使用します。Seriesプロパティは、各シリーズのプロパティを個別に指定するために使用されます。以下は、違いを示す縦棒グラフの例です。

Google Chartsの構成構文の章で、グラフの描画に使用される構成についてはすでに説明しました。ここで、違いを示す縦棒グラフの例を見てみましょう。

構成

使用しました ComboChart 組み合わせチャートを表示するクラス。

// Combination chart
ComboChart chart = new ComboChart();

HelloWorld.java

package com.tutorialspoint.client;

import com.google.gwt.core.client.EntryPoint;
import com.google.gwt.user.client.ui.RootPanel;

import com.googlecode.gwt.charts.client.ChartLoader;
import com.googlecode.gwt.charts.client.ChartPackage;
import com.googlecode.gwt.charts.client.ColumnType;
import com.googlecode.gwt.charts.client.DataTable;
import com.googlecode.gwt.charts.client.corechart.ComboChart;
import com.googlecode.gwt.charts.client.corechart.ComboChartOptions;
import com.googlecode.gwt.charts.client.corechart.ComboChartSeries;
import com.googlecode.gwt.charts.client.options.HAxis;
import com.googlecode.gwt.charts.client.options.SeriesType;
import com.googlecode.gwt.charts.client.options.VAxis;

public class HelloWorld implements EntryPoint {
   private ComboChart chart;

   private void initialize() {
      ChartLoader chartLoader = new ChartLoader(ChartPackage.CORECHART);
      chartLoader.loadApi(new Runnable() {
         public void run() {
            // Create and attach the chart
            chart = new ComboChart();
            RootPanel.get().add(chart);
            draw();
         }
      });
   }
   private void draw() {
      // Prepare the data
      DataTable data = DataTable.create();
      data.addColumn(ColumnType.STRING, "Fruits");
      data.addColumn(ColumnType.NUMBER, "Jane");
      data.addColumn(ColumnType.NUMBER, "Jone");
      data.addColumn(ColumnType.NUMBER, "Average");
      
      data.addRow("Apples", 3, 2, 2.5);
      data.addRow("Oranges",2, 3, 2.5);
      data.addRow("Pears", 1, 5, 3);
      data.addRow("Bananas", 3, 9, 6);    		
      data.addRow("Plums", 4, 2, 3);    
      
      // Set options
      ComboChartOptions options = ComboChartOptions.create();
      options.setTitle("Fruits distribution");
      options.setHAxis(HAxis.create("Person"));
      options.setVAxis(VAxis.create("Fruits"));
      options.setSeriesType(SeriesType.BARS);

      ComboChartSeries lineSeries = ComboChartSeries.create();
      lineSeries.setType(SeriesType.LINE);
      options.setSeries(2,lineSeries);

      // Draw the chart
      chart.draw(data,options);
      chart.setWidth("400px");
      chart.setHeight("400px");
   }
   public void onModuleLoad() {
      initialize();
   }
}

結果

結果を確認します。

ヒストグラムは、数値データをバケットにグループ化し、バケットをセグメント化された列として表示するグラフです。これらは、値が範囲に入る頻度としてデータセットの分布を表すために使用されます。Google Chartsは、バケットの数を自動的に選択します。すべてのバケットの幅は等しく、高さはバケット内のデータポイントの数に比例します。ヒストグラムは、他の点では縦棒グラフに似ています。このセクションでは、次のタイプのヒストグラムベースのグラフについて説明します。

シニア番号 チャートタイプ/説明
1 基本ヒストグラム

基本的なヒストグラムチャート。

2 色の制御

ヒストグラムチャートのカスタマイズされた色。

3 バケットの制御

ヒストグラムチャートのカスタマイズされたバケット。

4 複数シリーズ

複数のシリーズを持つヒストグラムチャート。

折れ線グラフは、折れ線ベースのグラフを描画するために使用されます。このセクションでは、次のタイプの線ベースのグラフについて説明します。

シニア番号 チャートタイプ/説明
1 ベーシックライン

基本的な折れ線グラフ。

2 目に見える点で

目に見えるデータポイントのあるグラフ。

3 カスタマイズ可能な背景色

カスタマイズされた背景色のチャート。

4 カスタマイズ可能な線の色

カスタマイズされた線の色のグラフ。

5 カスタマイズ可能な軸と目盛りラベル

カスタマイズされた軸と目盛りのラベルが付いたグラフ。

6 十字線

選択時のデータポイントの十字線を示す折れ線グラフ。

7 カスタマイズ可能なラインスタイル

カスタマイズされた線の色のグラフ。

8 曲線の折れ線グラフ

滑らかな曲線のチャート。

Google Map Chartは、Google MapsAPIを使用して地図を表示します。データ値は、マップ上にマーカーとして表示されます。データ値は、座標(孤立電子対)または実際のアドレスの場合があります。識別されたすべてのポイントが含まれるように、マップはそれに応じて拡大縮小されます。

シニア番号 チャートタイプ/説明
1 基本マップ

基本的なグーグルマップ。

2 緯度/経度を使用した地図

緯度と経度を使用して指定された場所を持つマップ。

以下は、組織図の例です。

組織図は、組織内の上位/下位の関係を表すために使用されるノードの階層をレンダリングするのに役立ちます。たとえば、家系図は組織図の一種です。Google Chartsの構成構文の章で、グラフの描画に使用される構成についてはすでに説明しました。それでは、組織図の例を見てみましょう。

構成

使用しました OrgChart 組織図を表示するクラス。

// Organization chart
OrgChart chart = new OrgChart();

HelloWorld.java

package com.tutorialspoint.client;

import com.google.gwt.core.client.EntryPoint;
import com.google.gwt.user.client.ui.RootPanel;

import com.googlecode.gwt.charts.client.ChartLoader;
import com.googlecode.gwt.charts.client.ChartPackage;
import com.googlecode.gwt.charts.client.ColumnType;
import com.googlecode.gwt.charts.client.DataTable;
import com.googlecode.gwt.charts.client.format.PatternFormat;
import com.googlecode.gwt.charts.client.orgchart.OrgChart;
import com.googlecode.gwt.charts.client.orgchart.OrgChartOptions;

public class HelloWorld implements EntryPoint {
   private OrgChart chart;

   private void initialize() {
      ChartLoader chartLoader = new ChartLoader(ChartPackage.ORGCHART);
      chartLoader.loadApi(new Runnable() {
         public void run() {
            // Create and attach the chart
            chart = new OrgChart();
            RootPanel.get().add(chart);
            draw();
         }
      });
   }
   private void draw() {
      // Prepare the data
      DataTable dataTable = DataTable.create();
      dataTable.addColumn(ColumnType.STRING, "Name");
      dataTable.addColumn(ColumnType.STRING, "Manager");
      dataTable.addColumn(ColumnType.STRING, "ToolTip");
      dataTable.addRows(5);

      dataTable.setValue(0, 0, "Mike");
      dataTable.setValue(0, 1, "");
      dataTable.setValue(0, 2, "The President");
      dataTable.setValue(1, 0, "Jim");
      dataTable.setValue(1, 1, "Mike");
      dataTable.setValue(1, 2, "VP");
      dataTable.setValue(2, 0, "Alice");
      dataTable.setValue(2, 1, "Mike");
      dataTable.setValue(2, 2, "");
      dataTable.setValue(3, 0, "Bob");
      dataTable.setValue(3, 1, "Jim");
      dataTable.setValue(3, 2, "Bob Sponge");
      dataTable.setValue(4, 0, "Carol");
      dataTable.setValue(4, 1, "Bob");
      dataTable.setValue(4, 2, "");

      PatternFormat format = PatternFormat.create("{0} {1}");
      format.format(dataTable, 0, 2);

      // Set options
      OrgChartOptions options = OrgChartOptions.create();
      options.setAllowHtml(true);

      // Draw the chart
      chart.draw(dataTable, options);
      chart.setWidth("400px");
      chart.setHeight("400px");
   }
   public void onModuleLoad() {
      initialize();
   }
}

結果

結果を確認します。

円グラフは、円ベースのグラフを描画するために使用されます。このセクションでは、次の種類の円ベースのグラフについて説明します。

シニア番号 チャートタイプ/説明
1 ベーシックパイ

基本的な円グラフ。

2 ドーナツグラフ

ドーナツグラフ。

3 3D円グラフ

3D円グラフ。

4 分解されたスライスの円グラフ

分解されたスライスの円グラフ。

サンキーチャートは視覚化ツールであり、ある値のセットから別のセットへのフローを表すために使用されます。接続されたオブジェクトはノードと呼ばれ、接続はリンクと呼ばれます。Sankeysは、2つのドメイン間、または一連のステージを介した複数のパス間の多対多のマッピングを示すために使用されます。

シニア番号 チャートタイプ/説明
1 基本的なサンキーチャート

基本的なサンキーチャート。

2 マルチレベルサンキーチャート

マルチレベルサンキーチャート。

3 サンキーチャートのカスタマイズ

カスタマイズされたサンキーチャート。

以下は、散布図の例です。

Google Chartsの構成構文の章で、グラフの描画に使用される構成についてはすでに説明しました。ここで、散布図の例を見てみましょう。

構成

使用しました ScatterChart 散布図を表示するクラス。

ScatterChart chart = new ScatterChart();

HelloWorld.java

package com.tutorialspoint.client;

import com.google.gwt.core.client.EntryPoint;
import com.google.gwt.user.client.ui.RootPanel;

import com.googlecode.gwt.charts.client.ChartLoader;
import com.googlecode.gwt.charts.client.ChartPackage;
import com.googlecode.gwt.charts.client.ColumnType;
import com.googlecode.gwt.charts.client.DataTable;
import com.googlecode.gwt.charts.client.corechart.ScatterChart;
import com.googlecode.gwt.charts.client.corechart.ScatterChartOptions;

public class HelloWorld implements EntryPoint {
   private ScatterChart chart;

   private void initialize() {
      ChartLoader chartLoader = new ChartLoader(ChartPackage.CORECHART);
      chartLoader.loadApi(new Runnable() {
         public void run() {
            // Create and attach the chart
            chart = new ScatterChart();
            RootPanel.get().add(chart);
            draw();
         }
      });
   }
   private void draw() {
      // Prepare the data
      DataTable data = DataTable.create();
      data.addColumn(ColumnType.NUMBER, "Age");
      data.addColumn(ColumnType.NUMBER, "Weight");

      data.addRow(8,12);
      data.addRow(4, 5.5);
      data.addRow(11,14);
      data.addRow(4,5);
      data.addRow(3,3.5);
      data.addRow(6.5,7);

      ScatterChartOptions options  = ScatterChartOptions.create();
      options.setTitle("Age vs Weight");
      options.setLegend(null);
      
      // Draw the chart
      chart.draw(data, options);
      chart.setWidth("400px");
      chart.setHeight("400px");
   }
   public void onModuleLoad() {
      initialize();
   }
}

結果

結果を確認します。

ステップ面グラフは、ステップベースの面グラフです。次のタイプの階段状面グラフについて説明します。

シニア番号 チャートタイプ/説明
1 基本的なステップチャート

基本的な段付き面グラフ。

2 積み上げステップチャート

積み上げ階段状面グラフ。

テーブルチャートは、並べ替えやページングが可能なテーブルのレンダリングに役立ちます。表のセルは、フォーマット文字列を使用するか、セル値としてHTMLを直接挿入することによってフォーマットできます。数値はデフォルトで右揃えになっています。ブール値は、チェックマークまたはクロスマークとして表示されます。ユーザーは、キーボードまたはマウスを使用して単一の行を選択できます。列ヘッダーは並べ替えに使用できます。スクロール中、ヘッダー行は固定されたままです。テーブルは、ユーザーの操作に対応するイベントを発生させます。

Google Chartsの構成構文の章で、グラフの描画に使用される構成についてはすでに説明しました。それでは、テーブルチャートの例を見てみましょう。

構成

使用しました Table テーブルチャートを表示するクラス。

Table chart = new Chart();

HelloWorld.java

package com.tutorialspoint.client;

import com.google.gwt.core.client.EntryPoint;
import com.google.gwt.user.client.ui.RootPanel;

import com.googlecode.gwt.charts.client.ChartLoader;
import com.googlecode.gwt.charts.client.ChartPackage;
import com.googlecode.gwt.charts.client.ColumnType;
import com.googlecode.gwt.charts.client.DataTable;
import com.googlecode.gwt.charts.client.table.Table;
import com.googlecode.gwt.charts.client.table.TableOptions;

public class HelloWorld implements EntryPoint {
   private Table chart;

   private void initialize() {
      ChartLoader chartLoader = new ChartLoader(ChartPackage.TABLE);
      chartLoader.loadApi(new Runnable() {
         public void run() {
            // Create and attach the chart
            chart = new Table();
            RootPanel.get().add(chart);
            draw();
         }
      });
   }
   private void draw() {
      // Prepare the data
      DataTable dataTable = DataTable.create();
      dataTable.addColumn(ColumnType.STRING, "Name");
      dataTable.addColumn(ColumnType.NUMBER, "Salary");
      dataTable.addColumn(ColumnType.BOOLEAN, "Full Time Employee");
      dataTable.addRows(4);
      
      dataTable.setCell(0, 0, "Mike");
      dataTable.setCell(0, 1, 10000, "$10,000");
      dataTable.setCell(0, 2, true);
      dataTable.setCell(1, 0, "Jim");
      dataTable.setCell(1, 1, 8000, "$8,000");
      dataTable.setCell(1, 2, false);
      dataTable.setCell(2, 0, "Alice");
      dataTable.setCell(2, 1, 12500, "$12,500");
      dataTable.setCell(2, 2, true);
      dataTable.setCell(3, 0, "Bob");
      dataTable.setCell(3, 1, 7000, "$7,000");
      dataTable.setCell(3, 2, true);

      TableOptions options  = TableOptions.create();
      options.setAlternatingRowStyle(true);
      options.setShowRowNumber(true);
      
      // Draw the chart
      chart.draw(dataTable, options);
      chart.setWidth("400px");
      chart.setHeight("400px");
   }
   public void onModuleLoad() {
      initialize();
   }
}

結果

結果を確認します。

TreeMapは、データツリーの視覚的表現であり、各ノードには0個以上の子があり、1つの親(ルートを除く)があります。各ノードは長方形として表示され、割り当てた値に応じてサイズと色を付けることができます。サイズと色は、グラフ内の他のすべてのノードを基準にして評価されます。以下は、ツリーマップチャートの例です。

Google Chartsの構成構文の章で、グラフの描画に使用される構成についてはすでに説明しました。それでは、TreeMapチャートの例を見てみましょう。

構成

使用しました TreeMap TreeMapチャートを表示するクラス。

TreeMap chart = new TreeMap();

HelloWorld.java

package com.tutorialspoint.client;

import com.google.gwt.core.client.EntryPoint;
import com.google.gwt.user.client.ui.RootPanel;

import com.googlecode.gwt.charts.client.ChartLoader;
import com.googlecode.gwt.charts.client.ChartPackage;
import com.googlecode.gwt.charts.client.ColumnType;
import com.googlecode.gwt.charts.client.DataTable;
import com.googlecode.gwt.charts.client.treemap.TreeMap;
import com.googlecode.gwt.charts.client.treemap.TreeMapOptions;

public class HelloWorld implements EntryPoint {
   private TreeMap chart;

   private void initialize() {
      ChartLoader chartLoader = new ChartLoader(ChartPackage.TREEMAP);
      chartLoader.loadApi(new Runnable() {
         public void run() {
            // Create and attach the chart
            chart = new TreeMap();
            RootPanel.get().add(chart);
            draw();
         }
      });
   }
   private void draw() {
      // Prepare the data
      DataTable dataTable = DataTable.create();
      dataTable.addColumn(ColumnType.STRING, "Location");
      dataTable.addColumn(ColumnType.STRING, "Parent");
      dataTable.addColumn(ColumnType.NUMBER, "Market trade volume (size)");
      dataTable.addColumn(ColumnType.NUMBER, "Market increase/decrease (color)");

      dataTable.addRow("Global",null,0,0);
      dataTable.addRow("America","Global",0,0);
      dataTable.addRow("Europe","Global",0,0);
      dataTable.addRow("Asia","Global",0,0);
      dataTable.addRow("Australia","Global",0,0);
      dataTable.addRow("Africa","Global",0,0);  

      dataTable.addRow("USA","America",52,31);
      dataTable.addRow("Mexico","America",24,12);
      dataTable.addRow("Canada","America",16,-23);

      dataTable.addRow("France","Europe",42,-11);
      dataTable.addRow("Germany","Europe",31,-2);
      dataTable.addRow("Sweden","Europe",22,-13);   

      dataTable.addRow("China","Asia",36,4);
      dataTable.addRow("Japan","Asia",20,-12);
      dataTable.addRow("India","Asia",40,63);

      dataTable.addRow("Egypt","Africa",21,0); 
      dataTable.addRow("Congo","Africa",10,12);
      dataTable.addRow("Zaire","Africa",8,10);

      // Set options
      TreeMapOptions options = TreeMapOptions.create();
      options.setMinColor("#ff7777");
      options.setMidColor("#ffff77");
      options.setMaxColor("#77ff77");
      options.setHeaderHeight(15);
      options.setShowScale(true);
      
      // Draw the chart
      chart.draw(dataTable, options);
      chart.setWidth("400px");
      chart.setHeight("400px");
   }
   public void onModuleLoad() {
      initialize();
   }
}

結果

結果を確認します。