Gérer les tableaux de présentation en PHP
Un tableau dans PowerPoint est un moyen efficace d’afficher et de représenter des informations. Les informations dans une grille de cellules (organisées en lignes et colonnes) sont simples et faciles à comprendre.
Aspose.Slides fournit la classe Table class, la classe Cell class, et d’autres types pour vous permettre de créer, mettre à jour et gérer des tableaux dans tous les types de présentations.
Créer un tableau à partir de zéro
- Créez une instance de la classe Presentation.
- Obtenez une référence à la diapositive via son index.
- Définissez un tableau de
columnWidth. - Définissez un tableau de
rowHeight. - Ajoutez un objet Table à la diapositive avec la méthode addTable.
- Itérez chaque Cell pour appliquer le 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 Cell.
- Ajoutez du texte au TextFrame.
- Enregistrez la présentation modifiée.
Ce code PHP montre comment créer un tableau dans une présentation :
# Instancie une classe Presentation qui représente un fichier PPTX
$pres = new Presentation();
try {
# Accède à la première diapositive
$sld = $pres->getSlides()->get_Item(0);
# Définit les colonnes avec leurs largeurs et les lignes avec leurs hauteurs
$dblCols = array(50, 50, 50 );
$dblRows = array(50, 30, 30, 30, 30 );
# Ajoute une forme de tableau à la diapositive
$tbl = $sld->getShapes()->addTable(100, 50, $dblCols, $dblRows);
# Définit le format de bordure pour chaque cellule
for($row = 0; $row < java_values($tbl->getRows()->size()) ; $row++) {
for($cell = 0; $cell < java_values($tbl->getRows()->get_Item($row)->size()) ; $cell++) {
$cellFormat = $tbl->getRows()->get_Item($row)->get_Item($cell)->getCellFormat();
$cellFormat::getBorderTop()->getFillFormat()->setFillType(FillType::Solid);
$cellFormat::getBorderTop()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cellFormat::getBorderTop()->setWidth(5);
$cellFormat::getBorderBottom()->getFillFormat()->setFillType(FillType::Solid);
$cellFormat::getBorderBottom()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cellFormat::getBorderBottom()->setWidth(5);
$cellFormat::getBorderLeft()->getFillFormat()->setFillType(FillType::Solid);
$cellFormat::getBorderLeft()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cellFormat::getBorderLeft()->setWidth(5);
$cellFormat::getBorderRight()->getFillFormat()->setFillType(FillType::Solid);
$cellFormat::getBorderRight()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cellFormat::getBorderRight()->setWidth(5);
}
}
# Fusionne les cellules 1 et 2 de la ligne 1
$tbl->mergeCells($tbl->getRows()->get_Item(0)->get_Item(0), $tbl->getRows()->get_Item(1)->get_Item(1), false);
# Ajoute du texte à la cellule fusionnée
$tbl->getRows()->get_Item(0)->get_Item(0)->getTextFrame()->setText("Merged Cells");
# Enregistre la présentation sur le disque
$pres->save("table.pptx", SaveFormat::Pptx);
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}
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 est indexée comme 0,0 (colonne 0, ligne 0).
Par exemple, les cellules d’un tableau de 4 colonnes et 4 lignes sont numérotées de cette façon :
| (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 PHP montre comment spécifier la numérotation des cellules dans un tableau :
# Instancie une classe Presentation qui représente un fichier PPTX
$pres = new Presentation();
try {
# Accède à la première diapositive
$sld = $pres->getSlides()->get_Item(0);
# Définit les colonnes avec leurs largeurs et les lignes avec leurs hauteurs
$dblCols = array(70, 70, 70, 70 );
$dblRows = array(70, 70, 70, 70 );
# Ajoute une forme de tableau à la diapositive
$tbl = $sld->getShapes()->addTable(100, 50, $dblCols, $dblRows);
# Définit le format de bordure pour chaque cellule
foreach($tbl->getRows() as $row) {
foreach($row as $cell) {
$cell->getCellFormat()->getBorderTop()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getBorderTop()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cell->getCellFormat()->getBorderTop()->setWidth(5);
$cell->getCellFormat()->getBorderBottom()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getBorderBottom()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cell->getCellFormat()->getBorderBottom()->setWidth(5);
$cell->getCellFormat()->getBorderLeft()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getBorderLeft()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cell->getCellFormat()->getBorderLeft()->setWidth(5);
$cell->getCellFormat()->getBorderRight()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getBorderRight()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cell->getCellFormat()->getBorderRight()->setWidth(5);
}
}
# Enregistre la présentation sur le disque
$pres->save("StandardTables_out.pptx", SaveFormat::Pptx);
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}
Accéder à un tableau existant
- Créez une instance de la classe Presentation.
- Obtenez une référence à la diapositive contenant le tableau via son index.
- Créez un objet Table et définissez-le sur null.
- Itérez tous les objets Shape jusqu’à ce que le tableau soit trouvé.
Si vous pensez que la diapositive que vous traitez contient 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 que vous traitez contient plusieurs tableaux, il est préférable de rechercher le tableau dont vous avez besoin via son setAlternativeText(String value).
- Utilisez l’objet Table pour travailler avec le tableau. Dans l’exemple ci‑dessus, nous avons ajouté une nouvelle ligne au tableau.
- Enregistrez la présentation modifiée.
# Instancie la classe Presentation qui représente un fichier PPTX
$pres = new Presentation("UpdateExistingTable.pptx");
try {
# Accède à la première diapositive
$sld = $pres->getSlides()->get_Item(0);
# Initialise TableEx à null
$tbl = null;
# Itère à travers les formes et définit une référence vers le tableau trouvé
foreach($sld->getShapes() as $shp) {
if (java_instanceof($shp, new JavaClass("com.aspose.slides.Table"))) {
$tbl = $shp;
# Définit le texte pour la première colonne de la deuxième ligne
$tbl->get_Item(0, 1)->getTextFrame()->setText("New");
}
}
# Enregistre la présentation modifiée sur le disque
$pres->save("table1_out.pptx", SaveFormat::Pptx);
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}
Aligner le texte dans un tableau
- Créez une instance de la classe Presentation.
- Obtenez une référence à la diapositive via son index.
- Ajoutez un objet Table à la diapositive.
- Accédez à un objet TextFrame du tableau.
- Accédez au Paragraph.
- Alignez le texte verticalement.
- Enregistrez la présentation modifiée.
# Crée une instance de la classe Presentation
$pres = new Presentation();
try {
# Obtient la première diapositive
$slide = $pres->getSlides()->get_Item(0);
# Définit les colonnes avec leurs largeurs et les lignes avec leurs hauteurs
$dblCols = array(120, 120, 120, 120 );
$dblRows = array(100, 100, 100, 100 );
# Ajoute la forme de tableau à la diapositive
$tbl = $slide->getShapes()->addTable(100, 50, $dblCols, $dblRows);
$tbl->get_Item(1, 0)->getTextFrame()->setText("10");
$tbl->get_Item(2, 0)->getTextFrame()->setText("20");
$tbl->get_Item(3, 0)->getTextFrame()->setText("30");
# Accède au cadre de texte
$txtFrame = $tbl->get_Item(0, 0)->getTextFrame();
# Crée l'objet Paragraph pour le cadre de texte
$paragraph = $txtFrame->getParagraphs()->get_Item(0);
# Crée l'objet Portion pour le paragraphe
$portion = $paragraph->getPortions()->get_Item(0);
$portion->setText("Text here");
$portion->getPortionFormat()->getFillFormat()->setFillType(FillType::Solid);
$portion->getPortionFormat()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->BLACK);
# Aligne le texte verticalement
$cell = $tbl->get_Item(0, 0);
$cell->setTextAnchorType(TextAnchorType::Center);
$cell->setTextVerticalType(TextVerticalType::Vertical270);
# Enregistre la présentation sur le disque
$pres->save("Vertical_Align_Text_out.pptx", SaveFormat::Pptx);
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}
Définir le formatage du texte au niveau du tableau
- Créez une instance de la classe Presentation.
- Obtenez une référence à la diapositive via son index.
- Accédez à un objet Table depuis la diapositive.
- Définissez le setFontHeight(float value) pour le texte.
- Définissez le setAlignment(int value) et le setMarginRight(float value).
- Définissez le setTextVerticalType(byte value).
- Enregistrez la présentation modifiée.
# Crée une instance de la classe Presentation
$pres = new Presentation("simpletable.pptx");
try {
# Supposons que la première forme de la première diapositive est un tableau
$someTable = $pres->getSlides()->get_Item(0)->getShapes()->get_Item(0);
# Définit la hauteur de police des cellules du tableau
$portionFormat = new PortionFormat();
$portionFormat::setFontHeight(25);
$someTable->setTextFormat($portionFormat);
# Définit l'alignement du texte des cellules du tableau et la marge droite en un seul appel
$paragraphFormat = new ParagraphFormat();
$paragraphFormat::setAlignment(TextAlignment->Right);
$paragraphFormat::setMarginRight(20);
$someTable->setTextFormat($paragraphFormat);
# Définit le type de texte vertical des cellules du tableau
$textFrameFormat = new TextFrameFormat();
$textFrameFormat::setTextVerticalType(TextVerticalType::Vertical);
$someTable->setTextFormat($textFrameFormat);
$pres->save("result.pptx", SaveFormat::Pptx);
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}
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 utiliser pour un autre tableau ou ailleurs. Ce code PHP montre comment obtenir les propriétés de style d’un style de tableau prédéfini :
$pres = new Presentation();
try {
$table = $pres->getSlides()->get_Item(0)->getShapes()->addTable(10, 10, array(100, 150 ), array(5, 5, 5 ));
$table->setStylePreset(TableStylePreset->DarkStyle1);// changer le thème de style prédéfini par défaut
$pres->save("table.pptx", SaveFormat::Pptx);
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}
Verrouiller le ratio d’aspect d’un tableau
Le ratio d’aspect d’une forme géométrique est le rapport de ses dimensions dans différents axes. Aspose.Slides fournit la méthode setAspectRatioLocked pour vous permettre de verrouiller le réglage du ratio d’aspect pour les tableaux et autres formes.
$pres = new Presentation("pres.pptx");
try {
$table = $pres->getSlides()->get_Item(0)->getShapes()->get_Item(0);
echo("Lock aspect ratio set: " . $table->getGraphicalObjectLock()->getAspectRatioLocked());
$table->getGraphicalObjectLock()->setAspectRatioLocked(!$table->getGraphicalObjectLock()->getAspectRatioLocked());// inverser
echo("Lock aspect ratio set: " . $table->getGraphicalObjectLock()->getAspectRatioLocked());
$pres->save("pres-out.pptx", SaveFormat::Pptx);
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}
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 une méthode setRightToLeft, et les paragraphes disposent de ParagraphFormat::setRightToLeft. En utilisant les deux, vous assurez 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 à l’intérieur d’une cellule comme arrière‑plan est‑elle prise en charge ?
Oui. Vous pouvez définir un picture fill pour une cellule ; l’image couvrira la zone de la cellule selon le mode choisi (étirement ou mosaïque).