Java 如何在JSF中以编程方式更新图表?
我有一个JSF应用程序,其中Java 如何在JSF中以编程方式更新图表?,java,jsf,primefaces,Java,Jsf,Primefaces,我有一个JSF应用程序,其中 用户随后按下一个按钮 一个新的数据项被添加到图表和 图表应该重新绘制 重新绘制图表的正确方法是什么 目前,我在托管bean中有以下代码,用于处理按钮按下事件: public void simulateYearButtonAction() { // Update other UI elements here this.updateChart(); } private void updateBirthsChart() { final F
- 用户随后按下一个按钮
- 一个新的数据项被添加到图表和
- 图表应该重新绘制
public void simulateYearButtonAction()
{
// Update other UI elements here
this.updateChart();
}
private void updateBirthsChart() {
final FacesContext context = FacesContext.getCurrentInstance();
final ChartBean bean =
(ChartBean) context.getApplication().evaluateExpressionGet(
context, "#{chartBean}", ChartBean.class);
final DataStore dataStore = (DataStore)this.simulationFacade;
bean.addBirthsData(this.year-1, dataStore.getValue(DataStoreValueType.BIRTHS_LAST_YEAR));
}
在ChartBean
中,我向图表系列添加了一个新的数据项
public ChartBean() {
createCategoryModel();
}
private void createCategoryModel() {
categoryModel = new CartesianChartModel();
birthsSeries = new ChartSeries();
birthsSeries.setLabel("Рождения");
birthsSeries.set(2012, 0);
categoryModel.addSeries(birthsSeries);
}
public void addBirthsData(final int aYear, final double aNumberOfBirths) {
this.birthsSeries.set(aYear, aNumberOfBirths);
}
页面以以下方式使用ChartBean
:
<p:lineChart id="category" value="#{chartBean.categoryModel}"
legendPosition="e" title="Демографическая динамика" minX="2012" maxX="2112"
style="height:300px;margin-top:20px" />
我不知道如何告诉图表它现在应该更新(并显示新数据)。当按下按钮时,将调用backingbean方法,该方法将重建图表。操作完成后,包括
update=“category”
您的图表将被更新:
<p:commandButton actionListener=#{chartBean.refreshCategoryModel()}
update="category"/>
新生成的图表可能取决于某些动态值。调用
时,不要忘记处理这些组件
你会发现下面的帖子很有用
public void refreshCategoryModel() {
createCategoryModel();
}
private void createCategoryModel() {
categoryModel = new CartesianChartModel();
birthsSeries = new ChartSeries();
birthsSeries.setLabel("Рождения");
birthsSeries.set(2012, 0);
categoryModel.addSeries(birthsSeries);
}