Convertir des présentations PowerPoint en vidéo dans .NET

Aperçu

En convertissant votre présentation PowerPoint ou OpenDocument en vidéo, vous obtenez :

Accessibilité accrue : Tous les appareils, quelle que soit la plateforme, sont équipés de lecteurs vidéo par défaut, ce qui facilite l’ouverture ou la lecture des vidéos comparé aux applications de présentation traditionnelles.

Portée élargie : Les vidéos vous permettent d’atteindre un public plus large et de présenter les informations sous un format plus engageant. Les enquêtes et les statistiques indiquent que les gens préfèrent regarder et consommer du contenu vidéo plutôt que d’autres formes, rendant votre message plus percutant.

Dans Aspose.Slides for .NET, nous avons implémenté la prise en charge de la conversion des présentations en vidéo.

  • Utilisez Aspose.Slides for .NET pour générer des images à partir des diapositives de la présentation à une fréquence d’images spécifiée (FPS).
  • Puis, utilisez un utilitaire tiers comme ffmpeg pour assembler ces images en une vidéo.

Convertir une présentation PowerPoint en vidéo

  1. Utilisez la commande dotnet add package pour ajouter Aspose.Slides et la bibliothèque FFMpegCore à votre projet :
    • exécutez dotnet add package Aspose.Slides.NET --version 22.11.0
    • exécutez dotnet add package FFMpegCore --version 4.8.0
  2. Téléchargez ffmpeg depuis ici.
  3. FFMpegCore nécessite que vous spécifiiez le chemin vers le ffmpeg téléchargé (par ex., extrait dans “C:\tools\ffmpeg”) :
    GlobalFFOptions.Configure(new FFOptions { BinaryFolder = @"c:\tools\ffmpeg\bin" });
  1. Exécutez le code de conversion PowerPoint en vidéo.

Ce code C# montre comment convertir une présentation (containing a shape and two animation effects) en vidéo :

using System.Collections.Generic;
using Aspose.Slides;
using FFMpegCore; // utilisera les binaires FFmpeg que nous avons extraits vers C:\tools\ffmpeg plus tôt.
using Aspose.Slides.Animation;

using (Presentation presentation = new Presentation())
{
    ISlide slide = presentation.Slides[0];

    // Ajoutez une forme sourire puis animez‑la.
    IAutoShape smile = slide.Shapes.AddAutoShape(ShapeType.SmileyFace, 110, 20, 500, 500);

    IEffect effectIn = slide.Timeline.MainSequence.AddEffect(
        smile, EffectType.Fly, EffectSubtype.TopLeft, EffectTriggerType.AfterPrevious);

    IEffect effectOut = slide.Timeline.MainSequence.AddEffect(
        smile, EffectType.Fly, EffectSubtype.BottomRight, EffectTriggerType.AfterPrevious);

    effectIn.Timing.Duration = 2f;
    effectOut.PresetClassType = EffectPresetClassType.Exit;

    const int Fps = 33;
    List<string> frames = new List<string>();

    using (var animationsGenerator = new PresentationAnimationsGenerator(presentation))
    using (var player = new PresentationPlayer(animationsGenerator, Fps))
    {
        player.FrameTick += (sender, args) =>
        {
            string frame = $"frame_{(sender.FrameIndex):D4}.png";
            args.GetFrame().Save(frame);
            frames.Add(frame);
        };
        animationsGenerator.Run(presentation.Slides);
    }

    // Configurez le dossier des binaires ffmpeg. Voir cette page: https://github.com/rosenbjerg/FFMpegCore#installation
    GlobalFFOptions.Configure(new FFOptions { BinaryFolder = @"c:\tools\ffmpeg\bin" });

    // Convertissez les images en vidéo webm.
    FFMpeg.JoinImageSequence("smile.webm", Fps, frames.Select(frame => ImageInfo.FromPath(frame)).ToArray());
}

Effets vidéo

Lors de la conversion d’une présentation PowerPoint en vidéo avec Aspose.Slides for .NET, vous pouvez appliquer divers effets vidéo pour améliorer la qualité visuelle du résultat. Ces effets vous permettent de contrôler l’apparence des diapositives dans la vidéo finale en ajoutant des transitions fluides, des animations et d’autres éléments visuels. Cette section explique les options d’effet vidéo disponibles et montre comment les appliquer.

