优化 Android 演示文稿中的图表计算

计算图表元素的实际值

Aspose.Slides for Android via 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 Android via 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 Android via 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 自动添加和更新,其参数会根据系列数据自动重新计算,您无需自行实现计算。

如果一个演示文稿包含多个带有外部链接的图表,我可以控制每个图表使用哪个工作簿来计算数值吗?

是的。每个图表都可以指向其自己的外部工作簿,或者您可以为每个图表单独创建/替换外部工作簿,而不影响其他图表。