Gérer les paragraphes de texte PowerPoint en .NET
Aspose.Slides fournit toutes les interfaces et classes dont vous avez besoin pour travailler avec les textes, paragraphes et portions PowerPoint en C#.
- Aspose.Slides fournit l’interface ITextFrame pour vous permettre d’ajouter des objets qui représentent un paragraphe. Un objet
ITextFamepeut contenir un ou plusieurs paragraphes (chaque paragraphe est créé par un retour chariot). - Aspose.Slides fournit l’interface IParagraph pour vous permettre d’ajouter des objets qui représentent des portions. Un objet
IParagraphpeut contenir une ou plusieurs portions (collection d’objets iPortions). - Aspose.Slides fournit l’interface IPortion pour vous permettre d’ajouter des objets qui représentent des textes et leurs propriétés de mise en forme.
Un objet IParagraph peut gérer des textes avec différentes propriétés de mise en forme grâce à ses objets IPortion sous‑jacents.
Add Multiple Paragraphs Containing Multiple Portions
Ces étapes montrent comment ajouter un cadre de texte contenant 3 paragraphes, chaque paragraphe contenant 3 portions :
- Créez une instance de la classe Presentation.
- Accédez à la référence de la diapositive concernée par son index.
- Ajoutez un rectangle IAutoShape à la diapositive.
- Récupérez le ITextFrame associé au IAutoShape.
- Créez deux objets IParagraph et ajoutez‑les à la collection
IParagraphsdu ITextFrame. - Créez trois objets IPortion pour chaque nouveau
IParagraph(deux objets Portion pour le paragraphe par défaut) et ajoutez chaque objetIPortionà la collection IPortion de chaqueIParagraph. - Définissez du texte pour chaque portion.
- Appliquez les options de mise en forme souhaitées à chaque portion en utilisant les propriétés de mise en forme exposées par l’objet
IPortion. - Enregistrez la présentation modifiée.
Ce code C# implémente les étapes d’ajout de paragraphes contenant des portions :
// Instancie une classe Presentation représentant un fichier PPTX
using (Presentation pres = new Presentation())
{
// Accède à la première diapositive
ISlide slide = pres.Slides[0];
// Ajoute une IAutoShape rectangle
IAutoShape ashp = slide.Shapes.AddAutoShape(ShapeType.Rectangle, 50, 150, 300, 150);
// Accède au TextFrame de l'AutoShape
ITextFrame tf = ashp.TextFrame;
// Crée des Paragraphs et Portions avec différents formats de texte
IParagraph para0 = tf.Paragraphs[0];
IPortion port01 = new Portion();
IPortion port02 = new Portion();
para0.Portions.Add(port01);
para0.Portions.Add(port02);
IParagraph para1 = new Paragraph();
tf.Paragraphs.Add(para1);
IPortion port10 = new Portion();
IPortion port11 = new Portion();
IPortion port12 = new Portion();
para1.Portions.Add(port10);
para1.Portions.Add(port11);
para1.Portions.Add(port12);
IParagraph para2 = new Paragraph();
tf.Paragraphs.Add(para2);
IPortion port20 = new Portion();
IPortion port21 = new Portion();
IPortion port22 = new Portion();
para2.Portions.Add(port20);
para2.Portions.Add(port21);
para2.Portions.Add(port22);
for (int i = 0; i < 3; i++)
for (int j = 0; j < 3; j++)
{
tf.Paragraphs[i].Portions[j].Text = "Portion0" + j.ToString();
if (j == 0)
{
tf.Paragraphs[i].Portions[j].PortionFormat.FillFormat.FillType = FillType.Solid;
tf.Paragraphs[i].Portions[j].PortionFormat.FillFormat.SolidFillColor.Color = Color.Red;
tf.Paragraphs[i].Portions[j].PortionFormat.FontBold = NullableBool.True;
tf.Paragraphs[i].Portions[j].PortionFormat.FontHeight = 15;
}
else if (j == 1)
{
tf.Paragraphs[i].Portions[j].PortionFormat.FillFormat.FillType = FillType.Solid;
tf.Paragraphs[i].Portions[j].PortionFormat.FillFormat.SolidFillColor.Color = Color.Blue;
tf.Paragraphs[i].Portions[j].PortionFormat.FontItalic = NullableBool.True;
tf.Paragraphs[i].Portions[j].PortionFormat.FontHeight = 18;
}
}
// Enregistre la présentation modifiée
pres.Save("multiParaPort_out.pptx", SaveFormat.Pptx);
}
Manage Paragraph Bullets
Les listes à puces vous aident à organiser et présenter les informations rapidement et efficacement. Les paragraphes à puces sont toujours plus faciles à lire et à comprendre.
- Créez une instance de la classe Presentation.
- Accédez à la référence de la diapositive concernée par son index.
- Ajoutez une autoshape à la diapositive sélectionnée.
- Accédez au TextFrame de l’autoshape.
- Supprimez le paragraphe par défaut du
TextFrame. - Créez la première instance de paragraphe en utilisant la classe Paragraph.
- Définissez le
Typede la puce du paragraphe surSymbolet indiquez le caractère de puce. - Définissez le
Textdu paragraphe. - Définissez l’
Indentdu paragraphe pour la puce. - Définissez une couleur pour la puce.
- Définissez une hauteur pour la puce.
- Ajoutez le nouveau paragraphe à la collection de paragraphes du
TextFrame. - Ajoutez le deuxième paragraphe et répétez le processus indiqué aux étapes 7 à 13.
- Enregistrez la présentation.
Ce code C# montre comment ajouter une puce de paragraphe :
// Instancie une classe Presentation représentant un fichier PPTX
using (Presentation pres = new Presentation())
{
// Accède à la première diapositive
ISlide slide = pres.Slides[0];
// Ajoute et accède à l'AutoShape
IAutoShape aShp = slide.Shapes.AddAutoShape(ShapeType.Rectangle, 200, 200, 400, 200);
// Accède au cadre de texte de l'autoforme
ITextFrame txtFrm = aShp.TextFrame;
// Supprime le paragraphe par défaut
txtFrm.Paragraphs.RemoveAt(0);
// Crée un paragraphe
Paragraph para = new Paragraph();
// Définit le style et le symbole de la puce du paragraphe
para.ParagraphFormat.Bullet.Type = BulletType.Symbol;
para.ParagraphFormat.Bullet.Char = Convert.ToChar(8226);
// Définit le texte du paragraphe
para.Text = "Welcome to Aspose.Slides";
// Définit le retrait de la puce
para.ParagraphFormat.Indent = 25;
// Définit la couleur de la puce
para.ParagraphFormat.Bullet.Color.ColorType = ColorType.RGB;
para.ParagraphFormat.Bullet.Color.Color = Color.Black;
para.ParagraphFormat.Bullet.IsBulletHardColor = NullableBool.True; // définir IsBulletHardColor à true pour utiliser la couleur de puce propre
// Définit la hauteur de la puce
para.ParagraphFormat.Bullet.Height = 100;
// Ajoute le paragraphe au cadre de texte
txtFrm.Paragraphs.Add(para);
// Crée le deuxième paragraphe
Paragraph para2 = new Paragraph();
// Définit le type et le style de la puce du paragraphe
para2.ParagraphFormat.Bullet.Type = BulletType.Numbered;
para2.ParagraphFormat.Bullet.NumberedBulletStyle = NumberedBulletStyle.BulletCircleNumWDBlackPlain;
// Ajoute le texte du paragraphe
para2.Text = "This is numbered bullet";
// Définit le retrait de la puce
para2.ParagraphFormat.Indent = 25;
para2.ParagraphFormat.Bullet.Color.ColorType = ColorType.RGB;
para2.ParagraphFormat.Bullet.Color.Color = Color.Black;
para2.ParagraphFormat.Bullet.IsBulletHardColor = NullableBool.True; // définir IsBulletHardColor à true pour utiliser la couleur de puce propre
// Définit la hauteur de la puce
para2.ParagraphFormat.Bullet.Height = 100;
// Ajoute le paragraphe au cadre de texte
txtFrm.Paragraphs.Add(para2);
// Enregistre la présentation modifiée
pres.Save("Bullet_out.pptx", SaveFormat.Pptx);
}
Manage Picture Bullets
Les listes à puces vous aident à organiser et présenter les informations rapidement et efficacement. Les paragraphes d’image sont faciles à lire et à comprendre.
- Créez une instance de la classe Presentation.
- Accédez à la référence de la diapositive concernée par son index.
- Ajoutez une autoshape à la diapositive.
- Accédez au TextFrame de l’autoshape.
- Supprimez le paragraphe par défaut du
TextFrame. - Créez la première instance de paragraphe en utilisant la classe Paragraph.
- Chargez l’image dans IPPImage.
- Définissez le type de puce sur Picture et indiquez l’image.
- Définissez le
Textdu paragraphe. - Définissez l’
Indentdu paragraphe pour la puce. - Définissez une couleur pour la puce.
- Définissez une hauteur pour la puce.
- Ajoutez le nouveau paragraphe à la collection de paragraphes du
TextFrame. - Ajoutez le deuxième paragraphe et répétez le processus basé sur les étapes précédentes.
- Enregistrez la présentation modifiée.
Ce code C# montre comment ajouter et gérer des puces d’image :
// Instancie une classe Presentation qui représente un fichier PPTX
Presentation presentation = new Presentation();
// Accède à la première diapositive
ISlide slide = presentation.Slides[0];
// Instancie l'image pour les puces
IImage image = Images.FromFile("bullets.png");
IPPImage ippxImage = presentation.Images.AddImage(image);
image.Dispose();
// Ajoute et accède à l'AutoShape
IAutoShape autoShape = slide.Shapes.AddAutoShape(ShapeType.Rectangle, 200, 200, 400, 200);
// Accède au TextFrame de l'autoshape
ITextFrame textFrame = autoShape.TextFrame;
// Supprime le paragraphe par défaut
textFrame.Paragraphs.RemoveAt(0);
// Crée un nouveau paragraphe
Paragraph paragraph = new Paragraph();
paragraph.Text = "Welcome to Aspose.Slides";
// Définit le style de puce du paragraphe et l'image
paragraph.ParagraphFormat.Bullet.Type = BulletType.Picture;
paragraph.ParagraphFormat.Bullet.Picture.Image = ippxImage;
// Définit la hauteur de la puce
paragraph.ParagraphFormat.Bullet.Height = 100;
// Ajoute le paragraphe au TextFrame
textFrame.Paragraphs.Add(paragraph);
// Enregistre la présentation au format PPTX
presentation.Save("ParagraphPictureBulletsPPTX_out.pptx", SaveFormat.Pptx);
// Enregistre la présentation au format PPT
presentation.Save("ParagraphPictureBulletsPPT_out.ppt", SaveFormat.Ppt);
Manage Multilevel Bullets
Les listes à puces vous aident à organiser et présenter les informations rapidement et efficacement. Les puces à plusieurs niveaux sont faciles à lire et à comprendre.
- Créez une instance de la classe Presentationclass.
- Accédez à la référence de la diapositive concernée par son index.
- Ajoutez une autoshape dans la nouvelle diapositive.
- Accédez au TextFrame de l’autoshape.
- Supprimez le paragraphe par défaut du
TextFrame. - Créez la première instance de paragraphe via la classe Paragraph et définissez la profondeur à 0.
- Créez la deuxième instance de paragraphe via la classe
Paragraphet définissez la profondeur à 1. - Créez la troisième instance de paragraphe via la classe
Paragraphet définissez la profondeur à 2. - Créez la quatrième instance de paragraphe via la classe
Paragraphet définissez la profondeur à 3. - Ajoutez les nouveaux paragraphes à la collection de paragraphes du
TextFrame. - Enregistrez la présentation modifiée.
Ce code C# montre comment ajouter et gérer des puces à plusieurs niveaux :
// Instancie une classe Presentation qui représente un fichier PPTX
using (Presentation pres = new Presentation())
{
// Accède à la première diapositive
ISlide slide = pres.Slides[0];
// Ajoute et accède à l'AutoShape
IAutoShape aShp = slide.Shapes.AddAutoShape(ShapeType.Rectangle, 200, 200, 400, 200);
// Accède au cadre de texte de l'AutoShape créé
ITextFrame text = aShp.AddTextFrame("");
// Supprime le paragraphe par défaut
text.Paragraphs.Clear();
// Ajoute le premier paragraphe
IParagraph para1 = new Paragraph();
para1.Text = "Content";
para1.ParagraphFormat.Bullet.Type = BulletType.Symbol;
para1.ParagraphFormat.Bullet.Char = Convert.ToChar(8226);
para1.ParagraphFormat.DefaultPortionFormat.FillFormat.FillType = FillType.Solid;
para1.ParagraphFormat.DefaultPortionFormat.FillFormat.SolidFillColor.Color = Color.Black;
// Définit le niveau de la puce
para1.ParagraphFormat.Depth = 0;
// Ajoute le deuxième paragraphe
IParagraph para2 = new Paragraph();
para2.Text = "Second Level";
para2.ParagraphFormat.Bullet.Type = BulletType.Symbol;
para2.ParagraphFormat.Bullet.Char = '-';
para2.ParagraphFormat.DefaultPortionFormat.FillFormat.FillType = FillType.Solid;
para2.ParagraphFormat.DefaultPortionFormat.FillFormat.SolidFillColor.Color = Color.Black;
// Définit le niveau de la puce
para2.ParagraphFormat.Depth = 1;
// Ajoute le troisième paragraphe
IParagraph para3 = new Paragraph();
para3.Text = "Third Level";
para3.ParagraphFormat.Bullet.Type = BulletType.Symbol;
para3.ParagraphFormat.Bullet.Char = Convert.ToChar(8226);
para3.ParagraphFormat.DefaultPortionFormat.FillFormat.FillType = FillType.Solid;
para3.ParagraphFormat.DefaultPortionFormat.FillFormat.SolidFillColor.Color = Color.Black;
// Définit le niveau de la puce
para3.ParagraphFormat.Depth = 2;
// Ajoute le quatrième paragraphe
IParagraph para4 = new Paragraph();
para4.Text = "Fourth Level";
para4.ParagraphFormat.Bullet.Type = BulletType.Symbol;
para4.ParagraphFormat.Bullet.Char = '-';
para4.ParagraphFormat.DefaultPortionFormat.FillFormat.FillType = FillType.Solid;
para4.ParagraphFormat.DefaultPortionFormat.FillFormat.SolidFillColor.Color = Color.Black;
// Définit le niveau de la puce
para4.ParagraphFormat.Depth = 3;
// Ajoute les paragraphes à la collection
text.Paragraphs.Add(para1);
text.Paragraphs.Add(para2);
text.Paragraphs.Add(para3);
text.Paragraphs.Add(para4);
// Enregistre la présentation au format PPTX
pres.Save("MultilevelBullet.pptx", Aspose.Slides.Export.SaveFormat.Pptx);
}
Manage a Paragraph with a Custom Numbered List
L’interface IBulletFormat fournit la propriété NumberedBulletStartWith et d’autres qui vous permettent de gérer des paragraphes avec une numérotation ou une mise en forme personnalisée.
- Créez une instance de la classe Presentationclass.
- Accédez à la diapositive contenant le paragraphe.
- Ajoutez une autoshape à la diapositive.
- Accédez au TextFrame de l’autoshape.
- Supprimez le paragraphe par défaut du
TextFrame. - Créez la première instance de paragraphe via la classe Paragraph et définissez NumberedBulletStartWith à 2.
- Créez la deuxième instance de paragraphe via la classe
Paragraphet définissezNumberedBulletStartWithà 3. - Créez la troisième instance de paragraphe via la classe
Paragraphet définissezNumberedBulletStartWithà 7. - Ajoutez les nouveaux paragraphes à la collection de paragraphes du
TextFrame. - Enregistrez la présentation modifiée.
Ce code C# montre comment ajouter et gérer des paragraphes avec une numérotation ou une mise en forme personnalisée :
using (var presentation = new Presentation())
{
var shape = presentation.Slides[0].Shapes.AddAutoShape(ShapeType.Rectangle, 200, 200, 400, 200);
// Accède au cadre de texte de l'autoforme créée
ITextFrame textFrame = shape.TextFrame;
// Supprime le paragraphe existant par défaut
textFrame.Paragraphs.RemoveAt(0);
// Première liste
var paragraph1 = new Paragraph { Text = "bullet 2" };
paragraph1.ParagraphFormat.Depth = 4;
paragraph1.ParagraphFormat.Bullet.NumberedBulletStartWith = 2;
paragraph1.ParagraphFormat.Bullet.Type = BulletType.Numbered;
textFrame.Paragraphs.Add(paragraph1);
var paragraph2 = new Paragraph { Text = "bullet 3" };
paragraph2.ParagraphFormat.Depth = 4;
paragraph2.ParagraphFormat.Bullet.NumberedBulletStartWith = 3;
paragraph2.ParagraphFormat.Bullet.Type = BulletType.Numbered;
textFrame.Paragraphs.Add(paragraph2);
var paragraph5 = new Paragraph { Text = "bullet 7" };
paragraph5.ParagraphFormat.Depth = 4;
paragraph5.ParagraphFormat.Bullet.NumberedBulletStartWith = 7;
paragraph5.ParagraphFormat.Bullet.Type = BulletType.Numbered;
textFrame.Paragraphs.Add(paragraph5);
presentation.Save("SetCustomBulletsNumber-slides.pptx", SaveFormat.Pptx);
}
Set Paragraph Indent
- Créez une instance de la classe Presentation.
- Accédez à la référence de la diapositive concernée par son index.
- Ajoutez un rectangle autoshape à la diapositive.
- Ajoutez un TextFrame contenant trois paragraphes au rectangle autoshape.
- Masquez les bordures du rectangle.
- Définissez le retrait pour chaque Paragraph via sa propriété BulletOffset.
- Enregistrez la présentation modifiée au format PPT.
Ce code C# montre comment définir un retrait de paragraphe :
// Instancie la classe Presentation
Presentation pres = new Presentation();
// Obtient la première diapositive
ISlide sld = pres.Slides[0];
// Ajoute une forme rectangulaire
IAutoShape rect = sld.Shapes.AddAutoShape(ShapeType.Rectangle, 100, 100, 500, 150);
// Ajoute un TextFrame au rectangle
ITextFrame tf = rect.AddTextFrame("This is first line \rThis is second line \rThis is third line");
// Définit le texte pour s'adapter à la forme
tf.TextFrameFormat.AutofitType = TextAutofitType.Shape;
// Masque les lignes du rectangle
rect.LineFormat.FillFormat.FillType = FillType.Solid;
// Obtient le premier paragraphe dans le TextFrame et définit son retrait
IParagraph para1 = tf.Paragraphs[0];
// Définit le style de puce du paragraphe et le symbole
para1.ParagraphFormat.Bullet.Type = BulletType.Symbol;
para1.ParagraphFormat.Bullet.Char = Convert.ToChar(8226);
para1.ParagraphFormat.Alignment = TextAlignment.Left;
para1.ParagraphFormat.Depth = 2;
para1.ParagraphFormat.Indent = 30;
// Obtient le deuxième paragraphe dans le TextFrame et définit son retrait
IParagraph para2 = tf.Paragraphs[1];
para2.ParagraphFormat.Bullet.Type = BulletType.Symbol;
para2.ParagraphFormat.Bullet.Char = Convert.ToChar(8226);
para2.ParagraphFormat.Alignment = TextAlignment.Left;
para2.ParagraphFormat.Depth = 2;
para2.ParagraphFormat.Indent = 40;
// Obtient le troisième paragraphe dans le TextFrame et définit son retrait
IParagraph para3 = tf.Paragraphs[2];
para3.ParagraphFormat.Bullet.Type = BulletType.Symbol;
para3.ParagraphFormat.Bullet.Char = Convert.ToChar(8226);
para3.ParagraphFormat.Alignment = TextAlignment.Left;
para3.ParagraphFormat.Depth = 2;
para3.ParagraphFormat.Indent = 50;
// Enregistre la présentation sur le disque
pres.Save("InOutDent_out.pptx", SaveFormat.Pptx);
Set Hanging Indent for a Paragraph
Ce code C# montre comment définir le retrait suspendu pour un paragraphe :
using (Presentation pres = new Presentation())
{
var autoShape = pres.Slides[0].Shapes.AddAutoShape(ShapeType.Rectangle, 50, 250, 550, 150);
Paragraph para1 = new Paragraph
{
Text = "Example"
};
Paragraph para2 = new Paragraph
{
Text = "Set Hanging Indent for Paragraph"
};
Paragraph para3 = new Paragraph
{
Text = "This C# code shows you how to set the hanging indent for a paragraph: "
};
para2.ParagraphFormat.MarginLeft = 10f;
para3.ParagraphFormat.MarginLeft = 20f;
autoShape.TextFrame.Paragraphs.Add(para1);
autoShape.TextFrame.Paragraphs.Add(para2);
autoShape.TextFrame.Paragraphs.Add(para3);
pres.Save("pres.pptx", SaveFormat.Pptx);
}
Manage End Paragraph Run Properties
- Créez une instance de Presentation class.
- Obtenez la référence de la diapositive contenant le paragraphe via sa position.
- Ajoutez un rectangle autoshape à la diapositive.
- Ajoutez un TextFrame contenant deux paragraphes au rectangle.
- Définissez le
FontHeightet le type de police pour les paragraphes. - Définissez les propriétés End pour les paragraphes.
- Enregistrez la présentation modifiée au format PPTX.
Ce code C# montre comment définir les propriétés End pour les paragraphes dans PowerPoint :
using (Presentation pres = new Presentation("Test.pptx"))
{
IAutoShape shape = pres.Slides[0].Shapes.AddAutoShape(ShapeType.Rectangle, 10, 10, 200, 250);
Paragraph para1 = new Paragraph();
para1.Portions.Add(new Portion("Sample text"));
Paragraph para2 = new Paragraph();
para2.Portions.Add(new Portion("Sample text 2"));
PortionFormat endParagraphPortionFormat = new PortionFormat();
endParagraphPortionFormat.FontHeight = 48;
endParagraphPortionFormat.LatinFont = new FontData("Times New Roman");
para2.EndParagraphPortionFormat = endParagraphPortionFormat;
shape.TextFrame.Paragraphs.Add(para1);
shape.TextFrame.Paragraphs.Add(para2);
pres.Save("pres.pptx", SaveFormat.Pptx);
}
Import HTML Text into Paragraphs
Aspose.Slides offre une prise en charge améliorée de l’importation de texte HTML dans les paragraphes.
- Créez une instance de la classe Presentation.
- Accédez à la référence de la diapositive concernée par son index.
- Ajoutez une autoshape à la diapositive.
- Ajoutez et accédez à l’
autoshapeITextFrame. - Supprimez le paragraphe par défaut dans le
ITextFrame. - Lisez le fichier HTML source avec un TextReader.
- Créez la première instance de paragraphe via la classe Paragraph.
- Ajoutez le contenu du fichier HTML lu par le TextReader à la ParagraphCollection du TextFrame.
- Enregistrez la présentation modifiée.
Ce code C# implémente les étapes d’importation de textes HTML dans les paragraphes :
// Crée une instance de présentation vide
using (Presentation pres = new Presentation())
{
// Accède à la première diapositive par défaut de la présentation
ISlide slide = pres.Slides[0];
// Ajoute l'AutoShape pour contenir le contenu HTML
IAutoShape ashape = slide.Shapes.AddAutoShape(ShapeType.Rectangle, 10, 10, pres.SlideSize.Size.Width - 20, pres.SlideSize.Size.Height - 10);
ashape.FillFormat.FillType = FillType.NoFill;
// Ajoute un cadre de texte à la forme
ashape.AddTextFrame("");
// Vide tous les paragraphes du cadre de texte ajouté
ashape.TextFrame.Paragraphs.Clear();
// Charge le fichier HTML à l'aide d'un StreamReader
TextReader tr = new StreamReader("file.html");
// Ajoute le texte du StreamReader HTML dans le cadre de texte
ashape.TextFrame.Paragraphs.AddFromHtml(tr.ReadToEnd());
// Enregistre la présentation
pres.Save("output_out.pptx", Aspose.Slides.Export.SaveFormat.Pptx);
}
Export Paragraph Text to HTML
Aspose.Slides offre une prise en charge améliorée de l’exportation de textes (contenus dans des paragraphes) vers HTML.
- Créez une instance de la classe Presentation et chargez la présentation souhaitée.
- Accédez à la référence de la diapositive concernée par son index.
- Accédez à la forme contenant le texte qui sera exporté vers HTML.
- Accédez à la TextFrame de la forme.
- Créez une instance de
StreamWriteret ajoutez le nouveau fichier HTML. - Fournissez un index de départ à StreamWriter et exportez les paragraphes souhaités.
Ce code C# montre comment exporter les textes de paragraphes PowerPoint vers HTML :
// Charge le fichier de présentation
using (Presentation pres = new Presentation("ExportingHTMLText.pptx"))
{
// Accède à la première diapositive par défaut de la présentation
ISlide slide = pres.Slides[0];
// Accède à l'index requis
int index = 0;
// Accède à la forme ajoutée
IAutoShape ashape = (IAutoShape)slide.Shapes[index];
StreamWriter sw = new StreamWriter("output_out.html", false, Encoding.UTF8);
// Écrit les données des paragraphes en HTML en spécifiant l'index de départ du paragraphe et le nombre de paragraphes à copier
sw.Write(ashape.TextFrame.Paragraphs.ExportToHtml(0, ashape.TextFrame.Paragraphs.Count, null));
sw.Close();
}
Save a Paragraph as an Image
Dans cette section, nous explorerons deux exemples illustrant comment enregistrer un paragraphe de texte, représenté par l’interface IParagraph, sous forme d’image. Les deux exemples incluent l’obtention de l’image d’une forme contenant le paragraphe à l’aide des méthodes GetImage de l’interface IShape, le calcul des limites du paragraphe dans la forme, puis son exportation sous forme d’image bitmap. Ces approches vous permettent d’extraire des parties spécifiques du texte d’une présentation PowerPoint et de les enregistrer comme images distinctes, ce qui peut être utile dans divers scénarios.
Supposons que nous disposions d’un fichier de présentation nommé sample.pptx contenant une diapositive, dont la première forme est une zone de texte contenant trois paragraphes.

