图表系列
系列是在图表中绘制的一行或一列数字。
设置图表系列重叠
使用 IChartSeriesOverlap 属性,您可以指定条形图和柱状图在 2D 图表上应重叠多少(范围:-100 到 100)。该属性适用于父系列组的所有系列:这是适当的组属性的投影。因此,该属性是只读的。
使用 ParentSeriesGroup.Overlap
可读写属性设置您喜欢的 Overlap
值。
- 创建 Presentation 类的实例。
- 在幻灯片上添加聚类柱状图。
- 访问第一个图表系列。
- 访问图表系列的
ParentSeriesGroup
并为该系列设置您喜欢的重叠值。 - 将修改后的演示文稿写入 PPTX 文件。
以下 PHP 代码显示如何设置图表系列的重叠:
$pres = new Presentation();
try {
# 添加图表
$chart = $pres->getSlides()->get_Item(0)->getShapes()->addChart(ChartType::ClusteredColumn, 50, 50, 600, 400, true);
$series = $chart->getChartData()->getSeries();
if (java_values($series->get_Item(0)->getOverlap()) == 0) {
# 设置系列重叠
$series->get_Item(0)->getParentSeriesGroup()->setOverlap(-30);
}
# 将演示文稿文件写入磁盘
$pres->save("SetChartSeriesOverlap_out.pptx", SaveFormat::Pptx);
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}
更改系列颜色
Aspose.Slides for PHP via Java 允许您以以下方式更改系列的颜色:
- 创建 Presentation 类的实例。
- 在幻灯片上添加图表。
- 访问您想要更改颜色的系列。
- 设置您喜欢的填充类型和填充颜色。
- 保存修改后的演示文稿。
以下 PHP 代码显示如何更改系列的颜色:
$pres = new Presentation("test.pptx");
try {
$chart = $pres->getSlides()->get_Item(0)->getShapes()->addChart(ChartType::Pie, 50, 50, 600, 400);
$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(java("java.awt.Color")->BLUE);
$pres->save("output.pptx", SaveFormat::Pptx);
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}
更改系列类别的颜色
Aspose.Slides for PHP via Java 允许您以以下方式更改系列类别的颜色:
- 创建 Presentation 类的实例。
- 在幻灯片上添加图表。
- 访问您想要更改颜色的系列类别。
- 设置您喜欢的填充类型和填充颜色。
- 保存修改后的演示文稿。
以下代码显示如何更改系列类别的颜色:
$pres = new Presentation();
try {
$chart = $pres->getSlides()->get_Item(0)->getShapes()->addChart(ChartType::ClusteredColumn, 50, 50, 600, 400);
$point = $chart->getChartData()->getSeries()->get_Item(0)->getDataPoints()->get_Item(0);
$point->getFormat()->getFill()->setFillType(FillType::Solid);
$point->getFormat()->getFill()->getSolidFillColor()->setColor(java("java.awt.Color")->BLUE);
$pres->save("output.pptx", SaveFormat::Pptx);
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}
更改系列的名称
默认情况下,图表的图例名称是每列或数据行上方单元格的内容。
在我们的示例中(示例图像),
- 列为 Series 1, Series 2, 和 Series 3;
- 行为 Category 1, Category 2, Category 3, 和 Category 4。
Aspose.Slides for PHP via Java 允许您在其图表数据和图例中更新或更改系列名称。
以下 PHP 代码显示如何在其图表数据 ChartDataWorkbook
中更改系列的名称:
$pres = new Presentation();
try {
$chart = $pres->getSlides()->get_Item(0)->getShapes()->addChart(ChartType::Column3D, 50, 50, 600, 400, true);
$seriesCell = $chart->getChartData()->getChartDataWorkbook()->getCell(0, 0, 1);
$seriesCell->setValue("新名称");
$pres->save("pres.pptx", SaveFormat::Pptx);
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}
以下 PHP 代码显示如何通过 Series
更改系列名称在其图例中:
$pres = new Presentation();
try {
$chart = $pres->getSlides()->get_Item(0)->getShapes()->addChart(ChartType::Column3D, 50, 50, 600, 400, true);
$series = $chart->getChartData()->getSeries()->get_Item(0);
$name = $series->getName();
$name->getAsCells()->get_Item(0)->setValue("新名称");
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}
设置图表系列填充颜色
Aspose.Slides for PHP via Java 允许您以如下方式为图表系列设置自动填充颜色:
- 创建 Presentation 类的实例。
- 根据索引获取幻灯片的引用。
- 根据您喜欢的类型添加一个默认数据显示的图表(在下面的示例中,我们使用了
ChartType::ClusteredColumn
)。 - 访问图表系列并将填充颜色设置为自动。
- 将演示文稿保存为 PPTX 文件。
以下 PHP 代码显示如何为图表系列设置自动填充颜色:
$pres = new Presentation();
try {
# 创建聚类柱状图
$chart = $pres->getSlides()->get_Item(0)->getShapes()->addChart(ChartType::ClusteredColumn, 100, 50, 600, 400);
# 将系列填充格式设置为自动
for($i = 0; $i < java_values($chart->getChartData()->getSeries()->size()) ; $i++) {
$chart->getChartData()->getSeries()->get_Item($i)->getAutomaticSeriesColor();
}
# 将演示文稿文件写入磁盘
$pres->save("AutoFillSeries_out.pptx", SaveFormat::Pptx);
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}
设置图表系列反转填充颜色
Aspose.Slides 允许您以如下方式设置图表系列的反转填充颜色:
- 创建 Presentation 类的实例。
- 根据索引获取幻灯片的引用。
- 根据您喜欢的类型添加一个默认数据显示的图表(在下面的示例中,我们使用了
ChartType::ClusteredColumn
)。 - 访问图表系列并将填充颜色设置为反转。
- 将演示文稿保存为 PPTX 文件。
以下 PHP 代码演示该操作:
$inverColor = java("java.awt.Color")->RED;
$pres = new Presentation();
try {
$chart = $pres->getSlides()->get_Item(0)->getShapes()->addChart(ChartType::ClusteredColumn, 100, 100, 400, 300);
$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"));
# 取第一系列并填充其系列数据。
$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));
$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 (!java_is_null($pres)) {
$pres->dispose();
}
}
设置系列在值为负时反转
Aspose.Slides 允许您通过 IChartDataPoint.InvertIfNegative
和 ChartDataPoint.InvertIfNegative
属性设置反转。当使用这些属性设置反转时,当数据点得到负值时,其颜色会反转。
以下 PHP 代码演示该操作:
$pres = new Presentation();
try {
$chart = $pres->getSlides()->get_Item(0)->getShapes()->addChart(ChartType::ClusteredColumn, 50, 50, 600, 400, true);
$series = $chart->getChartData()->getSeries();
$chart->getChartData()->getSeries()->clear();
$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 (!java_is_null($pres)) {
$pres->dispose();
}
}
清除特定数据点的数据
Aspose.Slides for PHP via Java 允许您以如下方式清除特定图表系列的 DataPoints
数据:
- 创建 Presentation 类的实例。
- 通过其索引获取幻灯片的引用。
- 通过其索引获取图表的引用。
- 遍历所有图表的
DataPoints
并将XValue
和YValue
设置为 null。 - 清除特定图表系列的所有
DataPoints
。 - 将修改后的演示文稿写入 PPTX 文件。
以下 PHP 代码演示该操作:
$pres = new Presentation("TestChart.pptx");
try {
$sl = $pres->getSlides()->get_Item(0);
$chart = $sl->getShapes()->get_Item(0);
foreach($chart->getChartData()->getSeries()->get_Item(0)->getDataPoints() as $dataPoint) {
$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 (!java_is_null($pres)) {
$pres->dispose();
}
}
设置系列间隔宽度
Aspose.Slides for PHP via Java 允许您通过 GapWidth
属性设置系列的间隔宽度,如下所示:
- 创建 Presentation 类的实例。
- 访问第一张幻灯片。
- 添加带有默认数据的图表。
- 访问任何图表系列。
- 设置
GapWidth
属性。 - 将修改后的演示文稿写入 PPTX 文件。
以下代码显示如何设置系列的间隔宽度:
# 创建空演示文稿
$pres = new Presentation();
try {
# 访问演示文稿的第一张幻灯片
$slide = $pres->getSlides()->get_Item(0);
# 添加带有默认数据的图表
$chart = $slide->getShapes()->addChart(ChartType::StackedColumn, 0, 0, 500, 500);
# 设置图表数据工作表的索引
$defaultWorksheetIndex = 0;
# 获取图表数据工作表
$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"));
# 取第二个图表系列
$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));
# 设置间隔宽度值
$series->getParentSeriesGroup()->setGapWidth(50);
# 保存演示文稿到磁盘
$pres->save("GapWidth_out.pptx", SaveFormat::Pptx);
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}