Convertir une diapositive
Aspose.Slides pour PHP via Java vous permet de convertir des diapositives (dans des présentations) en images. Voici les formats d’image pris en charge : BMP, PNG, JPG (JPEG), GIF et d’autres.
Pour convertir une diapositive en image, faites ceci :
-
Tout d’abord, définissez les paramètres de conversion et les objets de diapositive à convertir en utilisant :
- l’interface ITiffOptions ou
- l’interface IRenderingOptions.
-
Deuxièmement, convertissez la diapositive en image en utilisant la méthode getImage.
À propos de Bitmap et d’autres formats d’image
En Java, un Images est un objet qui vous permet de travailler avec des images définies par des données de pixels. Vous pouvez utiliser une instance de cette classe pour enregistrer des images dans un large éventail de formats (JPG, PNG, etc.).
Info
Aspose a récemment développé un convertisseur en ligne Texte en GIF.Conversion des diapositives en bitmap et enregistrement des images en PNG
Ce code PHP vous montre comment convertir la première diapositive d’une présentation en un objet bitmap puis comment enregistrer l’image au format PNG :
$pres = new Presentation("Presentation.pptx");
try {
# Convertit la première diapositive de la présentation en un objet Images
$slideImage = $pres->getSlides()->get_Item(0)->getImage();
# Enregistre l'image au format PNG
try {
# enregistre l'image sur le disque.
$slideImage->save("Slide_0.png", ImageFormat::Png);
} finally {
if (!java_is_null($slideImage)) {
$slideImage->dispose();
}
}
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}
Ce code exemple vous montre comment convertir la première diapositive d’une présentation en un objet bitmap en utilisant la méthode getImage :
$pres = new Presentation("Presentation.pptx");
try {
# Obtient la taille de la diapositive de la présentation
$slideSize = new Java("java.awt.Dimension", $slideSize->getWidth(), $slideSize->getHeight());
# Crée un Images avec la taille de la diapositive
$slideImage = $sld->getImage(new RenderingOptions(), $slideSize);
try {
# enregistre l'image sur le disque.
$slideImage->save("Slide_0.png", ImageFormat::Png);
} finally {
if (!java_is_null($slideImage)) {
$slideImage->dispose();
}
}
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}
Astuce
Vous pouvez convertir une diapositive en un objet Images et ensuite utiliser l’objet directement quelque part. Ou vous pouvez convertir une diapositive en un Images et ensuite enregistrer l’image en JPEG ou tout autre format de votre choix.Conversion des diapositives en images avec des tailles personnalisées
Vous pourriez avoir besoin d’obtenir une image d’une certaine taille. En utilisant une surcharge de la méthode getImage, vous pouvez convertir une diapositive en une image avec des dimensions spécifiques (longueur et largeur).
Ce code exemple démontre la conversion proposée en utilisant la méthode getImage :
$pres = new Presentation("Presentation.pptx");
try {
# Convertit la première diapositive de la présentation en un Bitmap avec la taille spécifiée
$slideImage = $pres->getSlides()->get_Item(0)->getImage(new Java("java.awt.Dimension", 1820, 1040));
# Enregistre l'image au format JPEG
try {
# enregistre l'image sur le disque.
$slideImage->save("Slide_0.jpg", ImageFormat::Jpeg);
} finally {
if (!java_is_null($slideImage)) {
$slideImage->dispose();
}
}
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}
Conversion des diapositives avec notes et commentaires en images
Certaines diapositives contiennent des notes et des commentaires.
Aspose.Slides fournit deux interfaces—ITiffOptions et IRenderingOptions—qui vous permettent de contrôler le rendu des diapositives de présentation en images. Les deux interfaces contiennent l’interface INotesCommentsLayoutingOptions qui vous permet d’ajouter des notes et des commentaires sur une diapositive lorsque vous convertissez cette diapositive en image.
Info
Avec l’interface INotesCommentsLayoutingOptions, vous pouvez spécifier votre position préférée pour les notes et les commentaires dans l’image résultante.Ce code PHP illustre le processus de conversion pour une diapositive avec des notes et des commentaires :
$pres = new Presentation("PresentationNotesComments.pptx");
try {
# Crée les options de rendu
$options = new RenderingOptions();
# Définit la position des notes sur la page
$options->getNotesCommentsLayouting()->setNotesPosition(NotesPositions::BottomTruncated);
# Définit la position des commentaires sur la page
$options->getNotesCommentsLayouting()->setCommentsPosition(CommentsPositions::Right);
# Définit la largeur de la zone de sortie des commentaires
$options->getNotesCommentsLayouting()->setCommentsAreaWidth(500);
# Définit la couleur de la zone des commentaires
$options->getNotesCommentsLayouting()->setCommentsAreaColor(java("java.awt.Color")->LIGHT_GRAY);
# Convertit la première diapositive de la présentation en un objet Bitmap
$slideImage = $pres->getSlides()->get_Item(0)->getImage($options, 2.0, 2.0);
# Enregistre l'image au format GIF
try {
$slideImage->save("Slide_Notes_Comments_0.gif", ImageFormat::Gif);
} finally {
if (!java_is_null($slideImage)) {
$slideImage->dispose();
}
}
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}
Ce code PHP montre le processus de conversion d’une diapositive avec des notes en utilisant la méthode getImage :
$pres = new Presentation("PresentationNotes.pptx");
try {
# Obtient la taille des notes de la présentation
$notesSize = $pres->getNotesSize()->getSize();
# Crée les options de rendu
$options = new RenderingOptions();
# Définit la position des notes
$options->getNotesCommentsLayouting()->setNotesPosition(NotesPositions::BottomTruncated);
# Crée un Images avec la taille des notes
$slideImage = $pres->getSlides()->get_Item(0)->getImage($options, $notesSize);
# Enregistre l'image au format PNG
try {
# enregistre l'image sur le disque.
$slideImage->save("Slide_0.png", ImageFormat::Png);
} finally {
if (!java_is_null($slideImage)) {
$slideImage->dispose();
}
}
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}
Remarque
Dans tout processus de conversion de diapositive en image, la propriété NotesPositions ne peut pas être définie sur BottomFull (pour spécifier la position des notes) car le texte d’une note peut être long, ce qui signifie qu’il pourrait ne pas tenir dans la taille d’image spécifiée.Conversion des diapositives en images en utilisant ITiffOptions
L’interface ITiffOptions vous donne un meilleur contrôle (en termes de paramètres) sur l’image résultante. En utilisant cette interface, vous pouvez spécifier la taille, la résolution, la palette de couleurs et d’autres paramètres pour l’image résultante.
Ce code PHP illustre un processus de conversion où ITiffOptions est utilisé pour produire une image en noir et blanc avec une résolution de 300 dpi et une taille de 2160 × 2800 :
$pres = new Presentation("PresentationNotesComments.pptx");
try {
# Obtient une diapositive par son index
$slide = $pres->getSlides()->get_Item(0);
# Crée un objet TiffOptions
$options = new TiffOptions();
$options->setImageSize(new Java("java.awt.Dimension", 2160, 2880));
# Définit la police utilisée au cas où la police source n'est pas trouvée
$options->setDefaultRegularFont("Arial Black");
# Définit la position des notes sur la page
$options->getNotesCommentsLayouting()->setNotesPosition(NotesPositions::BottomTruncated);
# Définit le format de pixels (noir et blanc)
$options->setPixelFormat(ImagePixelFormat::Format1bppIndexed);
# Définit la résolution
$options->setDpiX(300);
$options->setDpiY(300);
# Convertit la diapositive en un objet Bitmap
$slideImage = $slide->getImage($options);
# Enregistre l'image au format TIFF
try {
$slideImage->save("PresentationNotesComments.tiff", ImageFormat::Tiff);
} finally {
if (!java_is_null($slideImage)) {
$slideImage->dispose();
}
}
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}
Remarque
Le support de Tiff n’est pas garanti dans les versions antérieures à JDK 9.Conversion de toutes les diapositives en images
Aspose.Slides vous permet de convertir toutes les diapositives d’une seule présentation en images. Essentiellement, vous pouvez convertir la présentation (dans son ensemble) en images.
Ce code exemple vous montre comment convertir toutes les diapositives d’une présentation en images :
$pres = new Presentation("Presentation.pptx");
try {
# Rendre la présentation en un tableau d'images diapositive par diapositive
for($i = 0; $i < java_values($pres->getSlides()->size()) ; $i++) {
# Contrôler les diapositives cachées (ne pas rendre les diapositives cachées)
if ($pres->getSlides()->get_Item($i)->getHidden()) {
continue;
}
# Convertir la diapositive en un objet Bitmap
$slideImage = $pres->getSlides()->get_Item($i)->getImage(2.0, 2.0);
# Enregistrer l'image au format PNG
try {
$slideImage->save("Slide_" . $i . ".png", ImageFormat::Png);
} finally {
if (!java_is_null($slideImage)) {
$slideImage->dispose();
}
}
}
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}