Textfelder in Präsentationen auf Android verwalten
Texte auf Folien befinden sich typischerweise in Textfeldern oder Formen. Daher müssen Sie, um Text zu einer Folie hinzuzufügen, ein Textfeld hinzufügen und dann Text in das Textfeld einfügen. Aspose.Slides für Android via Java stellt die IAutoShape Schnittstelle bereit, die es ermöglicht, eine Form mit Text hinzuzufügen.
Info
Aspose.Slides stellt außerdem die IShape Schnittstelle bereit, mit der Sie Formen zu Folien hinzufügen können. Allerdings können nicht alle über dieIShape‑Schnittstelle hinzugefügten Formen Text enthalten. Formen, die über die IAutoShape Schnittstelle hinzugefügt werden, können jedoch Text enthalten.
Note
Daher sollten Sie, wenn Sie mit einer Form arbeiten, zu der Sie Text hinzufügen möchten, prüfen und bestätigen, dass sie über dieIAutoShape‑Schnittstelle gecastet wurde. Nur dann können Sie mit TextFrame arbeiten, das eine Eigenschaft von IAutoShape ist. Siehe den Abschnitt Update Text auf dieser Seite.
Ein Textfeld auf einer Folie erstellen
- Erzeugen Sie eine Instanz der Klasse Presentation.
- Erhalten Sie eine Referenz zur ersten Folie in der neu erstellten Präsentation.
- Fügen Sie ein IAutoShape‑Objekt mit dem ShapeType
Rectanglean einer angegebenen Position auf der Folie hinzu und erhalten Sie die Referenz zum neu hinzugefügtenIAutoShape‑Objekt. - Fügen Sie dem
IAutoShape‑Objekt die EigenschaftTextFramehinzu, die einen Text enthalten wird. Im folgenden Beispiel haben wir diesen Text hinzugefügt: Aspose TextBox - Schließlich schreiben Sie die PPTX‑Datei über das
Presentation‑Objekt.
Dieser Java‑Code – eine Umsetzung der obigen Schritte – zeigt Ihnen, wie Sie Text zu einer Folie hinzufügen:
// Instanziert eine Präsentation
Presentation pres = new Presentation();
try {
// Ruft die erste Folie in der Präsentation ab
ISlide sld = pres.getSlides().get_Item(0);
// Fügt eine AutoShape mit dem Typ Rectangle hinzu
IAutoShape ashp = sld.getShapes().addAutoShape(ShapeType.Rectangle, 150, 75, 150, 50);
// Fügt dem Rechteck ein TextFrame hinzu
ashp.addTextFrame(" ");
// Greift auf das Textframe zu
ITextFrame txtFrame = ashp.getTextFrame();
// Erstellt das Paragraph-Objekt für das Textframe
IParagraph para = txtFrame.getParagraphs().get_Item(0);
// Erstellt ein Portion-Objekt für den Paragraphen
IPortion portion = para.getPortions().get_Item(0);
// Setzt Text
portion.setText("Aspose TextBox");
// Speichert die Präsentation auf die Festplatte
pres.save("TextBox_out.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
Überprüfen, ob ein Shape ein Textfeld ist
Aspose.Slides stellt die Methode isTextBox aus der IAutoShape Schnittstelle bereit, mit der Sie Shapes prüfen und Textfelder identifizieren können.

Dieser Java‑Code zeigt Ihnen, wie Sie prüfen können, ob ein Shape als Textfeld erstellt wurde:
Presentation presentation = new Presentation("sample.pptx");
try {
ForEach.shape(presentation, (shape, slide, index) -> {
if (shape instanceof IAutoShape) {
IAutoShape autoShape = (IAutoShape) shape;
System.out.println(autoShape.isTextBox() ? "shape is a text box" : "shape is not a text box");
}
});
} finally {
presentation.dispose();
}
Beachten Sie, dass wenn Sie einfach eine AutoShape mit der Methode addAutoShape aus der IShapeCollection‑Schnittstelle hinzufügen, die isTextBox‑Methode der AutoShape false zurückgibt. Nachdem Sie jedoch Text zur AutoShape mit der Methode addTextFrame oder setText hinzugefügt haben, gibt die Eigenschaft isTextBox true zurück.
Presentation presentation = new Presentation();
ISlide slide = presentation.getSlides().get_Item(0);
IAutoShape shape1 = slide.getShapes().addAutoShape(ShapeType.Rectangle, 10, 10, 100, 40);
// shape1.isTextBox() gibt false zurück
shape1.addTextFrame("shape 1");
// shape1.isTextBox() gibt true zurück
IAutoShape shape2 = slide.getShapes().addAutoShape(ShapeType.Rectangle, 10, 110, 100, 40);
// shape2.isTextBox() gibt false zurück
shape2.getTextFrame().setText("shape 2");
// shape2.isTextBox() gibt true zurück
IAutoShape shape3 = slide.getShapes().addAutoShape(ShapeType.Rectangle, 10, 210, 100, 40);
// shape3.isTextBox() gibt false zurück
shape3.addTextFrame("");
// shape3.isTextBox() gibt false zurück
IAutoShape shape4 = slide.getShapes().addAutoShape(ShapeType.Rectangle, 10, 310, 100, 40);
// shape4.isTextBox() gibt false zurück
shape4.getTextFrame().setText("");
// shape4.isTextBox() gibt false zurück
Spalten zu einem Textfeld hinzufügen
Aspose.Slides stellt die Eigenschaften ColumnCount und ColumnSpacing (aus der ITextFrameFormat‑Schnittstelle und der Klasse TextFrameFormat) bereit, mit denen Sie Spalten zu Textfeldern hinzufügen können. Sie können die Anzahl der Spalten in einem Textfeld festlegen und den Abstand zwischen den Spalten in Punkten einstellen.
Dieser Java‑Code demonstriert die beschriebene Vorgehensweise:
Presentation pres = new Presentation();
try {
// Ruft die erste Folie in der Präsentation ab
ISlide slide = pres.getSlides().get_Item(0);
// Fügt eine AutoShape mit dem Typ Rectangle hinzu
IAutoShape aShape = slide.getShapes().addAutoShape(ShapeType.Rectangle, 100, 100, 300, 300);
// Fügt dem Rechteck ein TextFrame hinzu
aShape.addTextFrame("All these columns are limited to be within a single text container -- " +
"you can add or delete text and the new or remaining text automatically adjusts " +
"itself to flow within the container. You cannot have text flow from one container " +
"to other though -- we told you PowerPoint's column options for text are limited!");
// Ruft das Textformat des TextFrames ab
ITextFrameFormat format = aShape.getTextFrame().getTextFrameFormat();
// Legt die Anzahl der Spalten im TextFrame fest
format.setColumnCount(3);
// Legt den Abstand zwischen den Spalten fest
format.setColumnSpacing(10);
// Speichert die Präsentation
pres.save("ColumnCount.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
Spalten zu einem Textframe hinzufügen
Aspose.Slides für Android via Java stellt die Eigenschaft ColumnCount (aus der ITextFrameFormat‑Schnittstelle) bereit, mit der Sie Spalten in Textframes hinzufügen können. Über diese Eigenschaft können Sie die gewünschte Anzahl von Spalten in einem Textframe festlegen.
Dieser Java‑Code zeigt Ihnen, wie Sie einer Textframe eine Spalte hinzufügen:
String outPptxFileName = "ColumnsTest.pptx";
Presentation pres = new Presentation();
try {
IAutoShape shape1 = pres.getSlides().get_Item(0).getShapes().addAutoShape(ShapeType.Rectangle, 100, 100, 300, 300);
TextFrameFormat format = (TextFrameFormat)shape1.getTextFrame().getTextFrameFormat();
format.setColumnCount(2);
shape1.getTextFrame().setText("All these columns are forced to stay within a single text container -- " +
"you can add or delete text - and the new or remaining text automatically adjusts " +
"itself to stay within the container. You cannot have text spill over from one container " +
"to other, though -- because PowerPoint's column options for text are limited!");
pres.save(outPptxFileName, SaveFormat.Pptx);
Presentation test = new Presentation(outPptxFileName);
try {
IAutoShape autoShape = ((AutoShape)test.getSlides().get_Item(0).getShapes().get_Item(0));
Assert.assertTrue(2 == autoShape.getTextFrame().getTextFrameFormat().getColumnCount());
Assert.assertTrue(Double.NaN == autoShape.getTextFrame().getTextFrameFormat().getColumnSpacing());
} finally {
if (test != null) test.dispose();
}
format.setColumnSpacing(20);
pres.save(outPptxFileName, SaveFormat.Pptx);
Presentation test1 = new Presentation(outPptxFileName);
try {
IAutoShape autoShape = ((AutoShape)test1.getSlides().get_Item(0).getShapes().get_Item(0));
Assert.assertTrue(2 == autoShape.getTextFrame().getTextFrameFormat().getColumnCount());
Assert.assertTrue(20 == autoShape.getTextFrame().getTextFrameFormat().getColumnSpacing());
} finally {
if (test1 != null) test1.dispose();
}
format.setColumnCount(3);
format.setColumnSpacing(15);
pres.save(outPptxFileName, SaveFormat.Pptx);
Presentation test2 = new Presentation(outPptxFileName);
try {
IAutoShape autoShape = ((AutoShape)test2.getSlides().get_Item(0).getShapes().get_Item(0));
Assert.assertTrue(3 == autoShape.getTextFrame().getTextFrameFormat().getColumnCount());
Assert.assertTrue(15 == autoShape.getTextFrame().getTextFrameFormat().getColumnSpacing());
} finally {
if (test2 != null) test2.dispose();
}
} finally {
if (pres != null) pres.dispose();
}
Text aktualisieren
Aspose.Slides ermöglicht es Ihnen, den Text in einem Textfeld oder allen Texten in einer Präsentation zu ändern oder zu aktualisieren.
Dieser Java‑Code demonstriert einen Vorgang, bei dem alle Texte in einer Präsentation aktualisiert oder geändert werden:
Presentation pres = new Presentation("text.pptx");
try {
for (ISlide slide : pres.getSlides())
{
for (IShape shape : slide.getShapes())
{
if (shape instanceof IAutoShape) // Prüft, ob die Form einen Textframe unterstützt (IAutoShape).
{
IAutoShape autoShape = (IAutoShape)shape;
for (IParagraph paragraph : autoShape.getTextFrame().getParagraphs()) // Durchläuft Absätze im Textframe
{
for (IPortion portion : paragraph.getPortions()) // Durchläuft jede Portion im Absatz
{
portion.setText(portion.getText().replace("years", "months")); // Ändert den Text
portion.getPortionFormat().setFontBold(NullableBool.True); // Ändert die Formatierung
}
}
}
}
}
// Speichert die geänderte Präsentation
pres.save("text-changed.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
Ein Textfeld mit Hyperlink hinzufügen
Sie können einen Link in ein Textfeld einfügen. Wenn das Textfeld angeklickt wird, wird der Link geöffnet.
Um ein Textfeld mit einem Link hinzuzufügen, gehen Sie wie folgt vor:
- Erzeugen Sie eine Instanz der Klasse
Presentation. - Erhalten Sie eine Referenz zur ersten Folie in der neu erstellten Präsentation.
- Fügen Sie ein
AutoShape‑Objekt mitShapeTypeRectanglean einer angegebenen Position auf der Folie hinzu und erhalten Sie die Referenz zum neu hinzugefügten AutoShape‑Objekt. - Fügen Sie dem
AutoShape‑Objekt einTextFramehinzu, das Aspose TextBox als Standardtext enthält. - Instanziieren Sie die Klasse
IHyperlinkManager. - Weisen Sie das
IHyperlinkManager‑Objekt der Eigenschaft HyperlinkClick zu, die mit dem gewünschten Teil desTextFrameverknüpft ist. - Schließlich schreiben Sie die PPTX‑Datei über das
Presentation‑Objekt.
Dieser Java‑Code – eine Umsetzung der obigen Schritte – zeigt Ihnen, wie Sie ein Textfeld mit Hyperlink zu einer Folie hinzufügen:
// Instanziert eine Presentation-Klasse, die eine PPTX repräsentiert
Presentation pres = new Presentation();
try {
// Ruft die erste Folie in der Präsentation ab
ISlide slide = pres.getSlides().get_Item(0);
// Fügt ein AutoShape-Objekt mit dem Typ Rechteck hinzu
IShape shape = slide.getShapes().addAutoShape(ShapeType.Rectangle, 150, 150, 150, 50);
// Wandelt die Form in AutoShape um
IAutoShape pptxAutoShape = (IAutoShape)shape;
// Greift auf die ITextFrame-Eigenschaft zu, die mit dem AutoShape verknüpft ist
pptxAutoShape.addTextFrame("");
ITextFrame textFrame = pptxAutoShape.getTextFrame();
// Fügt dem Frame etwas Text hinzu
textFrame.getParagraphs().get_Item(0).getPortions().get_Item(0).setText("Aspose.Slides");
// Setzt den Hyperlink für den Portionstext
IHyperlinkManager hyperlinkManager = textFrame.getParagraphs().get_Item(0).getPortions().get_Item(0).
getPortionFormat().getHyperlinkManager();
hyperlinkManager.setExternalHyperlinkClick("http://www.aspose.com");
// Speichert die PPTX-Präsentation
pres.save("hLink_out.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
FAQ
Was ist der Unterschied zwischen einem Textfeld und einem Text‑Platzhalter bei der Arbeit mit Master‑Folien?
Ein Platzhalter erbt Stil/Position vom Master und kann in den Layouts überschrieben werden, während ein normales Textfeld ein unabhängiges Objekt auf einer bestimmten Folie ist und sich nicht ändert, wenn Sie das Layout wechseln.
Wie kann ich einen massiven Textaustausch in der gesamten Präsentation durchführen, ohne Text in Diagrammen, Tabellen und SmartArt zu berühren?
Beschränken Sie die Iteration auf AutoShapes, die TextFrames besitzen, und schließen Sie eingebettete Objekte (Diagramme, Tabellen, SmartArt) aus, indem Sie deren Sammlungen separat durchlaufen oder diese Objekttypen überspringen.