Gérer les cadres vidéo dans les présentations en JavaScript
Une vidéo bien placée dans une présentation peut rendre votre message plus percutant et augmenter le niveau d’engagement de votre audience.
PowerPoint vous permet d’ajouter des vidéos à une diapositive d’une présentation de deux façons :
- Ajouter ou intégrer une vidéo locale (stockée sur votre machine)
- Ajouter une vidéo en ligne (provenant d’une source web telle que YouTube).
Pour vous permettre d’ajouter des vidéos (objets vidéo) à une présentation, Aspose.Slides fournit la classe Video, la classe VideoFrame et d’autres types pertinents.
Créer un cadre vidéo intégré
Si le fichier vidéo que vous souhaitez ajouter à votre diapositive est stocké localement, vous pouvez créer un cadre vidéo pour incorporer la vidéo dans votre présentation.
- Créez une instance de la classe Presentation.
- Obtenez la référence d’une diapositive par son indice.
- Ajoutez un objet Video et transmettez le chemin du fichier vidéo pour l’intégrer à la présentation.
- Ajoutez un objet VideoFrame pour créer un cadre pour la vidéo.
- Enregistrez la présentation modifiée.
Ce code JavaScript montre comment ajouter une vidéo stockée localement à une présentation :
// Instancie la classe Presentation
var pres = new aspose.slides.Presentation("pres.pptx");
try {
// Charge la vidéo
var fileStream = java.newInstanceSync("java.io.FileInputStream", "Wildlife.mp4");
var video = pres.getVideos().addVideo(fileStream, aspose.slides.LoadingStreamBehavior.KeepLocked);
// Récupère la première diapositive et ajoute un cadre vidéo
pres.getSlides().get_Item(0).getShapes().addVideoFrame(10, 10, 150, 250, video);
// Enregistre la présentation sur le disque
pres.save("pres-with-video.pptx", aspose.slides.SaveFormat.Pptx);
} catch (e) {console.log(e);
} finally {
if (pres != null) {
pres.dispose();
}
}
Vous pouvez également ajouter une vidéo en transmettant directement son chemin de fichier à la méthode addVideoFrame(float x, float y, float width, float height, IVideo video) :
var pres = new aspose.slides.Presentation();
try {
var sld = pres.getSlides().get_Item(0);
var vf = sld.getShapes().addVideoFrame(50, 150, 300, 150, "video1.avi");
} finally {
if (pres != null) {
pres.dispose();
}
}
Créer un cadre vidéo avec une vidéo provenant d’une source Web
Microsoft PowerPoint 2013 et versions ultérieures prend en charge les vidéos YouTube dans les présentations. Si la vidéo que vous souhaitez utiliser est disponible en ligne (par ex. sur YouTube), vous pouvez l’ajouter à votre présentation via son lien web.
- Créez une instance de la classe Presentation.
- Obtenez la référence d’une diapositive par son indice.
- Ajoutez un objet Video et transmettez le lien vers la vidéo.
- Définissez une vignette pour le cadre vidéo.
- Enregistrez la présentation.
Ce code JavaScript montre comment ajouter une vidéo depuis le Web à une diapositive d’une présentation PowerPoint :
// Instancie un objet Presentation qui représente un fichier de présentation
var pres = new aspose.slides.Presentation();
try {
addVideoFromYouTube(pres, "Tj75Arhq5ho");
pres.save("out.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
if (pres != null) {
pres.dispose();
}
}
async function addVideoFromYouTube(pres, videoID) {
let slide = pres.getSlides().get_Item(0);
let videoUrl = "https://www.youtube.com/embed/" + videoID;
let videoFrame = slide.getShapes().addVideoFrame(10, 10, 427, 240, videoUrl);
videoFrame.setPlayMode(aspose.slides.VideoPlayModePreset.Auto);
let thumbnailUri = "http://img.youtube.com/vi/" + videoID + "/hqdefault.jpg";
try {
const imageStream = await getImageStream(thumbnailUri);
let image = pres.getImages().addImage(imageStream);
videoFrame.getPictureFormat().getPicture().setImage(image);
} catch (error) {
console.error("Error loading thumbnail:", error);
}
}
async function getImageStream(url) {
return new Promise((resolve, reject) => {
http.get(url, (response) => {
if (response.statusCode === 200) {
resolve(response);
} else {
reject(new Error(`Failed to load image: ${response.statusCode}`));
}
}).on('error', (e) => {
reject(e);
});
});
}
Gérer les sous-titres vidéo
Aspose.Slides vous permet de gérer les sous-titres fermés pour les cadres vidéo dans les présentations PowerPoint. Les sous-titres sont stockés au format WebVTT et sont exposés via la méthode VideoFrame.getCaptionTracks.
Ajouter des sous-titres à un cadre vidéo
Pour ajouter des sous-titres à un cadre vidéo :
- Créez une instance de la classe Presentation .
- Ajoutez une vidéo à la présentation.
- Ajoutez un objet VideoFrame à une diapositive.
- Utilisez la collection CaptionsCollection pour ajouter une piste de sous-titres WebVTT.
- Enregistrez la présentation modifiée.
Le code suivant montre comment ajouter des sous-titres à un cadre vidéo :
let presentation = new aspose.slides.Presentation();
try {
let videoStream = java.newInstanceSync("java.io.FileInputStream", "video.mp4");
let video = presentation.getVideos().addVideo(videoStream, aspose.slides.LoadingStreamBehavior.KeepLocked);
let slide = presentation.getSlides().get_Item(0);
let videoFrame = slide.getShapes().addVideoFrame(0, 0, 100, 100, video);
// Ajoute une nouvelle piste de sous-titres à partir d'un fichier WebVTT.
videoFrame.getCaptionTracks().add("English", "track.vtt");
presentation.save("video_with_captions.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
presentation.dispose();
}
La classe CaptionsCollection fournit également la méthode addFromStream qui vous permet d’ajouter des sous-titres depuis un flux.
Extraire les sous-titres d’un cadre vidéo
Pour extraire les sous-titres d’un cadre vidéo :
- Chargez la présentation contenant la vidéo.
- Repérez l’objet VideoFrame cible.
- Parcourez la collection CaptionsCollection.
- Enregistrez chaque piste de sous-titres dans un fichier
.vtt.
Le code suivant montre comment extraire les sous-titres d’un cadre vidéo :
let presentation = new aspose.slides.Presentation("video_with_captions.pptx");
try {
let slide = presentation.getSlides().get_Item(0);
let shapeCount = slide.getShapes().size();
for (let shapeIndex = 0; shapeIndex < shapeCount; shapeIndex++) {
let shape = slide.getShapes().get_Item(shapeIndex);
if (java.instanceOf(shape, "com.aspose.slides.VideoFrame")) {
let videoFrame = shape;
let trackCount = videoFrame.getCaptionTracks().getCount();
for (let trackIndex = 0; trackIndex < trackCount; trackIndex++) {
let captionTrack = videoFrame.getCaptionTracks().get_Item(trackIndex);
// Enregistre la piste de sous-titres dans un fichier WebVTT.
let filePath = captionTrack.getCaptionId() + ".vtt";
let captionData = Buffer.from(captionTrack.getBinaryData());
fs.writeFileSync(filePath, captionData);
}
}
}
} finally {
presentation.dispose();
}
Chaque objet Captions expose l’identifiant du sous-titre, le libellé, les données binaires et le texte du sous-titre sous forme de chaîne UTF‑8.
Supprimer les sous-titres d’un cadre vidéo
Pour supprimer les sous-titres d’un cadre vidéo :
- Chargez la présentation contenant la vidéo.
- Obtenez l’objet VideoFrame cible.
- Supprimez les pistes de sous-titres de la collection CaptionsCollection.
- Enregistrez la présentation modifiée.
Le code suivant montre comment supprimer tous les sous-titres d’un cadre vidéo :
let presentation = new aspose.slides.Presentation("video_with_captions.pptx");
try {
let slide = presentation.getSlides().get_Item(0);
let videoFrame = slide.getShapes().get_Item(0); // type : com.aspose.slides.VideoFrame
// Supprime tous les sous-titres du cadre vidéo.
videoFrame.getCaptionTracks().clear();
presentation.save("video_without_captions.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
presentation.dispose();
}
Si vous devez supprimer uniquement une piste de sous-titres, utilisez les méthodes remove ou removeAt à la place de clear.
Extraire la vidéo d’une diapositive
En plus d’ajouter des vidéos aux diapositives, Aspose.Slides vous permet d’extraire les vidéos intégrées dans les présentations.
- Créez une instance de la classe Presentation pour charger la présentation contenant la vidéo.
- Parcourez tous les objets Slide.
- Parcourez tous les objets Shape afin de trouver un VideoFrame.
- Enregistrez la vidéo sur le disque.
Ce code JavaScript montre comment extraire la vidéo d’une diapositive de présentation :
// Instancie un objet Presentation qui représente un fichier de présentation
var pres = new aspose.slides.Presentation("VideoSample.pptx");
try {
for (let i = 0; i < pres.getSlides().size(); i++) {
let slide = pres.getSlides().get_Item(i);
for (let j = 0; j < slide.getShapes().size(); j++) {
let shape = slide.getShapes().get_Item(j);
if (java.instanceOf(shape, "com.aspose.slides.VideoFrame")) {
var vf = shape;
console.log(shape);
var type = vf.getEmbeddedVideo().getContentType();
var ss = type.lastIndexOf('-');
const buffer = Buffer.from(vf.getEmbeddedVideo().getBinaryData());
console.log(buffer);
// Obtient l'extension de fichier
var charIndex = type.indexOf("/");
type = type.substring(charIndex + 1);
fs.writeFileSync("testing2." + type, buffer);
}
}
}
} catch (e) {console.log(e);
} finally {
if (pres != null) {
pres.dispose();
}
}
FAQ
Quels paramètres de lecture vidéo peuvent être modifiés pour un VideoFrame ?
Vous pouvez contrôler le mode de lecture (automatique ou au clic) et le bouclage. Ces options sont disponibles via les propriétés de l’objet VideoFrame.
L’ajout d’une vidéo affecte-t‑il la taille du fichier PPTX ?
Oui. Lorsque vous intégrez une vidéo locale, les données binaires sont incluses dans le document, ce qui fait croître la taille de la présentation proportionnellement à la taille du fichier. Lorsque vous ajoutez une vidéo en ligne, un lien et une vignette sont intégrés, de sorte que l’augmentation de taille est moindre.
Puis‑je remplacer la vidéo d’un VideoFrame existant sans changer sa position et sa taille ?
Oui. Vous pouvez échanger le contenu vidéo à l’intérieur du cadre tout en conservant la géométrie de la forme ; c’est un scénario fréquent pour mettre à jour les médias d’une mise en page existante.
Le type de contenu (MIME) d’une vidéo intégrée peut‑il être déterminé ?
Oui. Une vidéo intégrée possède un type de contenu que vous pouvez lire et utiliser, par exemple lors de son enregistrement sur le disque.