Google API Libraries for Google Web Toolkit(例如 gwt-visualization.jar)仅用于客户端(用于生成 javascript)。幸运的是,Google 还在其Google Visualization Data Source Library 中提供了用于发布 DataTables 的服务器端 java 代码。
这里的设置允许我在远程过程调用中在服务器上生成 DataTables,将它们作为 JSON 字符串传回客户端,并使用 Google Visualizations for Google Web Toolkit 在客户端上显示漂亮的 Google Plot网页。我将 Eclipse Indigo 与 Google Web Toolkit 2.4.0 一起使用。
在 src/com.package.name/project-name.xml 中:
<inherits name='com.google.gwt.visualization.Visualization'/>
在客户端/TableService.java 中:
package com.clark.demos.client;
import com.google.gwt.user.client.rpc.RemoteService;
import com.google.gwt.user.client.rpc.RemoteServiceRelativePath;
@RemoteServiceRelativePath("table")
public interface TableService extends RemoteService {
String getTable();
}
在客户端/TableServiceAsync.java 中:
package com.clark.demos.client;
import com.google.gwt.user.client.rpc.AsyncCallback;
public interface TableServiceAsync {
void getTable( AsyncCallback<String> callback );
}
在战争/WEB-INF/web.xml 中:
<servlet>
<servlet-name>tableServlet</servlet-name>
<servlet-class>com.clark.demos.server.TableServiceImpl</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>tableServlet</servlet-name>
<url-pattern>/google_visualization___gwt/table</url-pattern>
</servlet-mapping>
在服务器/TableServiceImpl.java 中:
package com.clark.demos.server;
import com.google.visualization.datasource.datatable.ColumnDescription;
import com.google.visualization.datasource.datatable.DataTable;
import com.google.visualization.datasource.datatable.value.ValueType;
import com.google.visualization.datasource.render.JsonRenderer;
@SuppressWarnings("serial")
public class TableServiceImpl extends RemoteServiceServlet implements
TableService {
@Override
public String getTable() {
DataTable data = new DataTable();
data.addColumn( new ColumnDescription("Task", ValueType.TEXT, "Task") );
data.addColumn( new ColumnDescription("Stemming", ValueType.NUMBER, "Stemming") );
data.addColumn( new ColumnDescription("NoStemming", ValueType.NUMBER, "No Stemming") );
data.addRowFromValues( "Fire", 1.0, 0.8 );
data.addRowFromValues( "Flood", 0.5, 0.65 );
return JsonRenderer.renderDataTable(data, true, false, false).toString();
}
}
- 让客户端代码调用“表”服务并根据返回的 JSON 字符串构造一个 DataTable:
在客户端/gwt-visualization-demo.java 中:
/**
* Create a remote service proxy to talk to the server-side Table service.
*/
private final TableServiceAsync tableService = GWT
.create(TableService.class);
public static native DataTable toDataTable(String json) /*-{
return new $wnd.google.visualization.DataTable(eval("(" + json + ")"));
}-*/;
public void onModuleLoad() {
// Create a callback to be called when the visualization API
// has been loaded.
Runnable onLoadCallback = new Runnable() {
public void run() {
final Panel panel = RootPanel.get();
tableService.getTable(new AsyncCallback<String>() {
@Override
public void onSuccess(String result) {
AbstractDataTable data = toDataTable(result);
BarChart pie = new BarChart(data, createOptions());
pie.addSelectHandler(createSelectHandler(pie));
panel.add(pie);
}
@Override
public void onFailure(Throwable caught) {
}
});
}
};
// Load the visualization api, passing the onLoadCallback to be called
// when loading is done.
VisualizationUtils.loadVisualizationApi(onLoadCallback, BarChart.PACKAGE);
}
示例代码位于https://github.com/RichDickClark/gwt-google-charts-demo.git