Les animations et les transitions rendent les diaporamas plus engageants et intéressants — et il en va de même pour les vidéos. Ajoutons une autre diapositive et une transition au code de la présentation précédente :

// Ajoutez une forme sourire et animez‑la.
// ...

// Ajoutez une nouvelle diapositive et une transition animée.
ISlide newSlide = presentation.Slides.AddEmptySlide(presentation.Slides[0].LayoutSlide);
newSlide.Background.Type = BackgroundType.OwnBackground;
newSlide.Background.FillFormat.FillType = FillType.Solid;
newSlide.Background.FillFormat.SolidFillColor.Color = Color.Indigo;
newSlide.SlideShowTransition.Type = TransitionType.Push;

Aspose.Slides prend également en charge les animations de texte. Dans cet exemple, nous animons les paragraphes sur des objets afin qu’ils apparaissent les uns après les autres, avec un délai d’une seconde entre chaque :

using System.Collections.Generic;
using Aspose.Slides.Export;
using Aspose.Slides;
using FFMpegCore;
using Aspose.Slides.Animation;

using (Presentation presentation = new Presentation())
{
    ISlide slide = presentation.Slides[0];

    // Ajouter du texte et des animations.
    IAutoShape autoShape = slide.Shapes.AddAutoShape(ShapeType.Rectangle, 210, 120, 300, 300);
    Paragraph para1 = new Paragraph();
    para1.Portions.Add(new Portion("Aspose Slides for .NET"));
    Paragraph para2 = new Paragraph();
    para2.Portions.Add(new Portion("Convert a PowerPoint presentation with text to video"));

    Paragraph para3 = new Paragraph();
    para3.Portions.Add(new Portion("paragraph by paragraph"));
    autoShape.TextFrame.Paragraphs.Add(para1);
    autoShape.TextFrame.Paragraphs.Add(para2);
    autoShape.TextFrame.Paragraphs.Add(para3);
    autoShape.TextFrame.Paragraphs.Add(new Paragraph());

    IEffect effect1 = slide.Timeline.MainSequence.AddEffect(
        para1, EffectType.Appear, EffectSubtype.None, EffectTriggerType.AfterPrevious);

    IEffect effect2 = slide.Timeline.MainSequence.AddEffect(
        para2, EffectType.Appear, EffectSubtype.None, EffectTriggerType.AfterPrevious);

    IEffect effect3 = slide.Timeline.MainSequence.AddEffect(
        para3, EffectType.Appear, EffectSubtype.None, EffectTriggerType.AfterPrevious);

    IEffect effect4 = slide.Timeline.MainSequence.AddEffect(
        para3, EffectType.Appear, EffectSubtype.None, EffectTriggerType.AfterPrevious);

    effect1.Timing.TriggerDelayTime = 1f;
    effect2.Timing.TriggerDelayTime = 1f;
    effect3.Timing.TriggerDelayTime = 1f;
    effect4.Timing.TriggerDelayTime = 1f;

    const int Fps = 33;
    List<string> frames = new List<string>();

    using (var animationsGenerator = new PresentationAnimationsGenerator(presentation))
    using (var player = new PresentationPlayer(animationsGenerator, Fps))
    {
        player.FrameTick += (sender, args) =>
        {
            string frame = $"frame_{(sender.FrameIndex):D4}.png";
            args.GetFrame().Save(frame);
            frames.Add(frame);
        };

        animationsGenerator.Run(presentation.Slides);
    }

    // Configurer le dossier des binaires ffmpeg. Voir cette page : https://github.com/rosenbjerg/FFMpegCore#installation
    GlobalFFOptions.Configure(new FFOptions { BinaryFolder = @"c:\tools\ffmpeg\bin" });

    // Convertir les images en vidéo webm.
    FFMpeg.JoinImageSequence("text_animation.webm", Fps, frames.Select(frame => ImageInfo.FromPath(frame)).ToArray());
}

Classes de conversion vidéo

Pour activer les tâches de conversion PowerPoint en vidéo, Aspose.Slides for .NET fournit les classes PresentationAnimationsGenerator et PresentationPlayer.

PresentationAnimationsGenerator vous permet de définir la taille du cadre pour la vidéo (qui sera créée ultérieurement) et la valeur FPS (images par seconde) via son constructeur. Si vous transmettez une instance d’une présentation, son Presentation.SlideSize sera utilisé et il génère des animations que PresentationPlayer utilise.

