Enregistrer des présentations en JavaScript
Vue d’ensemble
Open Presentations in JavaScript décrit comment utiliser la classe Presentation pour ouvrir une présentation. Cet article explique comment créer et enregistrer des présentations. La classe Presentation contient le contenu d’une présentation. Que vous créiez une présentation à partir de zéro ou que vous modifiiez une existante, vous voudrez l’enregistrer une fois terminé. Avec Aspose.Slides pour Node.js, vous pouvez enregistrer dans un fichier ou un flux. Cet article explique les différentes manières d’enregistrer une présentation.
Enregistrer les présentations dans des fichiers
Enregistrez une présentation dans un fichier en appelant la méthode save de la classe Presentation. Passez le nom du fichier et le format d’enregistrement à la méthode. L’exemple suivant montre comment enregistrer une présentation avec Aspose.Slides.
// Instancier la classe Presentation qui représente un fichier de présentation.
let presentation = new aspose.slides.Presentation();
try {
// Effectuer un travail ici...
// Enregistrer la présentation dans un fichier.
presentation.save("Output.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
presentation.dispose();
}
Enregistrer les présentations dans des flux
Vous pouvez enregistrer une présentation dans un flux en passant un flux de sortie à la méthode save de la classe Presentation. Une présentation peut être écrite dans de nombreux types de flux. Dans l’exemple ci‑dessous, nous créons une nouvelle présentation et l’enregistrons dans un flux de fichier.
// Instancier la classe Presentation qui représente un fichier de présentation.
let presentation = new aspose.slides.Presentation();
try {
let fileStream = java.newInstanceSync("java.io.FileOutputStream", "Output.pptx");
try {
// Enregistrer la présentation dans le flux.
presentation.save(fileStream, aspose.slides.SaveFormat.Pptx);
} finally {
fileStream.close();
}
} finally {
presentation.dispose();
}
Enregistrer les présentations avec un type de vue prédéfini
Aspose.Slides vous permet de définir la vue initiale que PowerPoint utilise lorsque la présentation générée s’ouvre via la classe ViewProperties. Utilisez la méthode setLastView avec une valeur provenant de l’énumération ViewType.
let presentation = new aspose.slides.Presentation();
try {
presentation.getViewProperties().setLastView(aspose.slides.ViewType.SlideMasterView);
presentation.save("SlideMasterView.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
presentation.dispose();
}
Enregistrer les présentations au format Strict Office Open XML
Aspose.Slides vous permet d’enregistrer une présentation au format Strict Office Open XML. Utilisez la classe PptxOptions et définissez sa propriété de conformité lors de l’enregistrement. Si vous définissez Conformance.Iso29500_2008_Strict, le fichier de sortie est enregistré au format Strict Office Open XML.
L’exemple ci‑dessous crée une présentation et l’enregistre au format Strict Office Open XML.
let options = new aspose.slides.PptxOptions();
options.setConformance(aspose.slides.Conformance.Iso29500_2008_Strict);
// Instancier la classe Presentation qui représente un fichier de présentation.
let presentation = new aspose.slides.Presentation();
try {
// Enregistrer la présentation au format Strict Office Open XML.
presentation.save("StrictOfficeOpenXml.pptx", aspose.slides.SaveFormat.Pptx, options);
} finally {
presentation.dispose();
}
Enregistrer les présentations au format Office Open XML en mode Zip64
Un fichier Office Open XML est une archive ZIP qui impose des limites de 4 Go (2^32 octets) sur la taille décompressée de tout fichier, la taille compressée de tout fichier et la taille totale de l’archive, et limite également l’archive à 65 535 (2^16‑1) fichiers. Les extensions du format ZIP64 augmentent ces limites à 2^64.
La méthode PptxOptions.setZip64Mode vous permet de choisir quand utiliser les extensions du format ZIP64 lors de l’enregistrement d’un fichier Office Open XML.
Cette méthode peut être utilisée avec les modes suivants :
- IfNecessary utilise les extensions du format ZIP64 uniquement si la présentation dépasse les limitations ci‑dessus. C’est le mode par défaut.
- Never n’utilise jamais les extensions du format ZIP64.
- Always utilise toujours les extensions du format ZIP64.
Le code suivant montre comment enregistrer une présentation au format PPTX avec les extensions du format ZIP64 activées :
let pptxOptions = new aspose.slides.PptxOptions();
pptxOptions.setZip64Mode(aspose.slides.Zip64Mode.Always);
let presentation = new aspose.slides.Presentation("Sample.pptx");
try {
presentation.save("OutputZip64.pptx", aspose.slides.SaveFormat.Pptx, pptxOptions);
} finally {
presentation.dispose();
}
NOTE
Lorsque vous enregistrez avec Zip64Mode.Never, une PptxException est levée si la présentation ne peut pas être enregistrée au format ZIP32.Enregistrer les présentations sans actualiser la vignette
La méthode PptxOptions.setRefreshThumbnail contrôle la génération de la vignette lors de l’enregistrement d’une présentation au format PPTX :
- Si la valeur est
true, la vignette est actualisée pendant l’enregistrement. C’est la valeur par défaut. - Si la valeur est
false, la vignette actuelle est conservée. Si la présentation n’a pas de vignette, aucune n’est générée.
Dans le code ci‑dessous, la présentation est enregistrée au format PPTX sans actualiser sa vignette.
let pptxOptions = new aspose.slides.PptxOptions();
pptxOptions.setRefreshThumbnail(false);
let presentation = new aspose.slides.Presentation("Sample.pptx");
try {
presentation.save("Output.pptx", aspose.slides.SaveFormat.Pptx, pptxOptions);
}
finally {
presentation.dispose();
}
Info
Cette option permet de réduire le temps nécessaire pour enregistrer une présentation au format PPTX.Mise à jour de la progression de l’enregistrement en pourcentage
Le rapport de progression d’enregistrement est configuré via la méthode setProgressCallback sur SaveOptions et ses sous‑classes. Fournissez un proxy Java qui implémente l’interface IProgressCallback ; pendant l’exportation, le rappel reçoit des mises à jour périodiques en pourcentage.
Les extraits de code suivants montrent comment utiliser IProgressCallback.
const ExportProgressHandler = java.newProxy("com.aspose.slides.IProgressCallback", {
reporting: function(progressValue) {
// Utilisez la valeur du pourcentage de progression ici.
const progress = Math.floor(progressValue);
console.log(`${progress}% of the file has been converted.`);
}
});
let saveOptions = new aspose.slides.PdfOptions();
saveOptions.setProgressCallback(ExportProgressHandler);
let presentation = new aspose.slides.Presentation("Sample.pptx");
try {
presentation.save("Output.pdf", aspose.slides.SaveFormat.Pdf, saveOptions);
} finally {
presentation.dispose();
}
Info
Aspose a développé une application gratuite PowerPoint Splitter utilisant sa propre API. L’application vous permet de diviser une présentation en plusieurs fichiers en enregistrant les diapositives sélectionnées en tant que nouveaux fichiers PPTX ou PPT.FAQ
La fonction « enregistrement rapide » (enregistrement incrémentiel) est‑elle prise en charge afin que seules les modifications soient écrites ?
Non. L’enregistrement crée le fichier cible complet à chaque fois ; l’« enregistrement rapide » incrémentiel n’est pas pris en charge.
Est‑il sûr d’enregistrer la même instance de Presentation depuis plusieurs threads ?
Non. Une instance de Presentation n’est pas thread‑safe ; enregistrez‑la depuis un seul thread.
Que se passe‑t‑il avec les hyperliens et les fichiers liés externement lors de l’enregistrement ?
Les hyperliens sont conservés. Les fichiers liés externement (par ex. : vidéos via des chemins relatifs) ne sont pas copiés automatiquement — assurez‑vous que les chemins référencés restent accessibles.
Puis‑je définir/enregistrer les métadonnées du document (Auteur, Titre, Société, Date) ?
Oui. Les propriétés de document standard sont prises en charge et seront écrites dans le fichier lors de l’enregistrement.