Gérer les tables de présentation dans .NET
Un tableau dans PowerPoint est un moyen efficace d’afficher et de présenter des informations. Les données présentées sous forme de grille de cellules (organisées en lignes et colonnes) sont simples à comprendre.
Aspose.Slides fournit la classe Table, l’interface ITable, la classe Cell, l’interface ICell et d’autres types pour vous permettre de créer, mettre à jour et gérer des tableaux dans tous types de présentations.
Créer un tableau à partir de zéro
- Créez une instance de la classe Presentation.
- Obtenez la référence d’une diapositive via son indice.
- Définissez un tableau de
columnWidth. - Définissez un tableau de
rowHeight. - Ajoutez un objet ITable à la diapositive à l’aide de la méthode AddTable.
- Parcourez chaque ICell pour appliquer un formatage aux bordures supérieure, inférieure, droite et gauche.
- Fusionnez les deux premières cellules de la première ligne du tableau.
- Accédez au TextFrame d’une ICell.
- Ajoutez du texte au TextFrame.
- Enregistrez la présentation modifiée.
Ce code C# vous montre comment créer un tableau dans une présentation :
// Instancie une classe Presentation qui représente un fichier PPTX
Presentation pres = new Presentation();
// Accède à la première diapositive
ISlide sld = pres.Slides[0];
// Définit les colonnes avec leurs largeurs et les lignes avec leurs hauteurs
double[] dblCols = { 50, 50, 50 };
double[] dblRows = { 50, 30, 30, 30, 30 };
// Ajoute une forme de tableau à la diapositive
ITable tbl = sld.Shapes.AddTable(100, 50, dblCols, dblRows);
// Définit le format de bordure pour chaque cellule
for (int row = 0; row < tbl.Rows.Count; row++)
{
for (int cell = 0; cell < tbl.Rows[row].Count; cell++)
{
tbl.Rows[row][cell].CellFormat.BorderTop.FillFormat.FillType = FillType.Solid;
tbl.Rows[row][cell].CellFormat.BorderTop.FillFormat.SolidFillColor.Color = Color.Red;
tbl.Rows[row][cell].CellFormat.BorderTop.Width = 5;
tbl.Rows[row][cell].CellFormat.BorderBottom.FillFormat.FillType = (FillType.Solid);
tbl.Rows[row][cell].CellFormat.BorderBottom.FillFormat.SolidFillColor.Color= Color.Red;
tbl.Rows[row][cell].CellFormat.BorderBottom.Width =5;
tbl.Rows[row][cell].CellFormat.BorderLeft.FillFormat.FillType = FillType.Solid;
tbl.Rows[row][cell].CellFormat.BorderLeft.FillFormat.SolidFillColor.Color =Color.Red;
tbl.Rows[row][cell].CellFormat.BorderLeft.Width = 5;
tbl.Rows[row][cell].CellFormat.BorderRight.FillFormat.FillType = FillType.Solid;
tbl.Rows[row][cell].CellFormat.BorderRight.FillFormat.SolidFillColor.Color = Color.Red;
tbl.Rows[row][cell].CellFormat.BorderRight.Width = 5;
}
}
// Fusionne les cellules 1 et 2 de la ligne 1
tbl.MergeCells(tbl.Rows[0][0], tbl.Rows[1][1], false);
// Ajoute du texte à la cellule fusionnée
tbl.Rows[0][0].TextFrame.Text = "Merged Cells";
// Enregistre la présentation sur le disque
pres.Save("table.pptx", SaveFormat.Pptx);
Numérotation dans un tableau standard
Dans un tableau standard, la numérotation des cellules est simple et commence à zéro. La première cellule d’un tableau a l’index 0,0 (colonne 0, ligne 0).
Par exemple, les cellules d’un tableau de 4 colonnes et 4 lignes sont numérotées ainsi :
| (0, 0) | (1, 0) | (2, 0) | (3, 0) |
|---|---|---|---|
| (0, 1) | (1, 1) | (2, 1) | (3, 1) |
| (0, 2) | (1, 2) | (2, 2) | (3, 2) |
| (0, 3) | (1, 3) | (2, 3) | (3, 3) |
Ce code C# vous montre comment spécifier la numérotation des cellules dans un tableau :
// Instancie une classe Presentation qui représente un fichier PPTX
using (Presentation pres = new Presentation())
{
// Accède à la première diapositive
ISlide sld = pres.Slides[0];
// Définit les colonnes avec leurs largeurs et les lignes avec leurs hauteurs
double[] dblCols = { 70, 70, 70, 70 };
double[] dblRows = { 70, 70, 70, 70 };
// Ajoute une forme de tableau à la diapositive
ITable tbl = sld.Shapes.AddTable(100, 50, dblCols, dblRows);
// Définit le format de bordure pour chaque cellule
foreach (IRow row in tbl.Rows)
{
foreach (ICell cell in row)
{
cell.CellFormat.BorderTop.FillFormat.FillType = FillType.Solid;
cell.CellFormat.BorderTop.FillFormat.SolidFillColor.Color = Color.Red;
cell.CellFormat.BorderTop.Width = 5;
cell.CellFormat.BorderBottom.FillFormat.FillType = FillType.Solid;
cell.CellFormat.BorderBottom.FillFormat.SolidFillColor.Color = Color.Red;
cell.CellFormat.BorderBottom.Width = 5;
cell.CellFormat.BorderLeft.FillFormat.FillType = FillType.Solid;
cell.CellFormat.BorderLeft.FillFormat.SolidFillColor.Color = Color.Red;
cell.CellFormat.BorderLeft.Width = 5;
cell.CellFormat.BorderRight.FillFormat.FillType = FillType.Solid;
cell.CellFormat.BorderRight.FillFormat.SolidFillColor.Color = Color.Red;
cell.CellFormat.BorderRight.Width = 5;
}
}
// Enregistre la présentation sur le disque
pres.Save("StandardTables_out.pptx", SaveFormat.Pptx);
}
Accéder à un tableau existant
-
Créez une instance de la classe Presentation.
-
Obtenez la référence de la diapositive contenant le tableau via son indice.
-
Créez un objet ITable et initialisez‑le à null.
-
Parcourez tous les objets IShape jusqu’à ce que le tableau soit trouvé.
Si vous pensez que la diapositive que vous traitez ne contient qu’un seul tableau, vous pouvez simplement vérifier toutes les formes qu’elle contient. Lorsqu’une forme est identifiée comme un tableau, vous pouvez la convertir en objet Table. Mais si la diapositive contient plusieurs tableaux, il vaut mieux rechercher le tableau souhaité via sa propriété AlternativeText.
-
Utilisez l’objet ITable pour travailler avec le tableau. Dans l’exemple ci‑dessous, nous ajoutons une nouvelle ligne au tableau.
-
Enregistrez la présentation modifiée.
Ce code C# vous montre comment accéder et travailler avec un tableau existant :
// Instancie une classe Presentation qui représente un fichier PPTX
using (Presentation pres = new Presentation("UpdateExistingTable.pptx"))
{
// Accède à la première diapositive
ISlide sld = pres.Slides[0];
// Initialise TableEx à null
ITable tbl = null;
// Parcourt les formes et définit une référence vers le tableau trouvé
foreach (IShape shp in sld.Shapes)
if (shp is ITable)
tbl = (ITable)shp;
// Définit le texte pour la première colonne de la deuxième ligne
tbl[0, 1].TextFrame.Text = "New";
// Enregistre la présentation modifiée sur le disque
pres.Save("table1_out.pptx", Aspose.Slides.Export.SaveFormat.Pptx);
}
Aligner le texte dans un tableau
- Créez une instance de la classe Presentation.
- Obtenez la référence d’une diapositive via son indice.
- Ajoutez un objet ITable à la diapositive.
- Accédez à un objet ITextFrame du tableau.
- Accédez au IParagraph du ITextFrame.
- Alignez le texte verticalement.
- Enregistrez la présentation modifiée.
Ce code C# vous montre comment aligner le texte dans un tableau :
// Creates an instance of the Presentation class
Presentation presentation = new Presentation();
// Gets the first slide
ISlide slide = presentation.Slides[0];
// Defines columns with widths and rows with heights
double[] dblCols = { 120, 120, 120, 120 };
double[] dblRows = { 100, 100, 100, 100 };
// Adds the table shape to the slide
ITable tbl = slide.Shapes.AddTable(100, 50, dblCols, dblRows);
tbl[1, 0].TextFrame.Text = "10";
tbl[2, 0].TextFrame.Text = "20";
tbl[3, 0].TextFrame.Text = "30";
// Accesses the text frame
ITextFrame txtFrame = tbl[0, 0].TextFrame;
// Creates the Paragraph object for the text frame
IParagraph paragraph = txtFrame.Paragraphs[0];
// Creates the Portion object for paragraph
IPortion portion = paragraph.Portions[0];
portion.Text = "Text here";
portion.PortionFormat.FillFormat.FillType = FillType.Solid;
portion.PortionFormat.FillFormat.SolidFillColor.Color = Color.Black;
// Aligns the text vertically
ICell cell = tbl[0, 0];
cell.TextAnchorType = TextAnchorType.Center;
cell.TextVerticalType = TextVerticalType.Vertical270;
// Saves the presentation to disk
presentation.Save("Vertical_Align_Text_out.pptx", SaveFormat.Pptx);
Définir le formatage du texte au niveau du tableau
- Créez une instance de la classe Presentation .
- Obtenez la référence d’une diapositive via son indice.
- Accédez à un objet ITable depuis la diapositive.
- Définissez la FontHeight du texte.
- Définissez l’Alignment et le MarginRight.
- Définissez le TextVerticalType.
- Enregistrez la présentation modifiée.
Ce code C# vous montre comment appliquer vos options de formatage préférées au texte d’un tableau :
// Crée une instance de la classe Presentation
Presentation presentation = new Presentation();
ISlide slide = presentation.Slides[0];
ITable someTable = presentation.Slides[0].Shapes[0] as ITable; // Supposons que la première forme de la première diapositive est un tableau
// Définit la hauteur de police des cellules du tableau
PortionFormat portionFormat = new PortionFormat();
portionFormat.FontHeight = 25;
someTable.SetTextFormat(portionFormat);
// Définit l'alignement du texte des cellules du tableau et la marge droite en un appel
ParagraphFormat paragraphFormat = new ParagraphFormat();
paragraphFormat.Alignment = TextAlignment.Right;
paragraphFormat.MarginRight = 20;
someTable.SetTextFormat(paragraphFormat);
// Définit le type vertical du texte des cellules du tableau
TextFrameFormat textFrameFormat = new TextFrameFormat();
textFrameFormat.TextVerticalType = TextVerticalType.Vertical;
someTable.SetTextFormat(textFrameFormat);
presentation.Save("result.pptx", Aspose.Slides.Export.SaveFormat.Pptx);
Obtenir les propriétés de style du tableau
Aspose.Slides vous permet de récupérer les propriétés de style d’un tableau afin de les réutiliser pour un autre tableau ou ailleurs. Ce code C# montre comment obtenir les propriétés de style à partir d’un style de tableau prédéfini :
using (Presentation pres = new Presentation())
{
ITable table = pres.Slides[0].Shapes.AddTable(10, 10, new double[] { 100, 150 }, new double[] { 5, 5, 5 });
table.StylePreset = TableStylePreset.DarkStyle1; // modifier le thème de style prédéfini par défaut
pres.Save("table.pptx", SaveFormat.Pptx);
}
Verrouiller le ratio d’aspect d’un tableau
Le ratio d’aspect d’une forme géométrique est le rapport de ses dimensions. Aspose.Slides fournit la propriété AspectRatioLocked pour vous permettre de verrouiller le réglage du ratio d’aspect des tableaux et d’autres formes.
Ce code C# montre comment verrouiller le ratio d’aspect d’un tableau :
using (Presentation pres = new Presentation("pres.pptx"))
{
ITable table = (ITable)pres.Slides[0].Shapes[0];
Console.WriteLine($"Lock aspect ratio set: {table.ShapeLock.AspectRatioLocked}");
table.ShapeLock.AspectRatioLocked = !table.ShapeLock.AspectRatioLocked; // inverser
Console.WriteLine($"Lock aspect ratio set: {table.ShapeLock.AspectRatioLocked}");
pres.Save("pres-out.pptx", SaveFormat.Pptx);
}
FAQ
Puis‑je activer la direction de lecture de droite à gauche (RTL) pour un tableau entier et le texte de ses cellules ?
Oui. Le tableau expose la propriété RightToLeft, et les paragraphes possèdent ParagraphFormat.RightToLeft. L’utilisation des deux garantit l’ordre RTL correct et le rendu à l’intérieur des cellules.
Comment empêcher les utilisateurs de déplacer ou de redimensionner un tableau dans le fichier final ?
Utilisez les verrous de forme pour désactiver le déplacement, le redimensionnement, la sélection, etc. Ces verrous s’appliquent également aux tableaux.
L’insertion d’une image dans une cellule comme arrière‑plan est‑elle prise en charge ?
Oui. Vous pouvez définir un remplissage d’image pour une cellule ; l’image couvrira la zone de la cellule selon le mode choisi (étirement ou mosaïque).