Lorsque les animations sont générées, un événement NewAnimation est déclenché pour chaque animation suivante, incluant un paramètre IPresentationAnimationPlayer. Cette classe représente un lecteur pour une animation individuelle.

Pour travailler avec IPresentationAnimationPlayer, vous utilisez la propriété Duration (qui donne la durée totale de l’animation) et la méthode SetTimePosition. Chaque position d’animation est définie dans la plage 0 à duration, et la méthode GetFrame renvoie alors un Bitmap représentant l’état de l’animation à ce moment‑là.

using (Presentation presentation = new Presentation())
{
    ISlide slide = presentation.Slides[0];

    // Ajoutez une forme sourire et animez‑la.
    IAutoShape smile = slide.Shapes.AddAutoShape(ShapeType.SmileyFace, 110, 20, 500, 500);

    IEffect effectIn = slide.Timeline.MainSequence.AddEffect(
        smile, EffectType.Fly, EffectSubtype.TopLeft, EffectTriggerType.AfterPrevious);

    IEffect effectOut = slide.Timeline.MainSequence.AddEffect(
        smile, EffectType.Fly, EffectSubtype.BottomRight, EffectTriggerType.AfterPrevious);

    effectIn.Timing.Duration = 2f;
    effectOut.PresetClassType = EffectPresetClassType.Exit;

    using (var animationsGenerator = new PresentationAnimationsGenerator(presentation))
    {
        animationsGenerator.NewAnimation += animationPlayer =>
        {
            Console.WriteLine($"Total animation duration: {animationPlayer.Duration}");

            animationPlayer.SetTimePosition(0);          // L'état initial de l'animation.
            Bitmap bitmap = animationPlayer.GetFrame();  // Le bitmap de l'état initial de l'animation.

            animationPlayer.SetTimePosition(animationPlayer.Duration);  // L'état final de l'animation.
            Bitmap lastBitmap = animationPlayer.GetFrame();             // La dernière image de l'animation.
            lastBitmap.Save("last.png");
        };
    }
}

Pour faire jouer toutes les animations d’une présentation simultanément, la classe PresentationPlayer est utilisée. Cette classe prend une instance de PresentationAnimationsGenerator et une valeur FPS pour les effets dans son constructeur, puis appelle l’événement FrameTick pour toutes les animations afin de les lire :

using (Presentation presentation = new Presentation("animated.pptx"))
{
    using (var animationsGenerator = new PresentationAnimationsGenerator(presentation))
    using (var player = new PresentationPlayer(animationsGenerator, 33))
    {
        player.FrameTick += (sender, args) =>
        {
            args.GetFrame().Save($"frame_{sender.FrameIndex}.png");
        };
        animationsGenerator.Run(presentation.Slides);
    }
}

Ensuite, les images générées peuvent être assemblées pour produire une vidéo. Voir la section Convertir une présentation PowerPoint en vidéo.

Animations et effets pris en charge

Lors de la conversion d’une présentation PowerPoint en vidéo avec Aspose.Slides for .NET, il est important de connaître les animations et effets pris en charge dans le résultat. Aspose.Slides prend en charge un large éventail d’effets d’entrée, de sortie et d’accentuation courants tels que fondu, vol, zoom et rotation. Cependant, certaines animations avancées ou personnalisées peuvent ne pas être entièrement conservées ou apparaître différemment dans la vidéo finale. Cette section décrit les animations et effets pris en charge.

Entrée :

Type d’animation Aspose.Slides PowerPoint
Appear non pris en charge pris en charge
Fade pris en charge pris en charge
Fly In pris en charge pris en charge
Float In pris en charge pris en charge
Split pris en charge pris en charge
Wipe pris en charge pris en charge
Shape pris en charge pris en charge
Wheel pris en charge pris en charge
Random Bars pris en charge pris en charge
Grow & Turn non pris en charge pris en charge
Zoom pris en charge pris en charge
Swivel pris en charge pris en charge
Bounce pris en charge pris en charge

Accentuation :

Type d’animation Aspose.Slides PowerPoint
Pulse non pris en charge pris en charge
Color Pulse non pris en charge pris en charge
Teeter pris en charge pris en charge
Spin pris en charge pris en charge
Grow/Shrink non pris en charge pris en charge
Desaturate non pris en charge pris en charge
Darken non pris en charge pris en charge
Lighten non pris en charge pris en charge
Transparency non pris en charge pris en charge
Object Color non pris en charge pris en charge
Complementary Color non pris en charge pris en charge
Line Color non pris en charge pris en charge
Fill Color non pris en charge pris en charge

