Gérer les zones de texte dans les présentations avec Java
Les textes sur les diapositives se trouvent généralement dans des zones de texte ou des formes. Ainsi, pour ajouter du texte à une diapositive, vous devez ajouter une zone de texte, puis y placer du texte. Aspose.Slides for Java fournit l’interface IAutoShape qui permet d’ajouter une forme contenant du texte.
Info
Aspose.Slides fournit également l’interface IShape qui permet d’ajouter des formes aux diapositives. Cependant, toutes les formes ajoutées via l’interfaceIShape ne peuvent pas contenir de texte. En revanche, les formes ajoutées via l’interface IAutoShape peuvent contenir du texte.
Note
Par conséquent, lorsque vous traitez une forme à laquelle vous souhaitez ajouter du texte, il est conseillé de vérifier et de confirmer qu’elle a été castée via l’interfaceIAutoShape. Ce n’est qu’alors que vous pourrez travailler avec TextFrame, qui est une propriété de IAutoShape. Consultez la section Update Text de cette page.
Créer une zone de texte sur une diapositive
Pour créer une zone de texte sur une diapositive, suivez ces étapes :
- Créez une instance de la classe Presentation.
- Obtenez une référence à la première diapositive de la présentation nouvellement créée.
- Ajoutez un objet IAutoShape avec le
ShapeTypedéfini surRectangleà une position spécifiée sur la diapositive et récupérez la référence de l’objetIAutoShapeajouté. - Ajoutez une propriété
TextFrameà l’objetIAutoShapequi contiendra du texte. Dans l’exemple ci‑dessous, nous avons ajouté ce texte : Aspose TextBox - Enfin, écrivez le fichier PPTX via l’objet
Presentation.
Ce code Java – une implémentation des étapes ci‑dessus – montre comment ajouter du texte à une diapositive :
// Instancie la présentation
Presentation pres = new Presentation();
try {
// Obtient la première diapositive de la présentation
ISlide sld = pres.getSlides().get_Item(0);
// Ajoute une AutoShape dont le type est Rectangle
IAutoShape ashp = sld.getShapes().addAutoShape(ShapeType.Rectangle, 150, 75, 150, 50);
// Ajoute un TextFrame au rectangle
ashp.addTextFrame(" ");
// Accède au cadre de texte
ITextFrame txtFrame = ashp.getTextFrame();
// Crée l'objet Paragraph pour le cadre de texte
IParagraph para = txtFrame.getParagraphs().get_Item(0);
// Crée un objet Portion pour le paragraphe
IPortion portion = para.getPortions().get_Item(0);
// Définit le texte
portion.setText("Aspose TextBox");
// Enregistre la présentation sur le disque
pres.save("TextBox_out.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
Vérifier la présence d’une forme de zone de texte
Aspose.Slides fournit la méthode isTextBox de l’interface IAutoShape qui permet d’examiner les formes et d’identifier les zones de texte.

Ce code Java montre comment vérifier si une forme a été créée en tant que zone de texte :
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();
}
Notez que si vous ajoutez simplement une forme automatique avec la méthode addAutoShape de l’interface IShapeCollection, la méthode isTextBox de la forme automatique renverra false. En revanche, après avoir ajouté du texte à la forme automatique avec la méthode addTextFrame ou la méthode setText, la propriété isTextBox renverra true.
Presentation presentation = new Presentation();
ISlide slide = presentation.getSlides().get_Item(0);
IAutoShape shape1 = slide.getShapes().addAutoShape(ShapeType.Rectangle, 10, 10, 100, 40);
// shape1.isTextBox() renvoie false
shape1.addTextFrame("shape 1");
// shape1.isTextBox() renvoie true
IAutoShape shape2 = slide.getShapes().addAutoShape(ShapeType.Rectangle, 10, 110, 100, 40);
// shape2.isTextBox() renvoie false
shape2.getTextFrame().setText("shape 2");
// shape2.isTextBox() renvoie true
IAutoShape shape3 = slide.getShapes().addAutoShape(ShapeType.Rectangle, 10, 210, 100, 40);
// shape3.isTextBox() renvoie false
shape3.addTextFrame("");
// shape3.isTextBox() renvoie false
IAutoShape shape4 = slide.getShapes().addAutoShape(ShapeType.Rectangle, 10, 310, 100, 40);
// shape4.isTextBox() renvoie false
shape4.getTextFrame().setText("");
// shape4.isTextBox() renvoie false
Ajouter des colonnes à une zone de texte
Aspose.Slides fournit les propriétés ColumnCount et ColumnSpacing (de l’interface ITextFrameFormat et de la classe TextFrameFormat) qui permettent d’ajouter des colonnes aux zones de texte. Vous pouvez spécifier le nombre de colonnes dans une zone de texte et définir l’espacement en points entre les colonnes.
Ce code Java illustre l’opération décrite :
Presentation pres = new Presentation();
try {
// Obtient la première diapositive de la présentation
ISlide slide = pres.getSlides().get_Item(0);
// Ajoute une AutoShape dont le type est Rectangle
IAutoShape aShape = slide.getShapes().addAutoShape(ShapeType.Rectangle, 100, 100, 300, 300);
// Ajoute un TextFrame au rectangle
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!");
// Obtient le format de texte du TextFrame
ITextFrameFormat format = aShape.getTextFrame().getTextFrameFormat();
// Définit le nombre de colonnes dans le TextFrame
format.setColumnCount(3);
// Définit l'espacement entre les colonnes
format.setColumnSpacing(10);
// Enregistre la présentation
pres.save("ColumnCount.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
Ajouter des colonnes à un cadre de texte
Aspose.Slides for Java fournit la propriété ColumnCount (de l’interface ITextFrameFormat) qui permet d’ajouter des colonnes aux cadres de texte. Grâce à cette propriété, vous pouvez définir le nombre de colonnes souhaité dans un cadre de texte.
Ce code Java montre comment ajouter une colonne dans un cadre de texte :
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();
}
Mettre à jour le texte
Aspose.Slides vous permet de modifier ou de mettre à jour le texte contenu dans une zone de texte ou tous les textes d’une présentation.
Ce code Java montre une opération où tous les textes d’une présentation sont mis à jour ou modifiés :
Presentation pres = new Presentation("text.pptx");
try {
for (ISlide slide : pres.getSlides())
{
for (IShape shape : slide.getShapes())
{
if (shape instanceof IAutoShape) //Vérifie si la forme prend en charge le cadre de texte (IAutoShape).
{
IAutoShape autoShape = (IAutoShape)shape;
for (IParagraph paragraph : autoShape.getTextFrame().getParagraphs()) //Parcourt les paragraphes du cadre de texte
{
for (IPortion portion : paragraph.getPortions()) //Parcourt chaque portion du paragraphe
{
portion.setText(portion.getText().replace("years", "months")); //Modifie le texte
portion.getPortionFormat().setFontBold(NullableBool.True); //Modifie le formatage
}
}
}
}
}
//Enregistre la présentation modifiée
pres.save("text-changed.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
Ajouter une zone de texte avec un hyperlien
Vous pouvez insérer un lien dans une zone de texte. Lorsque la zone de texte est cliquée, les utilisateurs sont dirigés vers le lien.
Pour ajouter une zone de texte contenant un lien, suivez ces étapes :
- Créez une instance de la classe
Presentation. - Obtenez une référence à la première diapositive de la présentation nouvellement créée.
- Ajoutez un objet
AutoShapeavec leShapeTypedéfini surRectangleà une position spécifiée sur la diapositive et récupérez la référence de l’objet AutoShape ajouté. - Ajoutez un
TextFrameà l’objetAutoShapecontenant Aspose TextBox comme texte par défaut. - Instanciez la classe
IHyperlinkManager. - Assignez l’objet
IHyperlinkManagerà la propriété HyperlinkClick associée à la partie souhaitée duTextFrame. - Enfin, écrivez le fichier PPTX via l’objet
Presentation.
Ce code Java – une implémentation des étapes ci‑dessus – montre comment ajouter une zone de texte avec un hyperlien à une diapositive :
// Instancie une classe Presentation qui représente un PPTX
Presentation pres = new Presentation();
try {
// Obtient la première diapositive de la présentation
ISlide slide = pres.getSlides().get_Item(0);
// Ajoute un objet AutoShape dont le type est Rectangle
IShape shape = slide.getShapes().addAutoShape(ShapeType.Rectangle, 150, 150, 150, 50);
// Convertit la forme en AutoShape
IAutoShape pptxAutoShape = (IAutoShape)shape;
// Accède à la propriété ITextFrame associée à l'AutoShape
pptxAutoShape.addTextFrame("");
ITextFrame textFrame = pptxAutoShape.getTextFrame();
// Ajoute du texte au cadre
textFrame.getParagraphs().get_Item(0).getPortions().get_Item(0).setText("Aspose.Slides");
// Définit le lien hypertexte pour le texte de la portion
IHyperlinkManager hyperlinkManager = textFrame.getParagraphs().get_Item(0).getPortions().get_Item(0).
getPortionFormat().getHyperlinkManager();
hyperlinkManager.setExternalHyperlinkClick("http://www.aspose.com");
// Enregistre la présentation PPTX
pres.save("hLink_out.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
FAQ
Quelle est la différence entre une zone de texte et un espace réservé de texte lorsqu’on travaille avec les diapositives maîtres ?
Un placeholder hérite du style/position de la maître et peut être remplacé sur les layouts, tandis qu’une zone de texte ordinaire est un objet indépendant sur une diapositive spécifique et ne change pas lorsque vous changez de layout.
Comment effectuer un remplacement massif de texte dans toute la présentation sans toucher au texte des graphiques, tableaux et SmartArt ?
Limitez votre itération aux formes automatiques qui possèdent des cadres de texte et excluez les objets intégrés (charts, tables, SmartArt) en parcourant leurs collections séparément ou en sautant ces types d’objets.