package com.sencha.gxt.explorer.client.chart; 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.Chart.Position; import com.sencha.gxt.chart.client.chart.Legend; import com.sencha.gxt.chart.client.chart.series.PieSeries; import com.sencha.gxt.chart.client.chart.series.SeriesLabelConfig; import com.sencha.gxt.chart.client.draw.Gradient; import com.sencha.gxt.chart.client.draw.RGB; import com.sencha.gxt.chart.client.draw.Stop; import com.sencha.gxt.chart.client.draw.sprite.TextSprite; import com.sencha.gxt.chart.client.draw.sprite.TextSprite.TextAnchor; 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.data.shared.StringLabelProvider; 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 PieExample implements IsWidget, EntryPoint { public interface DataPropertyAccess extends PropertyAccess
{ ValueProvider
data1(); ValueProvider
name(); @Path("name") ModelKeyProvider
nameKey(); } private static final DataPropertyAccess dataAccess = GWT.create(DataPropertyAccess.class); public Widget asWidget() { final ListStore
store = new ListStore
(dataAccess.nameKey()); store.addAll(TestData.getData(6, 20, 100)); final Chart
chart = new Chart
(); chart.setDefaultInsets(50); chart.setStore(store); chart.setChartShadow(true); Gradient slice1 = new Gradient("slice1", 45); slice1.addStop(new Stop(0, new RGB(148, 174, 10))); slice1.addStop(new Stop(100, new RGB(107, 126, 7))); chart.addGradient(slice1); Gradient slice2 = new Gradient("slice2", 45); slice2.addStop(new Stop(0, new RGB(17, 95, 166))); slice2.addStop(new Stop(100, new RGB(12, 69, 120))); chart.addGradient(slice2); Gradient slice3 = new Gradient("slice3", 45); slice3.addStop(new Stop(0, new RGB(166, 17, 32))); slice3.addStop(new Stop(100, new RGB(120, 12, 23))); chart.addGradient(slice3); Gradient slice4 = new Gradient("slice4", 45); slice4.addStop(new Stop(0, new RGB(255, 136, 9))); slice4.addStop(new Stop(100, new RGB(213, 110, 0))); chart.addGradient(slice4); Gradient slice5 = new Gradient("slice5", 45); slice5.addStop(new Stop(0, new RGB(255, 209, 62))); slice5.addStop(new Stop(100, new RGB(255, 197, 11))); chart.addGradient(slice5); Gradient slice6 = new Gradient("slice6", 45); slice6.addStop(new Stop(0, new RGB(166, 17, 135))); slice6.addStop(new Stop(100, new RGB(120, 12, 97))); chart.addGradient(slice6); final PieSeries
series = new PieSeries
(); series.setAngleField(dataAccess.data1()); series.addColor(slice1); series.addColor(slice2); series.addColor(slice3); series.addColor(slice4); series.addColor(slice5); series.addColor(slice6); TextSprite textConfig = new TextSprite(); textConfig.setFont("Arial"); textConfig.setFontSize(18); textConfig.setTextAnchor(TextAnchor.MIDDLE); SeriesLabelConfig
labelConfig = new SeriesLabelConfig
(); labelConfig.setSpriteConfig(textConfig); labelConfig.setNumericLabelProvider(null); labelConfig.setValueProvider(dataAccess.name(), new StringLabelProvider
()); series.setLabelConfig(labelConfig); series.setHighlighting(true); series.setLegendValueProvider(dataAccess.name(), new StringLabelProvider
()); chart.addSeries(series); Legend
legend = new Legend
(); legend.setPosition(Position.RIGHT); legend.setItemHighlighting(true); legend.setItemHiding(true); chart.setLegend(legend); TextButton regenerate = new TextButton("Reload Data"); regenerate.addSelectHandler(new SelectHandler() { @Override public void onSelect(SelectEvent event) { store.clear(); store.addAll(TestData.getData(6, 20, 100)); chart.redrawChart(); } }); ToggleButton donut = new ToggleButton("Donut"); donut.addValueChangeHandler(new ValueChangeHandler
() { @Override public void onValueChange(ValueChangeEvent
event) { if (event.getValue()) { series.setDonut(35); } else { series.setDonut(0); } chart.redrawChart(); } }); ToggleButton animation = new ToggleButton("Animate"); animation.addValueChangeHandler(new ValueChangeHandler
() { @Override public void onValueChange(ValueChangeEvent
event) { chart.setAnimated(event.getValue()); } }); ToolBar toolBar = new ToolBar(); toolBar.add(regenerate); toolBar.add(animation); toolBar.add(donut); ContentPanel panel = new ContentPanel(GWT.
create(FramedPanelAppearance.class)); panel.getElement().getStyle().setMargin(10, Unit.PX); panel.setCollapsible(true); panel.setHeadingText("Pie 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 void onModuleLoad() { RootPanel.get().add(asWidget()); } }