Расчёты диаграмм

Вычисление фактических значений элементов диаграммы

Aspose.Slides for Node.js via Java предоставляет простой API для получения этих свойств. Свойства класса Axis предоставляют информацию о фактическом положении элемента диаграммы оси (Axis.getActualMaxValue, Axis.getActualMinValue, Axis.getActualMajorUnit, Axis.getActualMinorUnit, Axis.getActualMajorUnitScale, Axis.getActualMinorUnitScale). Необходимо предварительно вызвать метод Chart.validateChartLayout() , чтобы заполнить свойства фактическими значениями.

var pres = new aspose.slides.Presentation();
try {
    var chart = pres.getSlides().get_Item(0).getShapes().addChart(aspose.slides.ChartType.Area, 100, 100, 500, 350);
    chart.validateChartLayout();
    var maxValue = chart.getAxes().getVerticalAxis().getActualMaxValue();
    var minValue = chart.getAxes().getVerticalAxis().getActualMinValue();
    var majorUnit = chart.getAxes().getHorizontalAxis().getActualMajorUnit();
    var minorUnit = chart.getAxes().getHorizontalAxis().getActualMinorUnit();
} finally {
    if (pres != null) {
        pres.dispose();
    }
}

Вычисление фактического положения родительских элементов диаграммы

Aspose.Slides for Node.js via Java предоставляет простой API для получения этих свойств. Свойства класса ActualLayout предоставляют информацию о фактическом положении родительского элемента диаграммы (ActualLayout.getActualX, ActualLayout.getActualY, ActualLayout.getActualWidth, ActualLayout.getActualHeight). Необходимо предварительно вызвать метод Chart.validateChartLayout() , чтобы заполнить свойства фактическими значениями.

var pres = new aspose.slides.Presentation();
try {
    var chart = pres.getSlides().get_Item(0).getShapes().addChart(aspose.slides.ChartType.ClusteredColumn, 100, 100, 500, 350);
    chart.validateChartLayout();
    var x = chart.getPlotArea().getActualX();
    var y = chart.getPlotArea().getActualY();
    var w = chart.getPlotArea().getActualWidth();
    var h = chart.getPlotArea().getActualHeight();
} finally {
    if (pres != null) {
        pres.dispose();
    }
}

Скрыть информацию на диаграмме

Эта тема поможет вам понять, как скрыть информацию на диаграмме. С помощью Aspose.Slides for Node.js via Java вы можете скрыть Заголовок, Вертикальную ось, Горизонтальную ось и Линии сетки на диаграмме. Пример кода ниже показывает, как использовать эти свойства.

var pres = new aspose.slides.Presentation();
try {
    var slide = pres.getSlides().get_Item(0);
    var chart = slide.getShapes().addChart(aspose.slides.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(java.newByte(aspose.slides.FillType.NoFill));
    for (var i = 0; i < chart.getChartData().getSeries().size(); i++) {
        chart.getChartData().getSeries().removeAt(i);
    }
    var series = chart.getChartData().getSeries().get_Item(0);
    series.getMarker().setSymbol(aspose.slides.MarkerStyleType.Circle);
    series.getLabels().getDefaultDataLabelFormat().setShowValue(true);
    series.getLabels().getDefaultDataLabelFormat().setPosition(aspose.slides.LegendDataLabelPosition.Top);
    series.getMarker().setSize(15);
    // Установка цвета линии серии
    series.getFormat().getLine().getFillFormat().setFillType(java.newByte(aspose.slides.FillType.Solid));
    series.getFormat().getLine().getFillFormat().getSolidFillColor().setColor(java.getStaticFieldValue("java.awt.Color", "MAGENTA"));
    series.getFormat().getLine().setDashStyle(aspose.slides.LineDashStyle.Solid);
    pres.save("HideInformationFromChart.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
    if (pres != null) {
        pres.dispose();
    }
}

FAQ

Работают ли внешние книги Excel в качестве источника данных и как это влияет на пересчет?

Да. Диаграмма может ссылаться на внешнюю книгу: при подключении или обновлении внешнего источника формулы и значения берутся из этой книги, и диаграмма отражает изменения во время операций открытия/редактирования. API позволяет вам указать путь к внешней книге и управлять связанными данными.

Могу ли я вычислять и отображать линии тренда без собственной реализации регрессии?

Да. Линии тренда (линейные, экспоненциальные и др.) добавляются и обновляются Aspose.Slides; их параметры автоматически пересчитываются из данных серии, поэтому вам не нужно реализовывать собственные вычисления.

Если презентация содержит несколько диаграмм с внешними ссылками, могу ли я контролировать, какую книгу использует каждая диаграмма для вычисляемых значений?

Да. Каждая диаграмма может указывать на свою собственную внешнюю книгу, либо вы можете создавать/заменять внешнюю книгу для каждой диаграммы независимо от остальных.