Example 1
Dans cet exemple, nous obtenons le deuxième paragraphe sous forme d’image. Pour ce faire, nous extrayons l’image de la forme de la première diapositive de la présentation, puis nous calculons les limites du deuxième paragraphe dans le cadre de texte de la forme. Le paragraphe est ensuite redessiné sur une nouvelle image bitmap, puis enregistré au format PNG. Cette méthode est particulièrement utile lorsque vous devez enregistrer un paragraphe spécifique en tant qu’image séparée tout en conservant les dimensions et la mise en forme exactes du texte.
using var presentation = new Presentation("sample.pptx");
var firstShape = presentation.Slides[0].Shapes[0] as IAutoShape;
// Enregistre la forme en mémoire sous forme de bitmap.
using var shapeImage = firstShape.GetImage();
using var shapeImageStream = new MemoryStream();
shapeImage.Save(shapeImageStream, ImageFormat.Png);
// Crée un bitmap de forme à partir de la mémoire.
shapeImageStream.Seek(0, SeekOrigin.Begin);
using var shapeBitmap = Image.FromStream(shapeImageStream);
// Calcule les limites du second paragraphe.
var secondParagraph = firstShape.TextFrame.Paragraphs[1];
var paragraphRectangle = secondParagraph.GetRect();
// Calcule la taille de l'image de sortie (taille minimale - 1x1 pixel).
var imageWidth = Math.Max(1, (int)Math.Ceiling(paragraphRectangle.Width));
var imageHeight = Math.Max(1, (int)Math.Ceiling(paragraphRectangle.Height));
// Prépare un bitmap pour le paragraphe.
using var paragraphBitmap = new Bitmap(imageWidth, imageHeight);
// Redessine le paragraphe depuis le bitmap de forme vers le bitmap du paragraphe.
using var imageGraphics = Graphics.FromImage(paragraphBitmap);
var drawingRectangle = new RectangleF(0, 0, paragraphRectangle.Width, paragraphRectangle.Height);
imageGraphics.DrawImage(shapeBitmap, drawingRectangle, paragraphRectangle, GraphicsUnit.Pixel);
paragraphBitmap.Save("paragraph.png", System.Drawing.Imaging.ImageFormat.Png);
Le résultat :

