针对 Java 演示文稿的图表计算优化
计算图表元素的实际值
Aspose.Slides for Java 提供了一个简便的 API 来获取这些属性。IAxis 接口的属性提供有关轴图表元素实际位置的信息(IAxis.getActualMaxValue、IAxis.getActualMinValue、IAxis.getActualMajorUnit、IAxis.getActualMinorUnit、IAxis.getActualMajorUnitScale、IAxis.getActualMinorUnitScale。需要先调用IChart.validateChartLayout() 方法,以便用实际值填充这些属性。
Presentation pres = new Presentation();
try {
Chart chart = (Chart)pres.getSlides().get_Item(0).getShapes().addChart(ChartType.Area, 100, 100, 500, 350);
chart.validateChartLayout();
double maxValue = chart.getAxes().getVerticalAxis().getActualMaxValue();
double minValue = chart.getAxes().getVerticalAxis().getActualMinValue();
double majorUnit = chart.getAxes().getHorizontalAxis().getActualMajorUnit();
double minorUnit = chart.getAxes().getHorizontalAxis().getActualMinorUnit();
} finally {
if (pres != null) pres.dispose();
}
计算父图表元素的实际位置
Aspose.Slides for Java 提供了一个简便的 API 来获取这些属性。 IActualLayout 接口的属性提供有关父图表元素实际位置的信息(IActualLayout.getActualX、IActualLayout.getActualY、IActualLayout.getActualWidth、IActualLayout.getActualHeight。需要先调用IChart.validateChartLayout() 方法,以便用实际值填充这些属性。
Presentation pres = new Presentation();
try {
Chart chart = (Chart) pres.getSlides().get_Item(0).getShapes().addChart(ChartType.ClusteredColumn, 100, 100, 500, 350);
chart.validateChartLayout();
double x = chart.getPlotArea().getActualX();
double y = chart.getPlotArea().getActualY();
double w = chart.getPlotArea().getActualWidth();
double h = chart.getPlotArea().getActualHeight();
} finally {
if (pres != null) pres.dispose();
}
隐藏图表元素
本主题帮助您了解如何在图表中隐藏信息。使用 Aspose.Slides for Java,您可以隐藏 标题、垂直轴、水平轴 和 网格线。下面的代码示例展示了如何使用这些属性。
Presentation pres = new Presentation();
try {
ISlide slide = pres.getSlides().get_Item(0);
IChart chart = slide.getShapes().addChart(ChartType.LineWithMarkers, 140, 118, 320, 370);
//隐藏图表标题
chart.setTitle(false);
///隐藏数值轴
chart.getAxes().getVerticalAxis().setVisible(false);
//类别轴可见性
chart.getAxes().getHorizontalAxis().setVisible(false);
//隐藏图例
chart.setLegend(false);
//隐藏主要网格线
chart.getAxes().getHorizontalAxis().getMajorGridLinesFormat().getLine().getFillFormat().setFillType(FillType.NoFill);
for (int i = 0; i < chart.getChartData().getSeries().size(); i++)
{
chart.getChartData().getSeries().removeAt(i);
}
IChartSeries series = chart.getChartData().getSeries().get_Item(0);
series.getMarker().setSymbol(MarkerStyleType.Circle);
series.getLabels().getDefaultDataLabelFormat().setShowValue(true);
series.getLabels().getDefaultDataLabelFormat().setPosition(LegendDataLabelPosition.Top);
series.getMarker().setSize(15);
//设置系列线颜色
series.getFormat().getLine().getFillFormat().setFillType(FillType.Solid);
series.getFormat().getLine().getFillFormat().getSolidFillColor().setColor(Color.MAGENTA);
series.getFormat().getLine().setDashStyle(LineDashStyle.Solid);
pres.save("HideInformationFromChart.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
常见问题
外部 Excel 工作簿可以作为数据源吗?这会如何影响重新计算?
是的。图表可以引用外部工作簿:当您连接或刷新外部来源时,公式和数值会从该工作簿中获取,图表会在打开/编辑操作期间反映更新。该 API 允许您指定外部工作簿的路径并管理链接的数据。
我可以在不自行实现回归的情况下计算和显示趋势线吗?
是的。趋势线(线性、指数等)由 Aspose.Slides 添加并自动更新;其参数会根据系列数据自动重新计算,您无需自行实现计算。
如果演示文稿中有多个带外部链接的图表,我能控制每个图表使用哪个工作簿来计算值吗?
是的。每个图表都可以指向其自己的外部工作簿,或者您可以为每个图表单独创建/替换外部工作簿,而不受其他图表的影响。