Sortie :

Type d’animation Aspose.Slides PowerPoint
Disappear non pris en charge pris en charge
Fade pris en charge pris en charge
Fly Out pris en charge pris en charge
Float Out pris en charge pris en charge
Split pris en charge pris en charge
Wipe pris en charge pris en charge
Shape pris en charge pris en charge
Random Bars pris en charge pris en charge
Shrink & Turn non pris en charge pris en charge
Zoom pris en charge pris en charge
Swivel pris en charge pris en charge
Bounce pris en charge pris en charge

Chemins de mouvement :

Type d’animation Aspose.Slides PowerPoint
Lines pris en charge pris en charge
Arcs pris en charge pris en charge
Turns pris en charge pris en charge
Shapes pris en charge pris en charge
Loops pris en charge pris en charge
Custom Path pris en charge pris en charge

Effets de transition de diapositive pris en charge

Les effets de transition de diapositive jouent un rôle important dans la création de changements fluides et visuellement attrayants entre les diapositives d’une vidéo. Aspose.Slides for .NET prend en charge une variété d’effets de transition couramment utilisés afin de préserver le flux et le style de votre présentation d’origine. Cette section met en évidence les effets de transition pris en charge pendant le processus de conversion.

Subtil :

Type d’animation Aspose.Slides PowerPoint
Morph non pris en charge pris en charge
Fade pris en charge pris en charge
Push pris en charge pris en charge
Pull pris en charge pris en charge
Wipe pris en charge pris en charge
Split pris en charge pris en charge
Reveal non pris en charge pris en charge
Random Bars pris en charge pris en charge
Shape non pris en charge pris en charge
Uncover non pris en charge pris en charge
Cover pris en charge pris en charge
Flash pris en charge pris en charge
Strips pris en charge pris en charge

Excitant :

Type d’animation Aspose.Slides PowerPoint
Fall Over non pris en charge pris en charge
Drape non pris en charge pris en charge
Curtains non pris en charge pris en charge
Wind non pris en charge pris en charge
Prestige non pris en charge pris en charge
Fracture non pris en charge pris en charge
Crush non pris en charge pris en charge
Peel Off non pris en charge pris en charge
Page Curl non pris en charge pris en charge
Airplane non pris en charge pris en charge
Origami non pris en charge pris en charge
Dissolve pris en charge pris en charge
Checkerboard non pris en charge pris en charge
Blinds non pris en charge pris en charge
Clock pris en charge pris en charge
Ripple non pris en charge pris en charge
Honeycomb non pris en charge pris en charge
Glitter non pris en charge pris en charge
Vortex non pris en charge pris en charge
Shred non pris en charge pris en charge
Switch non pris en charge pris en charge
Flip non pris en charge pris en charge
Gallery non pris en charge pris en charge
Cube non pris en charge pris en charge
Doors non pris en charge pris en charge
Box non pris en charge pris en charge
Comb non pris en charge pris en charge
Zoom pris en charge pris en charge
Random non pris en charge pris en charge

Contenu dynamique :

Type d’animation Aspose.Slides PowerPoint
Pan non pris en charge pris en charge
Ferris Wheel pris en charge pris en charge
Conveyor non pris en charge pris en charge
Rotate non pris en charge pris en charge
Orbit non pris en charge pris en charge
Fly Through pris en charge pris en charge

FAQ

Est‑il possible de convertir des présentations protégées par mot de passe ?

Oui, Aspose.Slides for .NET permet de travailler avec des présentations protégées par mot de passe. Lors du traitement de ces fichiers, vous devez fournir le mot de passe correct afin que la bibliothèque puisse accéder au contenu de la présentation.

Aspose.Slides for .NET prend‑il en charge une utilisation dans les solutions cloud ?

Oui, Aspose.Slides for .NET peut être intégré aux applications et services cloud. La bibliothèque est conçue pour fonctionner dans des environnements serveur, garantissant haute performance et évolutivité pour le traitement par lots de fichiers.

Existe‑t‑il des limitations de taille pour les présentations lors de la conversion ?

Aspose.Slides for .NET est capable de gérer des présentations de pratiquement n’importe quelle taille. Cependant, lors du traitement de fichiers très volumineux, des ressources système supplémentaires peuvent être nécessaires, et il est parfois recommandé d’optimiser la présentation afin d’améliorer les performances.