package com.sencha.gxt.explorer.client.chart; import java.util.List; import com.google.gwt.core.client.EntryPoint; import com.google.gwt.core.client.GWT; import com.google.gwt.dom.client.Style.Unit; import com.google.gwt.editor.client.Editor.Path; import com.google.gwt.event.logical.shared.ValueChangeEvent; import com.google.gwt.event.logical.shared.ValueChangeHandler; import com.google.gwt.user.client.ui.IsWidget; import com.google.gwt.user.client.ui.RootPanel; import com.google.gwt.user.client.ui.Widget; import com.sencha.gxt.chart.client.chart.Chart; import com.sencha.gxt.chart.client.chart.axis.RadialAxis; import com.sencha.gxt.chart.client.chart.series.Primitives; import com.sencha.gxt.chart.client.chart.series.RadarSeries; import com.sencha.gxt.chart.client.chart.series.Series; import com.sencha.gxt.chart.client.chart.series.SeriesRenderer; import com.sencha.gxt.chart.client.draw.Color; import com.sencha.gxt.chart.client.draw.RGB; import com.sencha.gxt.chart.client.draw.sprite.Sprite; import com.sencha.gxt.core.client.ValueProvider; import com.sencha.gxt.data.shared.ListStore; import com.sencha.gxt.data.shared.ModelKeyProvider; import com.sencha.gxt.data.shared.PropertyAccess; import com.sencha.gxt.examples.resources.client.TestData; import com.sencha.gxt.examples.resources.client.model.Data; import com.sencha.gxt.explorer.client.model.Example.Detail; import com.sencha.gxt.theme.base.client.panel.FramedPanelAppearance; import com.sencha.gxt.widget.core.client.ContentPanel; import com.sencha.gxt.widget.core.client.ContentPanel.ContentPanelAppearance; import com.sencha.gxt.widget.core.client.button.TextButton; import com.sencha.gxt.widget.core.client.button.ToggleButton; import com.sencha.gxt.widget.core.client.container.VerticalLayoutContainer; import com.sencha.gxt.widget.core.client.container.VerticalLayoutContainer.VerticalLayoutData; import com.sencha.gxt.widget.core.client.event.SelectEvent; import com.sencha.gxt.widget.core.client.event.SelectEvent.SelectHandler; import com.sencha.gxt.widget.core.client.toolbar.ToolBar; public class RadarExample implements IsWidget, EntryPoint { public interface DataPropertyAccess extends PropertyAccess
{ ValueProvider
data1(); ValueProvider
data2(); ValueProvider
data3(); ValueProvider
name(); @Path("name") ModelKeyProvider
nameKey(); } private static final DataPropertyAccess dataAccess = GWT.create(DataPropertyAccess.class); private Color[] colors = {RGB.RED, RGB.GREEN, RGB.BLUE}; private Color[] currentColor = {Color.NONE, Color.NONE, Color.NONE}; private double strokeWidth = 2; private double opacity = 1; public Widget asWidget() { final ListStore
store = new ListStore
(dataAccess.nameKey()); store.addAll(TestData.getData(12, 20, 100)); final Chart
chart = new Chart
(600, 400); chart.setStore(store); chart.setChartShadow(true); RadialAxis
axis = new RadialAxis
(); axis.setCategoryField(dataAccess.name()); chart.addAxis(axis); RadarSeries
radar = new RadarSeries
(); radar.setYField(dataAccess.data1()); radar.setStroke(colors[0]); radar.setShowMarkers(true); Sprite marker = Primitives.circle(0, 0, 4); marker.setFill(colors[0]); radar.setMarkerConfig(marker); radar.setLineRenderer(createRenderer(0)); chart.addSeries(radar); radar = new RadarSeries
(); radar.setYField(dataAccess.data2()); radar.setStroke(colors[1]); radar.setShowMarkers(true); marker = Primitives.diamond(0, 0, 4); marker.setFill(colors[1]); radar.setMarkerConfig(marker); radar.setLineRenderer(createRenderer(1)); chart.addSeries(radar); radar = new RadarSeries
(); radar.setYField(dataAccess.data3()); radar.setStroke(colors[2]); radar.setShowMarkers(true); marker = Primitives.square(0, 0, 4); marker.setFill(colors[2]); radar.setMarkerConfig(marker); radar.setLineRenderer(createRenderer(2)); chart.addSeries(radar); TextButton regenerate = new TextButton("Reload Data"); regenerate.addSelectHandler(new SelectHandler() { @Override public void onSelect(SelectEvent event) { store.clear(); store.addAll(TestData.getData(12, 20, 100)); chart.redrawChart(); } }); ToggleButton animation = new ToggleButton("Animate"); animation.addValueChangeHandler(new ValueChangeHandler
() { @Override public void onValueChange(ValueChangeEvent
event) { chart.setAnimated(event.getValue()); } }); ToggleButton fill = new ToggleButton("Fill"); fill.addValueChangeHandler(new ValueChangeHandler
() { @SuppressWarnings("rawtypes") @Override public void onValueChange(ValueChangeEvent
event) { if (event.getValue()) { opacity = 0.4; currentColor[0] = colors[0]; currentColor[1] = colors[1]; currentColor[2] = colors[2]; strokeWidth = Double.NaN; } else { opacity = 1; currentColor[0] = Color.NONE; currentColor[1] = Color.NONE; currentColor[2] = Color.NONE; strokeWidth = 2; } List
> series = chart.getSeries(); for (int i = 0; i < series.size(); i++) { RadarSeries radar = (RadarSeries) series.get(i); radar.setShowMarkers(!event.getValue()); } chart.redrawChart(); } }); ToolBar toolBar = new ToolBar(); toolBar.add(regenerate); toolBar.add(animation); toolBar.add(fill); ContentPanel panel = new ContentPanel(GWT.
create(FramedPanelAppearance.class)); panel.getElement().getStyle().setMargin(10, Unit.PX); panel.setCollapsible(true); panel.setHeadingText("Radar Chart"); panel.setPixelSize(620, 500); panel.setBodyBorder(true); panel.setBodyStyleName("white-bg"); VerticalLayoutContainer layout = new VerticalLayoutContainer(); layout.setBorders(true); panel.add(layout); toolBar.setLayoutData(new VerticalLayoutData(1, -1)); layout.add(toolBar); chart.setLayoutData(new VerticalLayoutData(1, 1)); layout.add(chart); return panel; } public SeriesRenderer
createRenderer(final int seriesIndex) { return new SeriesRenderer
() { @Override public void spriteRenderer(Sprite sprite, int index, ListStore
store) { sprite.setStrokeWidth(strokeWidth); sprite.setOpacity(opacity); sprite.setFill(currentColor[seriesIndex]); } }; } public void onModuleLoad() { RootPanel.get().add(asWidget()); } }