Example 2
Dans cet exemple, nous étendons l’approche précédente en ajoutant des facteurs d’échelle à l’image du paragraphe. La forme est extraite de la présentation et enregistrée comme image avec un facteur d’échelle de 2. Cela permet d’obtenir une sortie en haute résolution lors de l’exportation du paragraphe. Les limites du paragraphe sont ensuite calculées en tenant compte de l’échelle. Le redimensionnement peut être particulièrement utile lorsqu’une image plus détaillée est requise, par exemple pour une utilisation dans des documents imprimés de haute qualité.
var imageScaleX = 2f;
var imageScaleY = imageScaleX;
using var presentation = new Presentation("sample.pptx");
var firstShape = presentation.Slides[0].Shapes[0] as IAutoShape;
// Save the shape in memory as a bitmap with scaling.
using var shapeImage = firstShape.GetImage(ShapeThumbnailBounds.Shape, imageScaleX, imageScaleY);
using var shapeImageStream = new MemoryStream();
shapeImage.Save(shapeImageStream, ImageFormat.Png);
// Create a shape bitmap from memory.
shapeImageStream.Seek(0, SeekOrigin.Begin);
using var shapeBitmap = Image.FromStream(shapeImageStream);
// Calculate the boundaries of the second paragraph.
var secondParagraph = firstShape.TextFrame.Paragraphs[1];
var paragraphRectangle = secondParagraph.GetRect();
paragraphRectangle.X *= imageScaleX;
paragraphRectangle.Y *= imageScaleY;
paragraphRectangle.Width *= imageScaleX;
paragraphRectangle.Height *= imageScaleY;
// Calculate the size for the output image (minimum size - 1x1 pixel).
var imageWidth = Math.Max(1, (int)Math.Ceiling(paragraphRectangle.Width));
var imageHeight = Math.Max(1, (int)Math.Ceiling(paragraphRectangle.Height));
// Prepare a bitmap for the paragraph.
using var paragraphBitmap = new Bitmap(imageWidth, imageHeight);
// Redraw the paragraph from the shape bitmap to the paragraph bitmap.
using var imageGraphics = Graphics.FromImage(paragraphBitmap);
var drawingRectangle = new RectangleF(0, 0, paragraphRectangle.Width, paragraphRectangle.Height);
imageGraphics.DrawImage(shapeBitmap, drawingRectangle, paragraphRectangle, GraphicsUnit.Pixel);
paragraphBitmap.Save("paragraph.png", System.Drawing.Imaging.ImageFormat.Png);
FAQ
Can I completely disable line wrapping inside a text frame?
Oui. Utilisez le paramètre d’enveloppement du cadre de texte (WrapText) pour désactiver l’enveloppement afin que les lignes ne se coupent pas aux bords du cadre.
How can I get the exact on-slide bounds of a specific paragraph?
Vous pouvez récupérer le rectangle englobant du paragraphe (et même d’une portion) afin de connaître sa position et sa taille exactes sur la diapositive.
Where is paragraph alignment (left/right/center/justify) controlled?
Alignment est un paramètre au niveau du paragraphe dans ParagraphFormat; il s’applique à l’ensemble du paragraphe quel que soit le formatage des portions individuelles.
Can I set a spell-check language for just part of a paragraph (e.g., one word)?
Oui. La langue est définie au niveau de la portion (PortionFormat.LanguageId), ce qui permet à plusieurs langues de coexister dans un même paragraphe.