Серия графиков
Серия - это ряд или столбец чисел, нанесенных на график.
Установить перекрытие серии графиков
С помощью свойства IChartSeriesOverlap вы можете указать, насколько столбцы и бары должны перекрываться на 2D-графике (диапазон: от -100 до 100). Это свойство применяется ко всем сериям родительской группы серий: это проекция соответствующего свойству группы. Следовательно, это свойство является доступным только для чтения.
Используйте свойство ParentSeriesGroup.Overlap
для чтения и записи, чтобы установить желаемое значение для Overlap
.
- Создайте экземпляр класса Presentation.
- Добавьте столбчатый график на слайд.
- Получите доступ к первой серии графиков.
- Получите доступ к
ParentSeriesGroup
серии графиков и установите желаемое значение перекрытия для серии. - Запишите изменённую презентацию в файл PPTX.
Этот код на Java показывает, как установить перекрытие для серии графиков:
Presentation pres = new Presentation();
try {
// Добавляет график
IChart chart = pres.getSlides().get_Item(0).getShapes().addChart(ChartType.ClusteredColumn, 50, 50, 600, 400, true);
IChartSeriesCollection series = chart.getChartData().getSeries();
if (series.get_Item(0).getOverlap() == 0)
{
// Устанавливает перекрытие серии
series.get_Item(0).getParentSeriesGroup().setOverlap((byte)-30);
}
// Записывает файл презентации на диск
pres.save("SetChartSeriesOverlap_out.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
Изменить цвет серии
Aspose.Slides для Android через Java позволяет изменить цвет серии следующим образом:
- Создайте экземпляр класса Presentation.
- Добавьте график на слайде.
- Получите доступ к серии, цвет которой вы хотите изменить.
- Установите желаемый тип заливки и цвет заливки.
- Сохраните изменённую презентацию.
Этот код на Java показывает, как изменить цвет серии:
Presentation pres = new Presentation("test.pptx");
try {
IChart chart = pres.getSlides().get_Item(0).getShapes().addChart(ChartType.Pie, 50, 50, 600, 400);
IChartDataPoint point = chart.getChartData().getSeries().get_Item(0).getDataPoints().get_Item(1);
point.setExplosion(30);
point.getFormat().getFill().setFillType(FillType.Solid);
point.getFormat().getFill().getSolidFillColor().setColor(Color.BLUE);
pres.save("output.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
Изменить цвет категории серии
Aspose.Slides для Android через Java позволяет изменить цвет категории серии следующим образом:
- Создайте экземпляр класса Presentation.
- Добавьте график на слайде.
- Получите доступ к категории серии, цвет которой вы хотите изменить.
- Установите желаемый тип заливки и цвет заливки.
- Сохраните изменённую презентацию.
Этот код на Java показывает, как изменить цвет категории серии:
Presentation pres = new Presentation();
try {
IChart chart = pres.getSlides().get_Item(0).getShapes().addChart(ChartType.ClusteredColumn, 50, 50, 600, 400);
IChartDataPoint point = chart.getChartData().getSeries().get_Item(0).getDataPoints().get_Item(0);
point.getFormat().getFill().setFillType(FillType.Solid);
point.getFormat().getFill().getSolidFillColor().setColor(Color.BLUE);
pres.save("output.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
Изменить название серии
По умолчанию названия для легенды графика соответствуют содержимому ячеек над каждым столбцом или строкой данных.
В нашем примере (образец изображения),
- столбцы - это Серия 1, Серия 2, и Серия 3;
- строки - это Категория 1, Категория 2, Категория 3, и Категория 4.
Aspose.Slides для Android через Java позволяет обновить или изменить название серии в данных графика и легенде.
Этот код на Java показывает, как изменить название серии в данных графика ChartDataWorkbook
:
Presentation pres = new Presentation();
try {
IChart chart = pres.getSlides().get_Item(0).getShapes().addChart(ChartType.Column3D, 50, 50, 600, 400, true);
IChartDataCell seriesCell = chart.getChartData().getChartDataWorkbook().getCell(0, 0, 1);
seriesCell.setValue("Новое имя");
pres.save("pres.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
Этот код на Java показывает, как изменить название серии в легенде через Series
:
Presentation pres = new Presentation();
try {
IChart chart = pres.getSlides().get_Item(0).getShapes().addChart(ChartType.Column3D, 50, 50, 600, 400, true);
IChartSeries series = chart.getChartData().getSeries().get_Item(0);
IStringChartValue name = series.getName();
name.getAsCells().get_Item(0).setValue("Новое имя");
} finally {
if (pres != null) pres.dispose();
}
Установить цвет заливки для серии графиков
Aspose.Slides для Android через Java позволяет установить автоматический цвет заливки для серий графиков внутри области построения следующим образом:
- Создайте экземпляр класса Presentation.
- Получите ссылку на слайд по его индексу.
- Добавьте график с данными по умолчанию на основе вашего предпочтительного типа (в примере ниже мы использовали
ChartType.ClusteredColumn
). - Получите доступ к серии графиков и установите цвет заливки на Авто.
- Сохраните презентацию в файл PPTX.
Этот код на Java показывает, как установить автоматический цвет заливки для серии графиков:
Presentation pres = new Presentation();
try {
// Создаёт столбчатый график
IChart chart = pres.getSlides().get_Item(0).getShapes().addChart(ChartType.ClusteredColumn, 100, 50, 600, 400);
// Устанавливает формат заливки серии на автоматический
for (int i = 0; i < chart.getChartData().getSeries().size(); i++)
{
chart.getChartData().getSeries().get_Item(i).getAutomaticSeriesColor();
}
// Записывает файл презентации на диск
pres.save("AutoFillSeries_out.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
Установить инвертированные цвета заливки для серий графиков
Aspose.Slides позволяет установить инвертированный цвет заливки для серий графиков внутри области построения следующим образом:
- Создайте экземпляр класса Presentation.
- Получите ссылку на слайд по его индексу.
- Добавьте график с данными по умолчанию на основе вашего предпочтительного типа (в примере ниже мы использовали
ChartType.ClusteredColumn
). - Получите доступ к серии графиков и установите цвет заливки на инвертированный.
- Сохраните презентацию в файл PPTX.
Этот код на Java демонстрирует операцию:
Color inverColor = Color.RED;
Presentation pres = new Presentation();
try {
IChart chart = pres.getSlides().get_Item(0).getShapes().addChart(ChartType.ClusteredColumn, 100, 100, 400, 300);
IChartDataWorkbook workBook = chart.getChartData().getChartDataWorkbook();
chart.getChartData().getSeries().clear();
chart.getChartData().getCategories().clear();
// Добавляет новые серии и категории
chart.getChartData().getSeries().add(workBook.getCell(0, 0, 1, "Серия 1"), chart.getType());
chart.getChartData().getCategories().add(workBook.getCell(0, 1, 0, "Категория 1"));
chart.getChartData().getCategories().add(workBook.getCell(0, 2, 0, "Категория 2"));
chart.getChartData().getCategories().add(workBook.getCell(0, 3, 0, "Категория 3"));
// Берет первую серию графиков и заполняет ее данными серии.
IChartSeries series = chart.getChartData().getSeries().get_Item(0);
series.getDataPoints().addDataPointForBarSeries(workBook.getCell(0, 1, 1, -20));
series.getDataPoints().addDataPointForBarSeries(workBook.getCell(0, 2, 1, 50));
series.getDataPoints().addDataPointForBarSeries(workBook.getCell(0, 3, 1, -30));
Color seriesColor = series.getAutomaticSeriesColor();
series.setInvertIfNegative(true);
series.getFormat().getFill().setFillType(FillType.Solid);
series.getFormat().getFill().getSolidFillColor().setColor(seriesColor);
series.getInvertedSolidFillColor().setColor(inverColor);
pres.save("SetInvertFillColorChart_out.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
Установить инвертацию для серии, когда значение отрицательное
Aspose.Slides позволяет установить инверсию через свойства IChartDataPoint.InvertIfNegative
и ChartDataPoint.InvertIfNegative
. Когда инверсия установлена с помощью свойств, точка данных инвертирует свои цвета, когда получает отрицательное значение.
Этот код на Java демонстрирует операцию:
Presentation pres = new Presentation();
try {
IChart chart = pres.getSlides().get_Item(0).getShapes().addChart(ChartType.ClusteredColumn, 50, 50, 600, 400, true);
IChartSeriesCollection series = chart.getChartData().getSeries();
chart.getChartData().getSeries().clear();
IChartSeries chartSeries = series.add(chart.getChartData().getChartDataWorkbook().getCell(0, "B1"), chart.getType());
chartSeries.getDataPoints().addDataPointForBarSeries(chart.getChartData().getChartDataWorkbook().getCell(0, "B2", -5));
chartSeries.getDataPoints().addDataPointForBarSeries(chart.getChartData().getChartDataWorkbook().getCell(0, "B3", 3));
chartSeries.getDataPoints().addDataPointForBarSeries(chart.getChartData().getChartDataWorkbook().getCell(0, "B4", -2));
chartSeries.getDataPoints().addDataPointForBarSeries(chart.getChartData().getChartDataWorkbook().getCell(0, "B5", 1));
chartSeries.setInvertIfNegative(false);
chartSeries.getDataPoints().get_Item(2).setInvertIfNegative(true);
pres.save("out.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
Очистить данные определённых точек данных
Aspose.Slides для Android через Java позволяет очистить данные DataPoints
для определённой серии графиков следующим образом:
- Создайте экземпляр класса Presentation.
- Получите ссылку на слайд по его индексу.
- Получите ссылку на график по его индексу.
- Просмотрите все точки данных графика и установите
XValue
иYValue
в null. - Очистите все
DataPoints
для конкретной серии графиков. - Запишите изменённую презентацию в файл PPTX.
Этот код на Java демонстрирует операцию:
Presentation pres = new Presentation("TestChart.pptx");
try {
ISlide sl = pres.getSlides().get_Item(0);
IChart chart = (IChart)sl.getShapes().get_Item(0);
for (IChartDataPoint dataPoint : chart.getChartData().getSeries().get_Item(0).getDataPoints())
{
dataPoint.getXValue().getAsCell().setValue(null);
dataPoint.getYValue().getAsCell().setValue(null);
}
chart.getChartData().getSeries().get_Item(0).getDataPoints().clear();
pres.save("ClearSpecificChartSeriesDataPointsData.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
Установить ширину пробелов для серии
Aspose.Slides для Android через Java позволяет установить ширину пробелов для серии с помощью свойства GapWidth
следующим образом:
- Создайте экземпляр класса Presentation.
- Получите доступ к первому слайду.
- Добавьте график с данными по умолчанию.
- Получите доступ к любой серии графиков.
- Установите свойство
GapWidth
. - Запишите изменённую презентацию в файл PPTX.
Этот код на Java показывает, как установить ширину пробелов для серии:
// Создаёт пустую презентацию
Presentation pres = new Presentation();
try {
// Получает первый слайд презентации
ISlide slide = pres.getSlides().get_Item(0);
// Добавляет график с данными по умолчанию
IChart chart = slide.getShapes().addChart(ChartType.StackedColumn, 0, 0, 500, 500);
// Устанавливает индекс рабочего листа графика
int defaultWorksheetIndex = 0;
// Получает рабочий лист данных графика
IChartDataWorkbook fact = chart.getChartData().getChartDataWorkbook();
// Добавляет серии
chart.getChartData().getSeries().add(fact.getCell(defaultWorksheetIndex, 0, 1, "Серия 1"), chart.getType());
chart.getChartData().getSeries().add(fact.getCell(defaultWorksheetIndex, 0, 2, "Серия 2"), chart.getType());
// Добавляет категории
chart.getChartData().getCategories().add(fact.getCell(defaultWorksheetIndex, 1, 0, "Категория 1"));
chart.getChartData().getCategories().add(fact.getCell(defaultWorksheetIndex, 2, 0, "Категория 2"));
chart.getChartData().getCategories().add(fact.getCell(defaultWorksheetIndex, 3, 0, "Категория 3"));
// Берёт вторую серию графиков
IChartSeries series = chart.getChartData().getSeries().get_Item(1);
// Заполняет данные серии
series.getDataPoints().addDataPointForBarSeries(fact.getCell(defaultWorksheetIndex, 1, 1, 20));
series.getDataPoints().addDataPointForBarSeries(fact.getCell(defaultWorksheetIndex, 2, 1, 50));
series.getDataPoints().addDataPointForBarSeries(fact.getCell(defaultWorksheetIndex, 3, 1, 30));
series.getDataPoints().addDataPointForBarSeries(fact.getCell(defaultWorksheetIndex, 1, 2, 30));
series.getDataPoints().addDataPointForBarSeries(fact.getCell(defaultWorksheetIndex, 2, 2, 10));
series.getDataPoints().addDataPointForBarSeries(fact.getCell(defaultWorksheetIndex, 3, 2, 60));
// Устанавливает значение GapWidth
series.getParentSeriesGroup().setGapWidth(50);
// Сохраняет презентацию на диск
pres.save("GapWidth_out.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}