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.axis.CategoryAxis; import com.sencha.gxt.chart.client.chart.axis.NumericAxis; import com.sencha.gxt.chart.client.chart.series.BarSeries; import com.sencha.gxt.chart.client.chart.series.SeriesToolTipConfig; import com.sencha.gxt.chart.client.draw.RGB; import com.sencha.gxt.core.client.ValueProvider; import com.sencha.gxt.data.shared.LabelProvider; 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.Movies; 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 StackedBarExample implements IsWidget, EntryPoint { public interface MoviesPropertyAccess extends PropertyAccess
{ ValueProvider
action(); ValueProvider
comedy(); ValueProvider
drama(); @Path("year") ModelKeyProvider
nameKey(); ValueProvider
thriller(); ValueProvider
year(); } private static final MoviesPropertyAccess moviesAccess = GWT.create(MoviesPropertyAccess.class); private LabelProvider
million = new LabelProvider
() { @Override public String getLabel(Number item) { int value = item.intValue() / 1000000; return value + "M"; } }; @Override public Widget asWidget() { final ListStore
store = new ListStore
(moviesAccess.nameKey()); store.addAll(TestData.getMovieData(2005, 5, 0, 160000000)); final Chart
chart = new Chart
(); chart.setStore(store); chart.setChartShadow(true); NumericAxis
axis = new NumericAxis
(); axis.setPosition(Position.BOTTOM); axis.addField(moviesAccess.comedy()); axis.addField(moviesAccess.action()); axis.addField(moviesAccess.drama()); axis.addField(moviesAccess.thriller()); axis.setDisplayGrid(true); axis.setMinimum(0); axis.setMaximum(160000000); axis.setLabelProvider(million); chart.addAxis(axis); CategoryAxis
catAxis = new CategoryAxis
(); catAxis.setPosition(Position.LEFT); catAxis.setField(moviesAccess.year()); chart.addAxis(catAxis); BarSeries
bar = new BarSeries
(); bar.setYAxisPosition(Position.BOTTOM); bar.addYField(moviesAccess.comedy()); bar.addYField(moviesAccess.action()); bar.addYField(moviesAccess.drama()); bar.addYField(moviesAccess.thriller()); bar.addColor(new RGB(148, 174, 10)); bar.addColor(new RGB(17, 95, 166)); bar.addColor(new RGB(166, 17, 32)); bar.addColor(new RGB(255, 136, 9)); bar.setStacked(true); SeriesToolTipConfig
config = new SeriesToolTipConfig
(); config.setNumericLabelProvider(million); bar.setToolTipConfig(config); chart.addSeries(bar); Legend
legend = new Legend
(); legend.setPosition(Position.RIGHT); legend.setItemHiding(true); legend.setItemHighlighting(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.getMovieData(2005, 5, 0, 160000000)); 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); ContentPanel panel = new ContentPanel(GWT.
create(FramedPanelAppearance.class)); panel.getElement().getStyle().setMargin(10, Unit.PX); panel.setCollapsible(true); panel.setHeadingText("Stacked Bar 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()); } }