SmartArt-Grafiken in Präsentationen mit PHP verwalten
Eine SmartArt‑Form erstellen
Aspose.Slides for PHP via Java stellt eine API zum Erstellen von SmartArt‑Formen bereit. So erstellen Sie eine SmartArt‑Form in einer Folie:
- Erzeugen Sie eine Instanz der Klasse Presentation.
- Holen Sie sich die Referenz einer Folie über deren Index.
- Fügen Sie eine SmartArt‑Form hinzu und setzen Sie den LayoutType.
- Speichern Sie die geänderte Präsentation als PPTX‑Datei.
# Präsentationsklasse instanziieren
$pres = new Presentation();
try {
# Erste Folie abrufen
$slide = $pres->getSlides()->get_Item(0);
# SmartArt-Form hinzufügen
$smart = $slide->getShapes()->addSmartArt(0, 0, 400, 400, SmartArtLayoutType::BasicBlockList);
# Präsentation speichern
$pres->save("SimpleSmartArt.pptx", SaveFormat::Pptx);
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}
![]() |
|---|
| Abbildung: SmartArt‑Form zur Folie hinzugefügt |
Auf eine SmartArt‑Form in einer Folie zugreifen
Im folgenden Code wird auf die in der Präsentationsfolie hinzugefügten SmartArt‑Formen zugegriffen. Im Beispielcode durchlaufen wir jede Form in der Folie und prüfen, ob es sich um eine SmartArt‑Form handelt. Ist die Form vom Typ SmartArt, wird sie zu einer SmartArt‑Instanz gecastet.
# Gewünschte Präsentation laden
$pres = new Presentation("AccessSmartArtShape.pptx");
try {
# Durch alle Formen der ersten Folie traversieren
foreach($pres->getSlides()->get_Item(0)->getShapes() as $shape) {
# Prüfen, ob die Form vom SmartArt-Typ ist
if (java_instanceof($shape, new JavaClass("com.aspose.slides.SmartArt"))) {
# Form zu SmartArtEx typisieren
$smart = $shape;
echo("Shape Name:" . $smart->getName());
}
}
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}
Auf eine SmartArt‑Form mit einem bestimmten Layouttyp zugreifen
Der folgende Beispielcode zeigt, wie Sie die SmartArt‑Form mit einem bestimmten LayoutType abrufen können. Beachten Sie, dass Sie den LayoutType der SmartArt nicht ändern können, da er nur beim Hinzufügen der SmartArt‑Form festgelegt wird und schreibgeschützt ist.
- Erzeugen Sie eine Instanz der Klasse Presentation und laden Sie die Präsentation mit SmartArt‑Form.
- Holen Sie sich die Referenz der ersten Folie über deren Index.
- Durchlaufen Sie jede Form in der ersten Folie.
- Prüfen Sie, ob die Form vom Typ SmartArt ist, und casten Sie die ausgewählte Form zu SmartArt, falls sie SmartArt ist.
- Prüfen Sie die SmartArt‑Form mit dem gewünschten LayoutType und führen Sie die erforderlichen Aktionen danach aus.
$pres = new Presentation("AccessSmartArtShape.pptx");
try {
# Durch alle Formen der ersten Folie traversieren
foreach($pres->getSlides()->get_Item(0)->getShapes() as $shape) {
# Prüfen, ob die Form vom SmartArt-Typ ist
if (java_instanceof($shape, new JavaClass("com.aspose.slides.SmartArt"))) {
# Form zu SmartArtEx typisieren
$smart = $shape;
# SmartArt-Layout prüfen
if ($smart->getLayout() == SmartArtLayoutType::BasicBlockList) {
echo("Do some thing here....");
}
}
}
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}
Den Stil einer SmartArt‑Form ändern
In diesem Beispiel lernen wir, wie der Schnellstil einer beliebigen SmartArt‑Form geändert wird.
- Erzeugen Sie eine Instanz der Klasse Presentation und laden Sie die Präsentation mit SmartArt‑Form.
- Holen Sie sich die Referenz der ersten Folie über deren Index.
- Durchlaufen Sie jede Form in der ersten Folie.
- Prüfen Sie, ob die Form vom Typ SmartArt ist, und casten Sie die ausgewählte Form zu SmartArt, falls sie SmartArt ist.
- Finden Sie die SmartArt‑Form mit dem gewünschten Stil.
- Setzen Sie den neuen Stil für die SmartArt‑Form.
- Speichern Sie die Präsentation.
# Präsentationsklasse instanziieren
$pres = new Presentation("SimpleSmartArt.pptx");
try {
# Erste Folie abrufen
$slide = $pres->getSlides()->get_Item(0);
# Durch alle Formen der ersten Folie traversieren
foreach($slide->getShapes() as $shape) {
# Prüfen, ob die Form vom SmartArt-Typ ist
if (java_instanceof($shape, new JavaClass("com.aspose.slides.SmartArt"))) {
# Form zu SmartArtEx typisieren
$smart = $shape;
# SmartArt-Stil prüfen
if ($smart->getQuickStyle() == SmartArtQuickStyleType::SimpleFill) {
# SmartArt-Stil ändern
$smart->setQuickStyle(SmartArtQuickStyleType::Cartoon);
}
}
}
# Präsentation speichern
$pres->save("ChangeSmartArtStyle.pptx", SaveFormat::Pptx);
} finally {
$pres->dispose();
}
![]() |
|---|
| Abbildung: SmartArt‑Form mit geändertem Stil |
Die Farbformatierung einer SmartArt‑Form ändern
In diesem Beispiel lernen wir, wie die Farbformatierung einer beliebigen SmartArt‑Form geändert wird. Der folgende Beispielcode greift auf die SmartArt‑Form mit einer bestimmten Farbformatierung zu und ändert ihren Stil.
- Erzeugen Sie eine Instanz der Klasse Presentation und laden Sie die Präsentation mit SmartArt‑Form.
- Holen Sie sich die Referenz der ersten Folie über deren Index.
- Durchlaufen Sie jede Form in der ersten Folie.
- Prüfen Sie, ob die Form vom Typ SmartArt ist, und casten Sie die ausgewählte Form zu SmartArt, falls sie SmartArt ist.
- Finden Sie die SmartArt‑Form mit der gewünschten Farbformatierung.
- Setzen Sie die neue Farbformatierung für die SmartArt‑Form.
- Speichern Sie die Präsentation.
# Präsentationsklasse instanziieren
$pres = new Presentation("SimpleSmartArt.pptx");
try {
# Erste Folie abrufen
$slide = $pres->getSlides()->get_Item(0);
# Durch alle Formen der ersten Folie traversieren
foreach($slide->getShapes() as $shape) {
# Prüfen, ob die Form vom SmartArt-Typ ist
if (java_instanceof($shape, new JavaClass("com.aspose.slides.SmartArt"))) {
# Form zu SmartArtEx typisieren
$smart = $shape;
# SmartArt-Farbtyp prüfen
if ($smart->getColorStyle() == SmartArtColorType::ColoredFillAccent1) {
# SmartArt-Farbtyp ändern
$smart->setColorStyle(SmartArtColorType::ColorfulAccentColors);
}
}
}
# Präsentation speichern
$pres->save("ChangeSmartArtColorStyle.pptx", SaveFormat::Pptx);
} finally {
$pres->dispose();
}
![]() |
|---|
| Abbildung: SmartArt‑Form mit geänderter Farbformatierung |
FAQ
Kann ich SmartArt als ein einziges Objekt animieren?
Ja. SmartArt ist eine Form, sodass Sie über die Animations‑API Standardanimationen (Einstieg, Ausgang, Hervorhebung, Bewegungsbahnen) genauso wie bei anderen Formen anwenden können.
Wie finde ich ein bestimmtes SmartArt‑Objekt auf einer Folie, wenn ich seine interne ID nicht kenne?
Verwenden Sie den Alternativtext (AltText) und suchen Sie die Form nach diesem Wert – dies ist ein empfohlener Weg, um die Ziel‑Form zu lokalisieren.
Kann ich SmartArt mit anderen Formen gruppieren?
Ja. Sie können SmartArt mit anderen Formen (Bildern, Tabellen usw.) gruppieren und dann die Gruppe manipulieren.
Wie erhalte ich ein Bild eines bestimmten SmartArt‑Objekts (z. B. für eine Vorschau oder einen Bericht)?
Exportieren Sie ein Miniatur‑/Bild der Form; die Bibliothek kann einzelne Formen als Rasterdateien (PNG/JPG/TIFF) rendern.
Wird das Aussehen von SmartArt beim Konvertieren der gesamten Präsentation in PDF erhalten bleiben?
Ja. Die Rendering‑Engine strebt eine hohe Treue beim PDF‑Export an und bietet verschiedene Qualitäts‑ und Kompatibilitätsoptionen.

